2014-09-13 17 views
0

我試圖描述的情況,我有活動與listview1和容器,我保持片段。 它看起來像這樣enter image description hereclasscastexception提交後嘗試調用片段中的方法

黃色是帶碎片的容器。 開始時,應用程序啓動,在黃色的容器中,我保留與另一個例如listView2的片段。當我點擊listView1時,黃色部分會出現另一個顯示圖片的片段。當我想關閉這張圖片時,listview2應該出現在黃色的一面,並且一切都很好,直到這段代碼。

這裏我做的黃色的容器中的替換操作之後,我試着重新創建listview2 在更換新的片段

public void backToList() 
    { 
     FragmentTransaction fragmentTransaction = fragManager.beginTransaction(); 

     Fragment fragment =null; 

     fragment = new Presence_Fragment(); 


     fragmentTransaction.replace(R.id.main_screen_fragment_container, fragment); 
     fragmentTransaction.commit(); 
     createProperlyListViewInPresenceOrAktywnosciFragment(); 
    } 

,這裏是從片段調用CreateListViewMethod()方法

public void createProperlyListViewInPresenceOrAktywnosciFragment() 
    { 

      Presence_Fragment presence_Fragment = (Presence_Fragment) fragManager.findFragmentById(R.id.main_screen_fragment_container); 
      presence_Fragment.CreateListView(); 


    } 

的logcat的:

09-13 00:52:35.653: E/AndroidRuntime(2980): FATAL EXCEPTION: main 
09-13 00:52:35.653: E/AndroidRuntime(2980): Process: com.example.kinder, PID: 2980 
09-13 00:52:35.653: E/AndroidRuntime(2980): java.lang.ClassCastException: com.example.kinder.ChildBioFragment cannot be cast to com.example.kinder.Presence_Fragment 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.example.kinder.MainScreen.createProperlyListViewInPresenceOrAktywnosciFragment(MainScreen.java:175) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.example.kinder.MainScreen.backToList(MainScreen.java:216) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.example.kinder.ChildBioFragment$1.onClick(ChildBioFragment.java:47) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.view.View.performClick(View.java:4445) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.view.View$PerformClick.run(View.java:18446) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.os.Handler.handleCallback(Handler.java:733) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.os.Handler.dispatchMessage(Handler.java:95) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.os.Looper.loop(Looper.java:136) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at android.app.ActivityThread.main(ActivityThread.java:5139) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at java.lang.reflect.Method.invokeNative(Native Method) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at java.lang.reflect.Method.invoke(Method.java:515) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:796) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:612) 
09-13 00:52:35.653: E/AndroidRuntime(2980):  at dalvik.system.NativeStart.main(Native Method) 

logcat在容器中尋找像我仍然保留舊片段,但它不可能我已經用Presence_Fragment替換ChildBioFragment並提交。我想從Presence_fragment調用方法,所以這個代碼有什麼問題

回答

0

你在這裏做一個假設:即commit()立即執行。但是,情況並非如此。它按照文檔異步執行(在UI線程上):

提交不會立即發生;它將被安排在主線程上工作,在下次線程準備就緒時完成。執行同步提交

一種方法是調用下面的右後:

fragmentManager.executePendingTransactions(); 

參考the docs的細節:

如果你想立即執行任何此類未決操作[片段事務],您可以調用此函數(僅限於主線程)來執行此操作。

或者,只保留對您實例化的存在片段的引用(而不是從管理器中檢索它)。請記住commit()是異步運行的,所以在提交後不要試圖觸及它的任何視圖。

+0

是啊這是我放在logcat上的問題的來源,當ChildBioFragment中的onDetach方法被調用,並且當createProperlyListViewInPresenceOrAktywnosciFragment被調用時,首先被調用createProperly ..方法,然後onDetach,我的解決方案是重新創建Presence_Fragment中的列表,作品 – MyWay 2014-09-13 13:10:32

相關問題