Интеграция двух пакетов в Android - PullRequest
2 голосов
/ 15 марта 2012

У меня есть два пакета: 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. Но если он выполняется как часть другого приложения, он отлично работает!

Может кто-нибудь, пожалуйста, дайте мне знать, как избавиться от этой проблемы?

1 Ответ

1 голос
/ 16 марта 2012

Привет нашел решение моей проблемы

При интеграции двух пакетов из разных проектов я перетаскивал пакеты из папки src и gen (вместе с макетами).Итак, у меня было две копии R-файла.Но файл pakage2.R был недопустим, поскольку новый файл R был автоматически создан с новым R.id для каждого компонента в Package1 (в папке gen). Таким образом, решение было

  1. Удалить Package2 из папки gen.
  2. Импорт файла Package1.R в каждый файл Package2
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...