场景转换animation上的JNI错误 – 图层超过最大值

请注意问题底部的编辑

我有两个活动: ActivityAActivityB与相关的frgments:分别为FragmentAFragmentBImageView v在这两个片段之间共享。

一些代码: ActivityA

 Intent intent = new Intent(this, ActivityB.class); final ActivityOptionsCompat activityOptionsCompat = ActivityOptionsCompat. makeSceneTransitionAnimation(this, imageView, "photo"); ActivityCompat.startActivity(this, intent, activityOptionsCompat.toBundle()); 

ActivityB

 FragmentB fragment = new FragmentB(); getFragmentManager().beginTransaction()..replace(R.id.fragment_container, fragment, TAG).addToBackStack(TAG).commit(); 

FragmentB

 mView = (ImageView) view.findViewById(R.id.view); ViewCompat.setTransitionName(mView, "photo); 

4次,5次,它的工作。 但是当它不工作我得到非常翔实的错误:

 W/OpenGLRenderer﹕ Layer exceeds max. dimensions supported by the GPU (1080x10659, max=4096x4096) JNI DETECTED ERROR IN APPLICATION: JNI CallVoidMethodV called with pending exception 'java.lang.IllegalStateException' thrown in void android.os.MessageQueue.nativePollOnce(long, int):-2 

打电话给Picasso

 Picasso.with(context).load(url).centerCrop().resize(width, height).noFade().into(mView); 

几件事情,可以导致这一点:

  1. FragmentB mView位置是使用ViewTreeObserver.OnGlobalLayoutListenerdynamic计算的

  2. mView扩展ImageView ,以便在这两个片段中创build椭圆效果。

  3. ViewGroup是一个ScrollView

最后一件事:这两个活动的Theme是一个孩子的

 <style name="Theme" parent="Theme.AppCompat.Light" <item name="android:windowContentTransitions">true</item> <item name="android:windowAllowEnterTransitionOverlap">true</item> <item name="android:windowAllowReturnTransitionOverlap">true</item> <item name="android:windowSharedElementEnterTransition">@android:transition/move</item> <item name="android:windowSharedElementExitTransition">@android:transition/move</item> </style> 

—编辑—

类似的问题和答案,我的问题 和另一个

答案解决问题,但只适用于API 21 。 我正在使用ActivityCompat.startActivity(...) 。 它支持API 16及以上版本, TransitionListener仅在API 19之后可用, SceneTransitionAPI 21以来支持SceneTransition

另外android:transitionGroup="true"需要API 21所以现在我有两个主要问题:

  1. 为什么我甚至得到LayerExceeds max错误? 我的共享View不超过1080×1080。
  2. 我怎么能处理这种错误的API <21 ,其中TransitionListenertransitionGroup都不可用?

错误stacktrace

 JNI DETECTED ERROR IN APPLICATION: JNI CallVoidMethodV called with pending exception 'java.lang.IllegalStateException' thrown in void android.os.MessageQueue.nativePollOnce(long, int):-2 in call to CallVoidMethodV art/runtime/check_jni.cc:65] from void android.os.MessageQueue.nativePollOnce(long, int) art/runtime/check_jni.cc:65] "main" prio=5 tid=1 Runnable art/runtime/check_jni.cc:65] | group="main" sCount=0 dsCount=0 obj=0x72fb6000 self=0xb4827800 art/runtime/check_jni.cc:65] | sysTid=6497 nice=0 cgrp=default sched=0/0 handle=0xb6f83bec art/runtime/check_jni.cc:65] | state=R schedstat=( 1181860917 459124594 2277 ) utm=100 stm=18 core=2 HZ=100 art/runtime/check_jni.cc:65] | stack=0xbe27d000-0xbe27f000 stackSize=8MB art/runtime/check_jni.cc:65] | held mutexes= "mutator lock"(shared held) art/runtime/check_jni.cc:65] native: #00 pc 00004e64 /system/lib/libbacktrace_libc++.so (UnwindCurrent::Unwind(unsigned int, ucontext*)+23) art/runtime/check_jni.cc:65] native: #01 pc 00003665 /system/lib/libbacktrace_libc++.so (Backtrace::Unwind(unsigned int, ucontext*)+8) art/runtime/check_jni.cc:65] native: #02 pc 00256429 /system/lib/libart.so (art::DumpNativeStack(std::__1::basic_ostream<char, std::__1::char_traits<char> >&, int, char const*, art::mirror::ArtMethod*)+84) art/runtime/check_jni.cc:65] native: #03 pc 00238fe7 /system/lib/libart.so (art::Thread::Dump(std::__1::basic_ostream<char, std::__1::char_traits<char> >&) const+158) art/runtime/check_jni.cc:65] native: #04 pc 000b191b /system/lib/libart.so (art::JniAbort(char const*, char const*)+610) art/runtime/check_jni.cc:65] native: #05 pc 000b2055 /system/lib/libart.so (art::JniAbortF(char const*, char const*, ...)+68) art/runtime/check_jni.cc:65] native: #06 pc 000b530f /system/lib/libart.so (art::ScopedCheck::ScopedCheck(_JNIEnv*, int, char const*)+1346) art/runtime/check_jni.cc:65] native: #07 pc 000bd6f7 /system/lib/libart.so (art::CheckJNI::CallVoidMethodV(_JNIEnv*, _jobject*, _jmethodID*, std::__va_list)+42) art/runtime/check_jni.cc:65] native: #08 pc 0006244b /system/lib/libandroid_runtime.so (???) art/runtime/check_jni.cc:65] native: #09 pc 000760c5 /system/lib/libandroid_runtime.so (android::NativeDisplayEventReceiver::dispatchVsync(long long, int, unsigned int)+40) native: #10 pc 0007628d /system/lib/libandroid_runtime.so (android::NativeDisplayEventReceiver::handleEvent(int, int, void*)+80) native: #11 pc 00012545 /system/lib/libutils.so (android::Looper::pollInner(int)+484) native: #12 pc 000125ed /system/lib/libutils.so (android::Looper::pollOnce(int, int*, int*, void**)+92) native: #13 pc 00081709 /system/lib/libandroid_runtime.so (android::NativeMessageQueue::pollOnce(_JNIEnv*, int)+22) native: #14 pc 000b3863 /data/dalvik-cache/arm/system@framework@boot.oat (Java_android_os_MessageQueue_nativePollOnce__JI+102) at android.os.MessageQueue.nativePollOnce(Native method) at android.os.MessageQueue.next(MessageQueue.java:143) at android.os.Looper.loop(Looper.java:122) at android.app.ActivityThread.main(ActivityThread.java:5254) at java.lang.reflect.Method.invoke!(Native method) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) Fatal signal 11 (SIGSEGV), code 1, fault addr 0xfffffff0 in tid 6497 

    接受的第二个问题的答案讨论了这种情况发生的原因:大小限制在整个预渲染目标Activity上,而不仅仅是转换的元素。 将android:transitionGroup="true"到转换布局中的适当位置将会修复崩溃。 你没有在问题中发布你的布局,所以很难知道会去哪里,但如果你有一个ScrollView或其他非常长的视图,这将是一个很好的开始。

    对于21之前的API级别,这是一个非问题。 AppCompat.startActivity()将在21以下的API级别上工作,但共享元素转换animation将不会运行。 它将回退到默认的活动转换。