2012-03-27 206 views
4

我知道這個錯誤出現在論壇上數百萬次,但請幫我找到我錯過的東西。 我試圖做簡單的標籤導向的應用程序,我沒有太多的(除非錯誤)java.lang.RuntimeException:無法啓動活動ComponentInfo

1)我的主要活動是基於tablayout教程我發現了什麼

public class MainTabPanel extends TabActivity { 

    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.mainlayout); 
     Resources res = getResources(); 
     TabHost tabHost = getTabHost(); 
     TabHost.TabSpec spec; 
     Intent intent; 
     intent = new Intent().setClass(this, MyBookActivity.class); 
     spec = tabHost.newTabSpec("main") 
       .setIndicator("Main", res.getDrawable(R.drawable.ic_mybook)) 
       .setContent(intent); 
     tabHost.addTab(spec); 
     tabHost.setCurrentTab(0); 
    } 

} 

2)mainlayout。 XML

<?xml version="1.0" encoding="utf-8"?> 
<TabHost xmlns:android="http://schemas.android.com/apk/res/android" 
android:id="@android:id/tabhost" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent"> 
<LinearLayout 
    android:orientation="vertical" 
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"   
    android:padding="5dp"> 
<TabWidget 
    android:id="@android:id/tabs" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" />   

    <FrameLayout  
    android:id="@android:id/tabcontent" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:padding="5dp" /> 
</LinearLayout></TabHost> 

3)我的第二個活動是基本上幾乎是空的,它;只是顯示當前日期和時間,工作之前,我嘗試添加標籤面板

4)我的清單文件

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="org.th.mybook" 
    android:versionCode="1" 
    android:versionName="1.0" > 
    <uses-sdk android:minSdkVersion="8" /> 
    <application 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" > 
     <activity 
      android:name=".MainTabPanel" 
      android:label="@string/app_name" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 
       <category android:name="android.intent.category.LAUNCHER" /> 
      </intent-filter> 
     </activity> 
     <activity 
      android:name="MyBookActivity" 
      android:label="@string/app_name" > 
      <intent-filter> 
       <action android:name="android.intent.action.MAIN" /> 
       <category android:name="android.intent.category.ALTERNATIVE" /> 
      </intent-filter> 
     </activity> 
    </application> 
</manifest> 

5日誌貓錯誤

02-10 21:04:45.203: E/AndroidRuntime(1107): FATAL EXCEPTION: main 
02-10 21:04:45.203: E/AndroidRuntime(1107): java.lang.RuntimeException: Unable to start activity ComponentInfo{org.th.mybook/org.th.mybook.MainTabPanel}: java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{org.th.mybook/org.th.mybook.MyBookActivity}: java.lang.NullPointerException 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.os.Handler.dispatchMessage(Handler.java:99) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.os.Looper.loop(Looper.java:123) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at java.lang.reflect.Method.invokeNative(Native Method) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at java.lang.reflect.Method.invoke(Method.java:521) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at dalvik.system.NativeStart.main(Native Method) 
02-10 21:04:45.203: E/AndroidRuntime(1107): Caused by: java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{org.th.mybook/org.th.mybook.MyBookActivity}: java.lang.NullPointerException 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.startActivityNow(ActivityThread.java:2503) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:127) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:339) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:651) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.widget.TabHost.setCurrentTab(TabHost.java:323) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.widget.TabHost.addTab(TabHost.java:213) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at org.th.mybook.MainTabPanel.onCreate(MainTabPanel.java:30) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  ... 11 more 
02-10 21:04:45.203: E/AndroidRuntime(1107): Caused by: java.lang.NullPointerException 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.content.ContextWrapper.getApplicationContext(ContextWrapper.java:100) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at org.th.mybook.MyBookActivity.<init>(MyBookActivity.java:16) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at java.lang.Class.newInstanceImpl(Native Method) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at java.lang.Class.newInstance(Class.java:1429) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.Instrumentation.newActivity(Instrumentation.java:1021) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577) 
02-10 21:04:45.203: E/AndroidRuntime(1107):  ... 20 more 

請幫幫我,告訴我,我錯過了,即時通訊比較該代碼與我的舊的,我無法找到任何東西 問候

6)我的書活動

public class MyBookActivity extends Activity { 
    java.text.DateFormat dateFormat = android.text.format.DateFormat.getDateFormat(getApplicationContext()); 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.main); 
     DigitalClock clock = (DigitalClock) findViewById(R.id.digitalClock1); 
     final TextView date = (TextView) findViewById(R.id.textView1); 
     date.setText(dateFormat.format(new Date())); 
     TextWatcher watcher = new TextWatcher() { 

      @Override 
      public void afterTextChanged(Editable s) { 
      } 

      @Override 
      public void beforeTextChanged(CharSequence s, int start, int count, 
        int after) { 
      } 

      @Override 
      public void onTextChanged(CharSequence s, int start, int before, 
        int count) { 

       if (s.toString().startsWith("00:00:00") 
         || s.toString().startsWith("12:00:00")) { 
        date.setText(dateFormat.format(new Date())); 
       } 
      } 
     }; 
     clock.addTextChangedListener(watcher); 

    } 
} 

7)main.xml中的佈局 - >˚F或者我的書活動

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:gravity="right" 
    android:orientation="horizontal" > 


    <LinearLayout 
     android:id="@+id/DatePanel1" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" > 


     <TextView 
      android:id="@+id/textView1" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:layout_marginRight="@dimen/space" 
      android:layout_weight="1" 
      android:text="TextView" /> 

     <DigitalClock 
      android:id="@+id/digitalClock1" 
      android:layout_width="0dp" 
      android:layout_height="wrap_content" 
      android:layout_weight="1" 
      android:text="DigitalClock" /> 
    </LinearLayout> 

</LinearLayout> 
+0

您是否實施了MyBookActivity? – jpm 2012-03-27 22:14:47

+1

是的,請發佈代碼爲「MyBookActivity」,如果你還沒有實現它,然後實現它,這將解決您的問題。 – Mayank 2012-03-27 22:20:01

+0

正如我所說我沒有在這裏添加,因爲它工作之前我添加標籤,但現在我張貼代碼+佈局文件 – user902383 2012-03-28 06:08:14

回答

2

這是我自己的愚蠢:

java.text.DateFormat dateFormat = android.text.format.DateFormat.getDateFormat(getApplicationContext()); 

把這個位onCreate方法內固定我的問題

感謝大家的幫助

8
<activity 
     android:name="MyBookActivity" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 
      <category android:name="android.intent.category.ALTERNATIVE" /> 
     </intent-filter> 
    </activity> 

哪裏是MyBookActivity之前你點?

+1

我會檢查,但我不認爲這是問題,我檢查了一個工作示例,並且點只在主要活動之前 – user902383 2012-03-28 06:14:17

4

Manifest必須更改等確定像".YourActivityname"這個活動的名稱必須

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
package="org.th.mybook" 
android:versionCode="1" 
android:versionName="1.0" > 

<uses-sdk 
    android:minSdkVersion="8" android:targetSdkVersion="8" /> 

<application 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" > 
    <activity 
     android:name=".MainTabPanel" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 
      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
    <activity 
     android:name=".MyBookActivity" >    
    </activity> 
</application> 

0

我有同樣的問題,我清理和重建項目,它的工作。

相關問題