簡體   English   中英

Android 6.0 Marshmallow:片段動畫的奇怪錯誤

[英]Android 6.0 Marshmallow : Weird error with fragment animation

我在應用程序商店中的一個應用程序與Android 5.0完美配合,但從今天起我將設備升級到6.0我發現了奇怪的錯誤。 我把它縮小到碎片過渡動畫。

ftrans.setCustomAnimations(inAnim, outAnim, inAnim, outAnim);

沒有這一行,我的應用程序也可以在6.0上正常工作,我得到這個錯誤:

10-14 14:36:51.016 23750-23820/? A/libc: Fatal signal 7 (SIGBUS), code 1, fault addr 0xb1 in tid 23820 (hwuiTask1)
10-14 14:36:51.118 200-200/? A/DEBUG: *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
10-14 14:36:51.118 200-200/? A/DEBUG: Build fingerprint: 'google/hammerhead/hammerhead:6.0/MRA58K/2256973:user/release-keys'
10-14 14:36:51.118 200-200/? A/DEBUG: Revision: '0'
10-14 14:36:51.118 200-200/? A/DEBUG: ABI: 'arm'
10-14 14:36:51.118 200-200/? A/DEBUG: pid: 23750, tid: 23820, name: hwuiTask1  >>> com.xxx.xxx <<<
10-14 14:36:51.118 200-200/? A/DEBUG: signal 7 (SIGBUS), code 1 (BUS_ADRALN), fault addr 0xb1
10-14 14:36:51.110 200-200/? W/debuggerd: type=1400 audit(0.0:54): avc: denied { search } for name="com.xxx.xxx" dev="mmcblk0p28" ino=1499496 scontext=u:r:debuggerd:s0 tcontext=u:object_r:app_data_file:s0:c512,c768 tclass=dir permissive=0
10-14 14:36:51.136 200-200/? A/DEBUG:     r0 00000073  r1 96efeed8  r2 00000002  r3 00000005
10-14 14:36:51.136 200-200/? A/DEBUG:     r4 00000006  r5 00000073  r6 00000000  r7 96eff1e8
10-14 14:36:51.136 200-200/? A/DEBUG:     r8 00000005  r9 96efebd8  sl 96eff470  fp 00000016
10-14 14:36:51.136 200-200/? A/DEBUG:     ip 000000b1  sp 96efebd8  lr 00000006  pc b5d887d2  cpsr 300f0030
10-14 14:36:51.142 200-200/? A/DEBUG:     #00 pc 0005a7d2  /system/lib/libhwui.so
10-14 14:36:51.142 200-200/? A/DEBUG:     #01 pc 0005b8a3  /system/lib/libhwui.so
10-14 14:36:51.142 200-200/? A/DEBUG:     #02 pc 00055e0b  /system/lib/libhwui.so
10-14 14:36:51.142 200-200/? A/DEBUG:     #03 pc 0005c9fd  /system/lib/libhwui.so
10-14 14:36:51.142 200-200/? A/DEBUG:     #04 pc 0001fd93  /system/lib/libhwui.so
10-14 14:36:51.142 200-200/? A/DEBUG:     #05 pc 0001006d  /system/lib/libutils.so (android::Thread::_threadLoop(void*)+112)
10-14 14:36:51.142 200-200/? A/DEBUG:     #06 pc 0005ecd3  /system/lib/libandroid_runtime.so (android::AndroidRuntime::javaThreadShell(void*)+70)
10-14 14:36:51.142 200-200/? A/DEBUG:     #07 pc 0003f3e7  /system/lib/libc.so (__pthread_start(void*)+30)
10-14 14:36:51.142 200-200/? A/DEBUG:     #08 pc 00019b43  /system/lib/libc.so (__start_thread+6)
10-14 14:36:51.500 200-200/? W/debuggerd: type=1400 audit(0.0:55): avc: denied { read } for name="kgsl-3d0" dev="tmpfs" ino=5756 scontext=u:r:debuggerd:s0 tcontext=u:object_r:gpu_device:s0 tclass=chr_file permissive=0
10-14 14:36:52.189 799-25288/? W/ActivityManager:   Force finishing activity com.xxx.xxx/.MainActivity
10-14 14:36:52.190 200-200/? E/DEBUG: AM write failed: Broken pipe
10-14 14:36:52.190 799-815/? I/BootReceiver: Copying /data/tombstones/tombstone_01 to DropBox (SYSTEM_TOMBSTONE)
10-14 14:36:52.257 799-901/? I/OpenGLRenderer: Initialized EGL, version 1.4
10-14 14:36:52.286 799-4576/? D/GraphicsStats: Buffer count: 5
10-14 14:36:52.286 799-4576/? I/WindowState: WIN DEATH: Window{d660a8a u0 com.xxx.xxx/com.xxx.xxx.MainActivity}
10-14 14:36:52.321 799-808/? I/art: Background partial concurrent mark sweep GC freed 71211(4MB) AllocSpace objects, 18(1032KB) LOS objects, 33% free, 32MB/48MB, paused 3.554ms total 114.532ms
10-14 14:36:52.372 214-214/? I/Zygote: Process 23750 exited due to signal (7)
10-14 14:36:52.379 799-1413/? I/ActivityManager: Process com.xxx.xxx (pid 23750) has died
10-14 14:36:52.386 799-1418/? I/ActivityManager: Killing 23069:com.android.documentsui/u0a35 (adj 15): empty #17
10-14 14:36:52.864 799-817/? W/WindowAnimator: Failed to dispatch window animation state change.
10-14 14:36:52.864 799-817/? W/WindowAnimator: android.os.DeadObjectException
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.os.BinderProxy.transactNative(Native Method)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.os.BinderProxy.transact(Binder.java:503)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.view.IWindow$Stub$Proxy.onAnimationStopped(IWindow.java:534)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at com.android.server.wm.WindowAnimator.updateWindowsLocked(WindowAnimator.java:286)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at com.android.server.wm.WindowAnimator.animateLocked(WindowAnimator.java:678)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at com.android.server.wm.WindowAnimator.-wrap0(WindowAnimator.java)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at com.android.server.wm.WindowAnimator$1.doFrame(WindowAnimator.java:123)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.view.Choreographer$CallbackRecord.run(Choreographer.java:856)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.view.Choreographer.doCallbacks(Choreographer.java:670)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.view.Choreographer.doFrame(Choreographer.java:603)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:844)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.os.Handler.handleCallback(Handler.java:739)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.os.Handler.dispatchMessage(Handler.java:95)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.os.Looper.loop(Looper.java:148)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at android.os.HandlerThread.run(HandlerThread.java:61)
10-14 14:36:52.864 799-817/? W/WindowAnimator:     at com.android.server.ServiceThread.run(ServiceThread.java:46)
10-14 14:36:52.983 1889-2087/? W/OpenGLRenderer: Incorrectly called buildLayer on View: ShortcutAndWidgetContainer, destroying layer...
10-14 14:36:52.983 1889-2087/? W/OpenGLRenderer: Incorrectly called buildLayer on View: ShortcutAndWidgetContainer, destroying layer...

我使用的“in”動畫如下所示:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:interpolator/accelerate_decelerate">

<alpha
    android:fromAlpha="0" android:toAlpha="1"
    android:startOffset="@integer/fadein_offset"
    android:duration="@integer/fadein_duration"/>

<scale
    android:fromXScale="0%" android:toXScale="100%" android:fromYScale="0%" android:toYScale="100%"
    android:pivotX="50%"
    android:pivotY="50%"
    android:startOffset="@integer/fadein_offset"
    android:duration="@integer/fadein_duration"/>

“out”動畫看起來完全相同,只是相反。

所以我的問題是,這個錯誤意味着什么,你如何在棉花糖中進行片段轉換?

編輯:我的addFragment方法,我使用setCustomAnimations()。 我添加了SDK檢查,因為我使用縮放動畫,這對較低的Android版本有問題。 但請注意,此代碼適用於Android <6,動畫運行正常並且已經執行了3年。

private void addFragment(Fragment f, boolean addToBackstack, String tag) {
    FragmentManager fman = getSupportFragmentManager();
    FragmentTransaction ftrans = fman.beginTransaction();

//        if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.HONEYCOMB) {
//             ftrans.setCustomAnimations(inAnim, outAnim, inAnim, outAnim);
//        }

    if(addToBackstack) ftrans.addToBackStack(tag);
    ftrans.replace(R.id.content, f, tag);
    ftrans.commit();
}

按下片段1中的按鈕,我通過界面委托給活動,然后我打電話給

@Override
public void showFacts(DBCategory category) {
    addFragment(FragFacts.Instance(category.id(), category.name()), true, FragFacts.TAG);
}

編輯2:我發現它一般不是動畫,它只是導致它的轉換的縮放動畫部分。 我把它拿出來,現在它可以工作了。

當我們進行縮放動畫時,這是Marshmallow上的錯誤。 現在我們通過設置view.setLayerType(View.LAYER_TYPE_SOFTWARE)找到了解決方法, 請參閱文檔

對我來說,這是因為Proguard混淆而被掩蓋的NullPointer異常。 在沒有Proguard的情況下運行,希望你會看到潛在的異常。

我得到了這個異常和同樣的問題Failed to dispatch window animation state change.android.os.DeadObjectException

顯然這是因為我忘了在清單文件中提及活動。 我能夠通過在AndroidManifest.xml文件中添加活動來修復它。

只需添加以下活動類名稱即可解決問題

例如:

 <activity
        android:name="packageName.ClassName"
       android:configChanges="orientation|keyboardHidden|screenSize|screenLayout"
        android:screenOrientation="portrait" 
        android:theme="@style/Theme.ActionBarSize_all_view">
    </activity>

在我的情況下,我的應用程序沒有崩潰,但活動之間的過渡是錯誤的> 6.0。 原因是其中一個活動的windowBackground屬性從其樣式設置為@null。 我對它進行了評論並得到了解決。

<style name="CustomActionBarTheme" parent="@style/Theme.AppCompat.Light.DarkActionBar">    
   <item name="android:windowBackground">@null</item>
</style>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM