2011-05-23 132 views
5

我想在我的Activity中創建一個簡單的ProgressDialog。我創造這樣的:Android中的進度對話框問題

protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 

    setContentView(R.layout.channellist); 

    final Context c=this; 

    t1=(TextView) findViewById(R.id.channellistStatus); 

    listView=(ListView) findViewById(R.id.channellist); 

    rc=RCManager.getInstance(); 

    chlistAdapter = new ChannelListAdapter(this,R.layout.channellist_row_lyt,clist); 

    listView.setAdapter(chlistAdapter); 

    t1.setText("No Channel List Found..."); 

    progDailog=ProgressDialog.show(this,"HI", "Loading"); 

    new Thread(new Runnable() { 

     @Override 
     public void run() { 
      try 
      { 
       Thread.sleep(3000); 
      } 
      catch (InterruptedException e) 
      { 
       e.printStackTrace(); 
      } 
      updateChannelList(); 
     } 
    }).start(); 

但它導致以下情況例外,即窗口管理BadToken異常。我不知道它爲什麼。請任何人都可以幫我解決這個問題嗎?

05-23 16:56:44.573: ERROR/AndroidRuntime(2494): FATAL EXCEPTION: main 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494): java.lang.RuntimeException: Unable   to start activity   ComponentInfo{com.nds.fr.activities/com.nds.fr.activities.TabGroup2Activity}: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.nds.fr.activities/com.nds.fr.activities.ChannelListing}: android.view.WindowManager$BadTokenException: Unable to add window -- token [email protected] is not valid; is your activity running? 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.startActivityNow(ActivityThread.java:2503) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:127) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:339) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.widget.TabHost$IntentContentStrategy.getContentView(TabHost.java:651) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.widget.TabHost.setCurrentTab(TabHost.java:323) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.widget.TabHost$2.onTabSelectionChanged(TabHost.java:129) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.widget.TabWidget$TabClickListener.onClick(TabWidget.java:453) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.view.View.performClick(View.java:2408) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.view.View$PerformClick.run(View.java:8818) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.os.Handler.handleCallback(Handler.java:587) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.os.Handler.dispatchMessage(Handler.java:92) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.os.Looper.loop(Looper.java:123) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at java.lang.reflect.Method.invokeNative(Native Method) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at java.lang.reflect.Method.invoke(Method.java:521) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:871) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at dalvik.system.NativeStart.main(Native Method) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494): Caused by: java.lang.RuntimeException: Unable to start activity ComponentInfo{com.nds.fr.activities/com.nds.fr.activities.ChannelListing}: android.view.WindowManager$BadTokenException: Unable to add window -- token [email protected] is not valid; is your activity running? 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.startActivityNow(ActivityThread.java:2503) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.LocalActivityManager.moveToState(LocalActivityManager.java:127) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.LocalActivityManager.startActivity(LocalActivityManager.java:339) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at com.nds.fr.activities.TabGroupActivity.startChildActivity(TabGroupActivity.java:65) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at com.nds.fr.activities.TabGroup2Activity.onCreate(TabGroup2Activity.java:10) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  ... 18 more 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494): Caused by: android.view.WindowManager$BadTokenException: Unable to add window -- token [email protected] is not valid; is your activity running? 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.view.ViewRoot.setView(ViewRoot.java:505) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:200) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:114) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.view.Window$LocalWindowManager.addView(Window.java:424) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.Dialog.show(Dialog.java:241) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ProgressDialog.show(ProgressDialog.java:107) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ProgressDialog.show(ProgressDialog.java:90) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ProgressDialog.show(ProgressDialog.java:85) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at com.nds.fr.activities.ChannelListing.onCreate(ChannelListing.java:65) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 
05-23 16:56:44.573: ERROR/AndroidRuntime(2494):  ... 25 more 
+0

你在哪裏試圖顯示對話框? – jkhouw1 2011-05-23 11:35:41

+0

嗨在我的活動.in onCreate() – bHaRaTh 2011-05-23 11:37:16

+0

嘗試把它放在onStart(),而不是。應用程序窗口尚未在onCreate中創建。 – jkhouw1 2011-05-23 11:40:04

回答

19
progDailog=ProgressDialog.show(getParent(),"HI", "Loading"); 
+0

嗨Tanmay。感謝它爲我工作。但我不明白爲什麼我們應該在這裏調用getParent()。 – bHaRaTh 2011-05-23 11:48:39

+1

我想你在這裏使用'TabActivity'作爲父類。 – 2011-05-23 11:50:22

+0

是的,你是對的。我現在明白了。再次感謝你。 – bHaRaTh 2011-05-23 11:51:53

1

在活動對用戶可見之前,您無法顯示對話框。在onResume()或onClickListener的某個按鈕中調用顯示。

+0

感謝弗拉基米爾我會嘗試它。 – bHaRaTh 2011-05-23 11:49:09

0

如果您創建一個新線程並將其設置爲睡眠一段時間,則只有新線程會睡眠。這對你創建Activity的UI線程沒有任何影響!而且,這不是一個好辦法。

此外,您的活動變得可見之前無法顯示對話框。試用onStart-方法。