一:ViewPager适配的时候,刚开始用FragmentPagerAdapter,结果和列表刷新的上滑刷新冲突,导致上滑时候有些时候刷新提示不消失的问题,后来找到了用FragmentStatePagerAdapter适配代替FragmentPagerAdapter完美的解决了这个问题;
二:在华为手机安装百度云OS系统的手机上,隔N久点击app进入,小概率会出现如下异常:
02-05 19:31:43.707: E/Parcel(28308): Class not found when unmarshalling: android.support.v4.view.ViewPager$SavedState, e: java.lang.ClassNotFoundException: android.support.v4.view.ViewPager$SavedState
02-05 19:31:43.740: E/AndroidRuntime(28308): FATAL EXCEPTION: main
02-05 19:31:43.740: E/AndroidRuntime(28308): java.lang.IllegalStateException: Could not execute method of the activity
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View$1.onClick(View.java:3607)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View.performClick(View.java:4100)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View$PerformClick.run(View.java:17021)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Handler.handleCallback(Handler.java:615)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Handler.dispatchMessage(Handler.java:92)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Looper.loop(Looper.java:137)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.app.ActivityThread.main(ActivityThread.java:4791)
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invokeNative(Native Method)
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invoke(Method.java:511)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:766)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:533)
02-05 19:31:43.740: E/AndroidRuntime(28308): at dalvik.system.NativeStart.main(Native Method)
02-05 19:31:43.740: E/AndroidRuntime(28308): Caused by: java.lang.reflect.InvocationTargetException
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invokeNative(Native Method)
02-05 19:31:43.740: E/AndroidRuntime(28308): at java.lang.reflect.Method.invoke(Method.java:511)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.view.View$1.onClick(View.java:3602)
02-05 19:31:43.740: E/AndroidRuntime(28308): ... 11 more
02-05 19:31:43.740: E/AndroidRuntime(28308): Caused by: android.os.BadParcelableException: ClassNotFoundException when unmarshalling: android.support.v4.view.ViewPager$SavedState
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readParcelable(Parcel.java:2077)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readValue(Parcel.java:1965)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readSparseArrayInternal(Parcel.java:2255)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readSparseArray(Parcel.java:1687)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readValue(Parcel.java:2022)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Parcel.readMapInternal(Parcel.java:2226)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Bundle.unparcel(Bundle.java:223)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.os.Bundle.getSparseParcelableArray(Bundle.java:1232)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:861)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1104)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:682)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1467)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentManagerImpl.executePendingTransactions(FragmentManager.java:472)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.app.FragmentStatePagerAdapter.finishUpdate(FragmentStatePagerAdapter.java:163)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.populate(ViewPager.java:1068)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:550)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.setCurrentItemInternal(ViewPager.java:509)
02-05 19:31:43.740: E/AndroidRuntime(28308): at android.support.v4.view.ViewPager.setCurrentItem(ViewPager.java:490)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.jianjian.clock.view.TouchViewPager.setCurrentItem(TouchViewPager.java:49)
02-05 19:31:43.740: E/AndroidRuntime(28308): at com.jianjian.clock.activity.MainActivity.onClick(MainActivity.java:243)
02-05 19:31:43.740: E/AndroidRuntime(28308): ... 14 more
02-05 19:31:48.433: E/MediaPlayer(14042): stop called in state 1
为了解决这个问题,在网上找到了如下的解决办法:
@Override
public Object instantiateItem(ViewGroup container, int position) {
final Object fragment = super.instantiateItem(container, position);
try {
final Field saveFragmentStateField = Fragment.class.getDeclaredField("mSavedFragmentState");
saveFragmentStateField.setAccessible(true);
final Bundle savedFragmentState = (Bundle) saveFragmentStateField.get(fragment);
if (savedFragmentState != null) {
savedFragmentState.setClassLoader(Fragment.class.getClassLoader());
}
} catch (Exception e) {
Log.w("CustomFragmentStatePagerAdapter", "Could not get mSavedFragmentState field: " + e);
}
return fragment;
}