0

3 つの子アクティビティを持つタブホストがあります

1)TabbarExample.java //タブ アクティビティ

2)FirstTab.java //子アクティビティ

3)SecondTab.java // 子アクティビティ

4)ThirdTab.java // 子アクティビティ

したがって、タブホストの最初の子アクティビティでは、getApplicationContext.bindService() が正常に動作し、サービスからデータを取得して UI に表示することができました。

実際には、リモート サービスから最初の子アクティビティへの値 (速度、温度など) にアクセスし、UI に表示しています。

tabhost の 2 番目の子アクティビティについては、最初の子アクティビティと同じコードを繰り返す必要がありますか。

tabhost の 2 番目と 3 番目の子アクティビティに同じコードを繰り返したくありません。

2 番目の子アクティビティ (SecondTab.java) について、いくつかの変更を行いましたが、UI がデータを取得していません。

2 番目の子アクティビティでは、データが表示されず、エラーが発生しています。

        @Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.hvacpass);
    // ((SecondTab) getApplicationContext()).doBindService();
    // doBindService();
    try {
        passcurtempcount = (TextView) findViewById(R.id.passcurtempcount);

        hvactemppass = remoteService.getHvacTemppass(); //GETTING ERRORS HERE
        passcurtempcount.setText(Integer.toString(hvactemppass));
        Toast.makeText(SecondTab.this, "Connected", Toast.LENGTH_SHORT)
                .show();
    } catch (RemoteException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    } 
}

public void onServiceConnected(ComponentName className, IBinder boundService) {
    // TODO Auto-generated method stub
    doBindService();

    remoteService = IMyRemoteService.Stub
            .asInterface((IBinder) boundService);
    Log.d(getClass().getSimpleName(), "onServiceConnected()");

    Intent i = new Intent();
    i.setClassName("com.msat.home.clusterservices",
            "com.msat.home.clusterservices.RemoteService");
    getApplicationContext().startService(i);
    getApplicationContext().bindService(i, this, Context.BIND_AUTO_CREATE);

    if(startService(i) != null) { 
        Toast.makeText(getBaseContext(), "service is already running", Toast.LENGTH_SHORT).show();
    }else {
        Toast.makeText(getBaseContext(), "There is no service running, starting service..", Toast.LENGTH_SHORT).show();
    }




}

public void onServiceDisconnected(ComponentName className) {
    // TODO Auto-generated method stub
    remoteService = null;

}

public void doBindService() {

    getApplicationContext().bindService(
            // getApplicationContext() fixed the problem here.
            new Intent(getApplicationContext(), FirstTab.class), conn,
            Context.BIND_AUTO_CREATE);


}

これらはエラーメッセージです

      09-06 12:58:55.160: E/AndroidRuntime(2512): FATAL EXCEPTION: main
      09-06 12:58:55.160: E/AndroidRuntime(2512): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.hvaccontroller.msat/com.hvaccontroller.msat.SecondTab}: java.lang.NullPointerException
      09-06 12:58:55.160: E/AndroidRuntime(2512):   at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1650)
      09-06 12:58:55.160: E/AndroidRuntime(2512):   at android.app.ActivityThread.startActivityNow(ActivityThread.java:1487)
     09-06 12:58:55.160: E/AndroidRuntime(2512):    at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:127)
     09-06 12:58:55.160: E/AndroidRuntime(2512):    at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:339)
     09-06 12:58:55.160: E/AndroidRuntime(2512):    at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:654)
     09-06 12:58:55.160: E/AndroidRuntime(2512):    at android.widget.TabHost.setCurrentTab(TabHost.java:326)
     09-06 12:58:55.160: E/AndroidRuntime(2512):    at android.widget.TabHost$2.onTabSelectionChanged(TabHost.java:132)
     09-06 12:58:55.160: E/AndroidRuntime(2512):    at android.widget.TabWidget$TabClickListener.onClick(TabWidget.java:456)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at android.view.View.performClick(View.java:2485)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at android.view.View$PerformClick.run(View.java:9080)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at android.os.Handler.handleCallback(Handler.java:587)
   09-06 12:58:55.160: E/AndroidRuntime(2512):  at android.os.Handler.dispatchMessage(Handler.java:92)
   09-06 12:58:55.160: E/AndroidRuntime(2512):  at android.os.Looper.loop(Looper.java:130)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at android.app.ActivityThread.main(ActivityThread.java:3686)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at java.lang.reflect.Method.invokeNative(Native Method)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at java.lang.reflect.Method.invoke(Method.java:507)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at dalvik.system.NativeStart.main(Native Method)
    09-06 12:58:55.160: E/AndroidRuntime(2512): Caused by: java.lang.NullPointerException
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at com.hvaccontroller.msat.SecondTab.onCreate(SecondTab.java:37)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1614)
    09-06 12:58:55.160: E/AndroidRuntime(2512):     ... 18 more
4

1 に答える 1

0

onCreate の remoteService が初期化されていないように見えるため、NullPointerException が発生します。onServiceConnected メソッドで remoteService を初期化しますが、そこでは使用しません。それがメンバー変数であり、onServiceConnected が onCreate メソッドの前に呼び出されない限り。

それはあなたが得たエラーを説明するかもしれませんが、そうでなければあなたが何を求めているのかわからない - 明確にしてもらえますか?

于 2012-11-30T08:37:15.493 に答える