2015-12-01 26 views
10

sto ottenendo questo errore strano quando provo a fare funzionare la mia applicazione su una pre API 21 dispositivo:Impossibile trovare la classe 'android.widget.ThemedSpinnerAdapter' [Studio Android]

I/Choreographer: Skipped 39 frames! The application may be doing too much work on its main thread. 
12-10 07:58:44.179 4469-4472/projects.test.com.webviewtest D/dalvikvm: GC_CONCURRENT freed 156K, 4% free 4561K/4744K, paused 4ms+12ms, total 76ms 
12-10 07:58:44.409 4469-4469/projects.test.com.webviewtest I/dalvikvm: Could not find method android.widget.Spinner.getPopupContext, referenced from method android.support.v7.widget.AppCompatSpinner.getPopupContext 
12-10 07:58:44.409 4469-4469/projects.test.com.webviewtest W/dalvikvm: VFY: unable to resolve virtual method 18719: Landroid/widget/Spinner;.getPopupContext()Landroid/content/Context; 
12-10 07:58:44.409 4469-4469/projects.test.com.webviewtest D/dalvikvm: VFY: replacing opcode 0x6f at 0x000b 
12-10 07:58:44.419 4469-4469/projects.test.com.webviewtest I/dalvikvm: Could not find method android.content.Context.getDrawable, referenced from method android.support.v7.widget.AppCompatSpinner.setPopupBackgroundResource 
12-10 07:58:44.419 4469-4469/projects.test.com.webviewtest W/dalvikvm: VFY: unable to resolve virtual method 255: Landroid/content/Context;.getDrawable (I)Landroid/graphics/drawable/Drawable; 
12-10 07:58:44.419 4469-4469/projects.test.com.webviewtest D/dalvikvm: VFY: replacing opcode 0x6e at 0x0004 
12-10 07:58:44.429 4469-4469/projects.test.com.webviewtest I/dalvikvm: Could not find method android.widget.PopupWindow.showAsDropDown, referenced from method android.support.v7.widget.AppCompatPopupWindow.showAsDropDown 
12-10 07:58:44.429 4469-4469/projects.test.com.webviewtest W/dalvikvm: VFY: unable to resolve virtual method 18641: Landroid/widget/PopupWindow;.showAsDropDown (Landroid/view/View;III)V 
12-10 07:58:44.429 4469-4469/projects.test.com.webviewtest D/dalvikvm: VFY: replacing opcode 0x6f at 0x000d 
12-10 07:58:44.459 4469-4469/projects.test.com.webviewtest I/dalvikvm: Could not find method android.widget.CompoundButton.drawableHotspotChanged, referenced from method android.support.v7.widget.SwitchCompat.drawableHotspotChanged 
12-10 07:58:44.459 4469-4469/projects.test.com.webviewtest W/dalvikvm: VFY: unable to resolve virtual method 18333: Landroid/widget/CompoundButton;.drawableHotspotChanged (FF)V 
12-10 07:58:44.459 4469-4469/projects.test.com.webviewtest D/dalvikvm: VFY: replacing opcode 0x6f at 0x0006 
12-10 07:58:44.559 4469-4469/projects.test.com.webviewtest E/dalvikvm: Could not find class 'android.widget.ThemedSpinnerAdapter', referenced from method android.support.v7.widget.AppCompatSpinner$DropDownAdapter.<init> 
12-10 07:58:44.569 4469-4469/projects.test.com.webviewtest W/dalvikvm: VFY: unable to resolve instanceof 2184 (Landroid/widget/ThemedSpinnerAdapter;) in Landroid/support/v7/widget/AppCompatSpinner$DropDownAdapter; 
12-10 07:58:44.569 4469-4469/projects.test.com.webviewtest D/dalvikvm: VFY: replacing opcode 0x20 at 0x0016 

In realtà non ottiene Don un ANR o Sfortunatamente la tua app ha smesso di funzionare, l'app esce silenziosamente dall'attività principale.

Non utilizzo immagini pesanti nella mia applicazione, solo una pagina con quattro filatori.

In particolare, questa linea è evidenziata in rosso:

E/dalvikvm: Could not find class 'android.widget.ThemedSpinnerAdapter', referenced from method android.support.v7.widget.AppCompatSpinner$DropDownAdapter.<init> 

Tuttavia come io non sto usando Eclipse, io sono sicuro di avere le importazioni corrette utilizzando Gradle:

apply plugin: 'com.android.application' 

android { 
    compileSdkVersion 23 
    buildToolsVersion "23.0.1" 

    defaultConfig { 
     applicationId "projects.test.com.webviewtest" 
     minSdkVersion 14 
     targetSdkVersion 23 
     versionCode 1 
     versionName "1.0" 
    } 
    buildTypes { 
     release { 
      minifyEnabled false 
      proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 
     } 
    } 
} 

dependencies { 
    compile fileTree(dir: 'libs', include: ['*.jar']) 
    testCompile 'junit:junit:4.12' 
    compile 'com.android.support:appcompat-v7:23.1.1' 
    compile 'com.android.support:design:23.1.1' 
    compile 'com.android.support:recyclerview-v7:23.1.1' 
} 
+0

controllare se la visualizzazione del filatore nel layout con la vista recuperata con findViewById, voglio dire controllare il cast, quindi se hai AppCompatSpinner o la tua classe personalizzata assicurati di lanciare findViewById con la stessa classe – Mouloud

+0

Se stai ricevendo questo errore messaggio mentre usi Parse, guarda questa domanda: 'http: // stackoverflow.com/questions/33416691/could-not-find-class-android-widget-themedspinneradapter/34968810 # 34968810' –

risposta

4

Nella mia situazione presente è stato risolto rimuovendo l'uso di android:tint="?attr/colorControlNormal" all'interno del file XML di layout ... Forse questo aiuta gli altri.

1

Ho risolto il problema guardando a compileSdkVersion nel mio progetto. Avevo 4 moduli, 3 di loro stavano compilando con lo sdk 22, uno stava compilando con il sdk 23.

Dopo averli modificati tutti nello sdk 22, il problema era risolto. Quindi il mio consiglio è di controllare la versione dell'SDK e selezionare tutti i moduli del progetto con lo stesso numero.

Acclamazioni

+0

in qualche modo penso che il problema sia SDK versione 23 – BlackPearl

1

Ho anche avuto lo stesso problema con il filatore, è in esecuzione in alcuni dispositivi e non è in esecuzione in alcuni dispositivi. Perché ho messo setAdapter(null). Per questo si comporta in questo modo. Invece di quello messo ArrayList arrayList = new ArrayList(); spinner.setAdapter(new ArrayAdapter<String>(activity.this, android.R.layout.simple_dropdown_item_1line, arrayList)); allora funzionerà su tutti i dispositivi.

Problemi correlati