2016-12-02 20 views
11

Projemde kitaplık lapism/SearchView (https://github.com/lapism/SearchView) kullanıyorum. Ama sadece Android 5.0 üzerinde çalışma zamanı özel aşağıdaki olsun:Void android.view.View.setElevation (float) lapism/null nesnesinde void çağrılabilir/SearchView

A/art: art/runtime/check_jni.cc:65] JNI DETECTED ERROR IN APPLICATION: can't call void android.view.View.setElevation(float) on null object 
A/art: art/runtime/check_jni.cc:65]  in call to CallVoidMethodV 
A/art: art/runtime/check_jni.cc:65]  from void android.animation.PropertyValuesHolder.nCallFloatMethod(java.lang.Object, long, float) 
A/art: art/runtime/check_jni.cc:65] "main" prio=5 tid=1 Runnable 
A/art: art/runtime/check_jni.cc:65] | group="main" sCount=0 dsCount=0 obj=0x757838b0 self=0xb8994958 
A/art: art/runtime/check_jni.cc:65] | sysTid=28467 nice=0 cgrp=apps sched=0/0 handle=0xb6f80058 
A/art: art/runtime/check_jni.cc:65] | state=R schedstat=(0 0 0) utm=27 stm=10 core=1 HZ=100 
A/art: art/runtime/check_jni.cc:65] | stack=0xbe01e000-0xbe020000 stackSize=8MB 
A/art: art/runtime/check_jni.cc:65] | held mutexes= "mutator lock"(shared held) 
A/art: art/runtime/check_jni.cc:65] native: #00 pc 00004828 /system/lib/libbacktrace_libc++.so (UnwindCurrent::Unwind(unsigned int, ucontext*)+23) 
A/art: art/runtime/check_jni.cc:65] native: #01 pc 00002ec5 /system/lib/libbacktrace_libc++.so (Backtrace::Unwind(unsigned int, ucontext*)+8) 
A/art: art/runtime/check_jni.cc:65] native: #02 pc 0024437d /system/lib/libart.so (art::DumpNativeStack(std::__1::basic_ostream<char, std::__1::char_traits<char> >&, int, char const*, art::mirror::ArtMethod*)+68) 
A/art: art/runtime/check_jni.cc:65] native: #03 pc 0022774b /system/lib/libart.so (art::Thread::DumpStack(std::__1::basic_ostream<char, std::__1::char_traits<char> >&) const+394) 
A/art: art/runtime/check_jni.cc:65] native: #04 pc 000af2db /system/lib/libart.so (art::JniAbort(char const*, char const*)+582) 
A/art: art/runtime/check_jni.cc:65] native: #05 pc 000afa21 /system/lib/libart.so (art::JniAbortF(char const*, char const*, ...)+60) 
A/art: art/runtime/check_jni.cc:65] native: #06 pc 000b0613 /system/lib/libart.so (art::ScopedCheck::CheckVirtualMethod(_jobject*, _jmethodID*)+402) 
A/art: art/runtime/check_jni.cc:65] native: #07 pc 000ba087 /system/lib/libart.so (art::CheckJNI::CallVoidMethodV(_JNIEnv*, _jobject*, _jmethodID*, std::__va_list)+70) 
A/art: art/runtime/check_jni.cc:65] native: #08 pc 0006028f /system/lib/libandroid_runtime.so (???) 
A/art: art/runtime/check_jni.cc:65] native: #09 pc 000721e5 /data/dalvik-cache/arm/[email protected]@boot.oat (Java_android_animation_PropertyValuesHolder_nCallFloatMethod__Ljava_lang_Object_2JF+132) 
A/art: art/runtime/check_jni.cc:65] at android.animation.PropertyValuesHolder.nCallFloatMethod(Native method) 
A/art: art/runtime/check_jni.cc:65] at android.animation.PropertyValuesHolder.access$400(PropertyValuesHolder.java:38) 
A/art: art/runtime/check_jni.cc:65] at android.animation.PropertyValuesHolder$FloatPropertyValuesHolder.setAnimatedValue(PropertyValuesHolder.java:1296) 
A/art: art/runtime/check_jni.cc:65] at android.animation.ObjectAnimator.animateValue(ObjectAnimator.java:952) 
A/art: art/runtime/check_jni.cc:65] at android.animation.ValueAnimator.animationFrame(ValueAnimator.java:1207) 
A/art: art/runtime/check_jni.cc:65] at android.animation.ValueAnimator.doAnimationFrame(ValueAnimator.java:1248) 
A/art: art/runtime/check_jni.cc:65] at android.animation.ValueAnimator$AnimationHandler.doAnimationFrame(ValueAnimator.java:659) 
A/art: art/runtime/check_jni.cc:65] at android.animation.ValueAnimator$AnimationHandler.run(ValueAnimator.java:682) 
A/art: art/runtime/check_jni.cc:65] at android.view.Choreographer$CallbackRecord.run(Choreographer.java:792) 
A/art: art/runtime/check_jni.cc:65] at android.view.Choreographer.doCallbacks(Choreographer.java:596) 
A/art: art/runtime/check_jni.cc:65] at android.view.Choreographer.doFrame(Choreographer.java:556) 
A/art: art/runtime/check_jni.cc:65] at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:778) 
A/art: art/runtime/check_jni.cc:65] at android.os.Handler.handleCallback(Handler.java:739) 
A/art: art/runtime/check_jni.cc:65] at android.os.Handler.dispatchMessage(Handler.java:95) 
A/art: art/runtime/check_jni.cc:65] at android.os.Looper.loop(Looper.java:155) 
A/art: art/runtime/check_jni.cc:65] at android.app.ActivityThread.main(ActivityThread.java:5696) 
A/art: art/runtime/check_jni.cc:65] at java.lang.reflect.Method.invoke!(Native method) 
A/art: art/runtime/check_jni.cc:65] at java.lang.reflect.Method.invoke(Method.java:372) 
A/art: art/runtime/check_jni.cc:65] at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1028) 
A/art: art/runtime/check_jni.cc:65] at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:823) 

Lütfen herkes nasıl bu sorunu çözmek için herhangi bir fikir mi?

+0

Kodunuzu yazın. –

+0

Android 4.4, Android 5, Android 6'yı denediniz mi? –

cevap

39

Bu sorunu düzeltmek için, SearchView ve AppBarLayout içeriklerini içeren XML dosyanızı güncellemeniz gerekir. android:stateListAnimator="@null", aşağıda gösterildiği gibi AppBarLayout numaranıza ekleyin. Bu android:stateListAnimator="@null" nitelik stateListAnimator sadece API düzeyinde 21. kullanılır Ama kütüphanenin kaynak kodunu kontrol ettik ve onu ayarlamaya çalıştığında o SearchBehavior sınıfta çöküyor konusunda uyararak gösterir

<android.support.design.widget.AppBarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:stateListAnimator="@null"> 

mAppBarLayout.setStateListAnimator(null);

Bu konu android bileşenlerine daha ilişkilidir altında

DÜZENLEME

olarak yorumlarda söz oldu native crash on scrolling in RecyclerView+CollapsingToolbarLayout

+0

Çok teşekkürler! Çözümünüz çalışıyor. –

+1

Bu sorunun da farklı bir durumda olduğunu düşünüyorum ve bence bu geçici çözüm de orada çalışıyor: https://issuetracker.google.com/issues/64431012 –

+0

Teşekkürler! Bu düzeltildi. – X09