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