日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > 綜合技術 > android之Fragment的bug解決

android之Fragment的bug解決

來源:程序員人生   發布時間:2014-12-24 08:51:33 閱讀次數:3793次

最近做1個功能,當第2次進入1個界面的時候出現1個奇怪的bug,以下面詳細的log信息:

10-01 13:36:23.549: E/AndroidRuntime(14188): Process: com.android.settings, PID: 14188 10-01 13:36:23.549: E/AndroidRuntime(14188): android.view.InflateException: Binary XML file line #43: Error inflating class fragment 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:713) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.view.LayoutInflater.rInflate(LayoutInflater.java:755) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.view.LayoutInflater.inflate(LayoutInflater.java:492) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.view.LayoutInflater.inflate(LayoutInflater.java:397) 10-01 13:36:23.549: E/AndroidRuntime(14188): at com.android.settings.accessibility.ToggleCaptioningPreferenceFragment.onCreateView(ToggleCaptioningPreferenceFragment.java:69) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.Fragment.performCreateView(Fragment.java:1700) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:890) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.FragmentManagerImpl.moveToState(FragmentManager.java:1062) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.BackStackRecord.run(BackStackRecord.java:698) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1447) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.FragmentManagerImpl$1.run(FragmentManager.java:443) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.os.Handler.handleCallback(Handler.java:808) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.os.Handler.dispatchMessage(Handler.java:103) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.os.Looper.loop(Looper.java:193) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.ActivityThread.main(ActivityThread.java:5333) 10-01 13:36:23.549: E/AndroidRuntime(14188): at java.lang.reflect.Method.invokeNative(Native Method) 10-01 13:36:23.549: E/AndroidRuntime(14188): at java.lang.reflect.Method.invoke(Method.java:515) 10-01 13:36:23.549: E/AndroidRuntime(14188): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:824) 10-01 13:36:23.549: E/AndroidRuntime(14188): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640) 10-01 13:36:23.549: E/AndroidRuntime(14188): at dalvik.system.NativeStart.main(Native Method) 10-01 13:36:23.549: E/AndroidRuntime(14188): Caused by: java.lang.IllegalArgumentException: Binary XML file line #43: Duplicate id 0x7f0b0034, tag null, or parent id 0xffffffff with another fragment for com.android.settings.accessibility.CaptionPropertiesFragment 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.app.Activity.onCreateView(Activity.java:4912) 10-01 13:36:23.549: E/AndroidRuntime(14188): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
如上的log信息可以知道:加載了1個(Duplicate)重復的Fragment(CaptionPropertiesFragment)。問題是代碼應當是沒有問題的!具體看看我系的代碼:

public class ToggleCaptioningPreferenceFragment extends Fragment { private static final float DEFAULT_FONT_SIZE = 48f; private CaptionPropertiesFragment mPropsFragment; private SubtitleView mPreviewText; private CaptioningManager mCaptioningManager; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mCaptioningManager = (CaptioningManager) getActivity() .getSystemService(Context.CAPTIONING_SERVICE); } @Override public View onCreateView( LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { final View rootView = inflater.inflate(R.layout.captioning_preview, container, false); // We have to do this now because PreferenceFrameLayout looks at it // only when the view is added. if (container instanceof PreferenceFrameLayout) { ((PreferenceFrameLayout.LayoutParams) rootView.getLayoutParams()).removeBorders = true; } return rootView; }

從報錯信息可以知道出錯的代碼:final View rootView = inflater.inflate(R.layout.captioning_preview, container, false);

那末報錯信息說是加載了重復的Fragment(CaptionPropertiesFragment)。實際上這個重復的Fragment在這個layout文件里面布局的:R.layout.captioning_preview。

很明顯,就是第1次進入這個界面,再退出的時候,這個用過的Fragment(CaptionPropertiesFragment)沒有remove掉!從而出現了兩個問題:

(1)為何會出現這個Fragment(CaptionPropertiesFragment)沒有remove,

(2)怎樣解決這個問題!

        在activity中不同的frament之間項目替換的時候,FragmentManager只會remove和add這些frament,但是這些frament里面自己加載的frament(這里就是我們的CaptionPropertiesFragment)是沒有被remove. 很明顯這是1個缺點!由于后1個frament(CaptionPropertiesFragment)很明顯是依賴與他的父frament的,應當同時遞歸的remove.

        那末如何解決這個問題呢!很明顯就是在不用這個frament(ToggleCaptioningPreferenceFragment)的時候把他里面加載的frament給remove掉!這個操作在ToggleCaptioningPreferenceFragment的onDestroyView()里面就能夠解決問題了!以下代碼:

@Override public void onDestroyView() { super.onDestroyView(); if(mPropsFragment != null){ FragmentManager f = getFragmentManager(); if(f != null && !f.isDestroyed()){ final FragmentTransaction ft = f.beginTransaction(); if(ft != null){ ft.remove(mPropsFragment).commit(); } } } }
      這里要注意f.isDestroyed()這樣來判斷是不是這個FragmentManager處于Destroyed,如果不加這個判斷的話,橫豎屏切換時候會出錯!

     注意:對這個問題,網上有各種無效的解決辦法。

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 免费福利在线观看 | 91精品一区二区三区久久久久久 | 日韩美女一区 | 九九在线| 中文字幕不卡在线观看 | 久久久久久久一区 | 欧美日韩在线免费 | 久草一区 | 日韩欧美亚洲国产精品字幕久久久 | 三级av网址 | 欧美精品久久久久a | 久久久久久穴 | 欧美精品免费在线观看 | 黄色电影地址 | 99视频一区二区 | 国产99在线视频 | 大陆一级毛片免费视频观看 | 国产成人网 | 久久久久久国产精品免费免费狐狸 | 国产精品日韩精品 | 免费99视频| 成人免费福利 | 看片一区二区 | 成人av在线网站 | 久久精品国产亚洲 | 亚洲欧美综合精品久久成人 | 午夜精品久久久久久99热软件 | 91av日本| 国产乱码精品一区二区三区中文 | 韩日中文字幕 | 99久久久久 | 天堂在线资源8 | 欧美一区二区在线观看视频 | 91这里只有精品 | 成人国产在线视频 | 国产精品欧美一区二区三区 | 在线免费看黄 | 红桃www.ht123成人 | 免费看v片| 亚洲久久色 | 亚洲精品美女久久久久99 |