2016-09-05 14 views
1

一部のデバイスでこの例外が発生していますが、何が原因なのかわかりません。Android Snackbarが原因でIndexOutOfBoundsExceptionが発生する

java.util.ArrayList.throwIndexOutOfBoundsException (ArrayList.java:255) 
java.util.ArrayList.get (ArrayList.java:308) 
android.support.design.widget.CoordinatorLayout.onChildViewsChanged (CoordinatorLayout.java:1225) android.support.design.widget.CoordinatorLayout$HierarchyChangeListener.onChildViewRemoved (CoordinatorLayout.java:2863) 
android.view.ViewGroup.dispatchViewRemoved (ViewGroup.java:4226) 
android.view.ViewGroup.removeViewInternal (ViewGroup.java:4627) 
android.view.ViewGroup.removeViewInternal (ViewGroup.java:4582) 
android.view.ViewGroup.removeView (ViewGroup.java:4513) 
android.support.design.widget.Snackbar.onViewHidden (Snackbar.java:646) 
android.support.design.widget.Snackbar.access$300 (Snackbar.java:72) 
android.support.design.widget.Snackbar$9.onAnimationEnd (Snackbar.java:588) 
android.support.v4.view.ViewPropertyAnimatorCompatJB$1.onAnimationEnd (ViewPropertyAnimatorCompatJB.java:47) 
android.view.ViewPropertyAnimator$AnimatorEventListener.onAnimationEnd (ViewPropertyAnimator.java:1114) 
android.animation.ValueAnimator.endAnimation (ValueAnimator.java:1239) 
android.animation.ValueAnimator$AnimationHandler.doAnimationFrame (ValueAnimator.java:766) 
android.animation.ValueAnimator$AnimationHandler$1.run (ValueAnimator.java:801) 
android.view.Choreographer$CallbackRecord.run (Choreographer.java:873) 
android.view.Choreographer.doCallbacks (Choreographer.java:676) 
android.view.Choreographer.doFrame (Choreographer.java:603) 
android.view.Choreographer$FrameDisplayEventReceiver.run (Choreographer.java:859) 
android.os.Handler.handleCallback (Handler.java:739) 
android.os.Handler.dispatchMessage (Handler.java:95) 
android.os.Looper.loop (Looper.java:168) 
android.app.ActivityThread.main (ActivityThread.java:5845) 
java.lang.reflect.Method.invoke (Method.java) 
com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:797) 
com.android.internal.os.ZygoteInit.main (ZygoteInit.java:687) 

私はcontent_mail xmlファイルが含まれてapp_bar_main.xmlに含めるとactivity_main xmlファイルを持っています。

activity_main.xml

<?xml version="1.0" encoding="utf-8"?> 
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:id="@+id/drawer_layout" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true" 
    tools:openDrawer="start"> 

    <include 
     layout="@layout/app_bar_main" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" /> 

    <android.support.design.widget.NavigationView 
     android:id="@+id/nav_view" 
     android:layout_width="wrap_content" 
     android:layout_height="match_parent" 
     android:layout_gravity="start" 
     android:fitsSystemWindows="true" 
     app:headerLayout="@layout/nav_header_main" 
     app:menu="@menu/activity_main_drawer" /> 

</android.support.v4.widget.DrawerLayout> 

app_bar_main.xml

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:id="@+id/bar_layout" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true" 
    tools:context=".application.activities.MainActivity"> 

    <android.support.design.widget.AppBarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:theme="@style/AppTheme.AppBarOverlay"> 

     <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:background="?attr/colorPrimary" 
      app:popupTheme="@style/AppTheme.PopupOverlay" /> 

    </android.support.design.widget.AppBarLayout> 

    <include layout="@layout/content_main" /> 

</android.support.design.widget.CoordinatorLayout> 

content_main.xml

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    app:layout_behavior="@string/appbar_scrolling_view_behavior" 
    tools:context=".application.activities.MainActivity" 
    tools:showIn="@layout/app_bar_main"> 

    <android.support.design.widget.CoordinatorLayout 
     android:id="@+id/container" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" /> 

</android.support.design.widget.CoordinatorLayout> 

私は標準コンテンツビューでスナックバーを作っていますが、例外のためにほとんどランダムな瞬間にクラッシュします。私のデバイス/エミュレータでは、私はエラーを再現できません(最初に再現できましたが、Snackbarの表示をandroid.R.id.contentに変更してから、デバイスに表示されなくなりました) 。しかし、私の友人のHTC M8(Android 6.0)のような他のデバイスでは例外が表示されます。

Snackbar.make(findViewById(android.R.id.content), "Updating " + info.type, Snackbar.LENGTH_LONG).show(); 

UPDATE 1: 似の問題私は古いAndroidのサポートライブラリのバージョン(V24へのダウングレードによって私の問題を解決した

+0

あなたは(はい、付属のコードで私は 'Snackbar.makeを使用し、[この](http://stackoverflow.com/questions/30986163/arrayindexoutofboundsexception-while-dismissing-snackbar-viewdraghelper) – Shaishav

+0

@Shaishavを試してみましたfindViewById(android.R.id.content)、 "Updating" + info.type、Snackbar.LENGTH_LONG); ' –

答えて

0

を見つけました。 1.1)。 Android Issue Tracker hereをチェックしてください。

UPDATE 1は:24.2.1は、今日とエラーのようにしている:Androidのサポートライブラリ(v24.2.1)

UPDATE 2の解除次のバージョンで解決することになるだろうように思えます解決されたようです - 少なくとも私は現在のバージョンでそれを再現することができました。 - PattaFeuFeu

関連する問題