У меня есть два пакета: com.android.package1 и com.android.package2
Активность в package1 (скажем, A) хочет запустить активность в package2 (скажем, B)
Для этого я использовал следующий метод
Intent to_start_B = new Intent(A.this,com.android.Package2.B.class);
startActivity(to_start_B);
Это отлично работает для других действий, кроме этого (так что никаких проблем с манифестом и вызовом) !!
код этого конкретного действия B:
public class B extends Activity {
private Logger logger = Logger.getMyLogger(this.getClass().getName());
private MicroRuntimeServiceBinder microRuntimeServiceBinder;
private ServiceConnection serviceConnection;
static final int CHAT_REQUEST = 0;
static final int SETTINGS_REQUEST = 1;
private MyReceiver myReceiver;
private MyHandler myHandler;
private TextView infoTextView;
private static String nickname="";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
myReceiver = new MyReceiver();
IntentFilter killFilter = new IntentFilter();
killFilter.addAction("jade.demo.chat.KILL");
registerReceiver(myReceiver, killFilter);
IntentFilter showChatFilter = new IntentFilter();
showChatFilter.addAction("jade.demo.chat.SHOW_CHAT");
registerReceiver(myReceiver, showChatFilter);
myHandler = new MyHandler();
nickname = "Ganesh";//getIntent().getExtras().getString("uname");
setContentView(R.layout.chat_main);
Button button = (Button) findViewById(R.id.btn_chatroom);
button.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
// TODO Auto-generated method stub
if (!checkName(nickname)) {
logger.info("Invalid nickname!");
myHandler.postError(getString(R.string.msg_nickname_not_valid));
} else {
try {
SharedPreferences settings = getSharedPreferences(
"jadeChatPrefsFile", 0);
String host = settings.getString("defaultHost", "");
String port = settings.getString("defaultPort", "");
infoTextView.setText(getString(R.string.msg_connecting_to)
+ " " + host + ":" + port + "...");
startChat(nickname, host, port, agentStartupCallback);
} catch (Exception ex) {
logger.severe("Unexpected exception creating chat agent!");
infoTextView.setText(getString(R.string.msg_unexpected));
}
}
}
});
infoTextView = (TextView) findViewById(R.id.infoTextView);
infoTextView.setText("");
}
Я получаю сообщение об ошибке следующим образом
03-07 11:36:25.399: W/dalvikvm(8493): threadid=1: thread exiting with uncaught exception (group=0x40015560)
03-07 11:36:25.409: E/AndroidRuntime(8493): FATAL EXCEPTION: main
03-07 11:36:25.409: E/AndroidRuntime(8493): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.android.home/chat.client.gui.MainActivity}: java.lang.NullPointerException
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.os.Handler.dispatchMessage(Handler.java:99)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.os.Looper.loop(Looper.java:123)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.ActivityThread.main(ActivityThread.java:3683)
03-07 11:36:25.409: E/AndroidRuntime(8493): at java.lang.reflect.Method.invokeNative(Native Method)
03-07 11:36:25.409: E/AndroidRuntime(8493): at java.lang.reflect.Method.invoke(Method.java:507)
03-07 11:36:25.409: E/AndroidRuntime(8493): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-07 11:36:25.409: E/AndroidRuntime(8493): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-07 11:36:25.409: E/AndroidRuntime(8493): at dalvik.system.NativeStart.main(Native Method)
03-07 11:36:25.409: E/AndroidRuntime(8493): Caused by: java.lang.NullPointerException
03-07 11:36:25.409: E/AndroidRuntime(8493): at chat.client.gui.MainActivity.onCreate(MainActivity.java:96)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-07 11:36:25.409: E/AndroidRuntime(8493): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
03-07 11:36:25.409: E/AndroidRuntime(8493): ... 11 more
Так что в основном его проблема связана только с этой конкретной деятельностью B.
Но если он выполняется как часть другого приложения, он отлично работает!
Может кто-нибудь, пожалуйста, дайте мне знать, как избавиться от этой проблемы?