2013-04-20 5 views
0

Я пытаюсь получить класс HoloEverywhere AutoCompleteTextView для работы с моим приложением. Основной причиной этого является то, я хочу, чтобы тема Холо работать на предварительно 3,0 устройств (в частности уровни 8-10 API) Вот мой основной код деятельности:HoloEverywhere AutoCompleteTextView java.lang.ClassCastException

package com.example.testautocomp; 

import org.holoeverywhere.widget.AutoCompleteTextView; 

import android.app.Activity; 
import android.os.Bundle; 
import android.widget.ArrayAdapter; 

public class MainActivity extends Activity { 

    private AutoCompleteTextView m_edit; 

    private static final String[] items = { "lorem", "ipsum", "dolor", "sit", 
     "amet", "consectetuer", "adipiscing", "elit", "morbi", "vel", 
     "augue", "purus", "sitter", "sitting", "sither", "sithar" }; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    m_edit = (AutoCompleteTextView)findViewById(R.id.edit2); 

    m_edit.setAdapter(new ArrayAdapter<String>(this, 
      android.R.layout.simple_dropdown_item_1line, items)); 
    } 
} 

также мой activity_main.xml код:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:orientation="vertical" > 

<AutoCompleteTextView 
    android:id="@+id/edit2" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:completionThreshold="1" 
    android:hint="Testing" /> 
</LinearLayout> 

Когда я запускаю мое приложение, он переходит в режим отладки для затмения и после нажатия кнопки резюме (или F8), чтобы продолжить нить, мое приложение аварий/силы закрывает и я получаю следующее сообщение об ошибке в моем LogCat:

04-19 17:52:56.342: W/dalvikvm(675): threadid=1: thread exiting with uncaught exception (group=0x409c01f8) 
04-19 17:52:56.422: E/AndroidRuntime(675): FATAL EXCEPTION: main 
04-19 17:52:56.422: E/AndroidRuntime(675): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.testautocomp/com.example.testautocomp.MainActivity}: java.lang.ClassCastException: android.widget.AutoCompleteTextView cannot be cast to org.holoeverywhere.widget.AutoCompleteTextView 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1956) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.ActivityThread.access$600(ActivityThread.java:123) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.os.Handler.dispatchMessage(Handler.java:99) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.os.Looper.loop(Looper.java:137) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.ActivityThread.main(ActivityThread.java:4424) 
04-19 17:52:56.422: E/AndroidRuntime(675): at java.lang.reflect.Method.invokeNative(Native Method) 
04-19 17:52:56.422: E/AndroidRuntime(675): at java.lang.reflect.Method.invoke(Method.java:511) 
04-19 17:52:56.422: E/AndroidRuntime(675): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
04-19 17:52:56.422: E/AndroidRuntime(675): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
04-19 17:52:56.422: E/AndroidRuntime(675): at dalvik.system.NativeStart.main(Native Method) 
04-19 17:52:56.422: E/AndroidRuntime(675): Caused by: java.lang.ClassCastException: android.widget.AutoCompleteTextView cannot be cast to org.holoeverywhere.widget.AutoCompleteTextView 
04-19 17:52:56.422: E/AndroidRuntime(675): at com.example.testautocomp.MainActivity.onCreate(MainActivity.java:22) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.Activity.performCreate(Activity.java:4465) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049) 
04-19 17:52:56.422: E/AndroidRuntime(675): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920) 
04-19 17:52:56.422: E/AndroidRuntime(675): ... 11 more 

Как исправить это исключение CastClassException?

ответ

-1

Очень похож на этот question

Fixed, изменив свою main_activity.xml на:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:orientation="vertical" > 

<org.holoeverywhere.widget.AutoCompleteTextView 
    android:id="@+id/edit2" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:completionThreshold="1" 
    android:hint="Testing" /> 
</LinearLayout> 

основная часть является org.holoeverywhere.widget.AutoCompleteTextView

0

Нет, ваш действие выше неверно. Вы должны изменить базовый класс активности на org.holoeverywhere.app.Activity.

+0

это может быть для другого вопроса, теперь я пытаюсь использовать org.holoeverywhere.widget.AutoCompleteTextView, используя com.actionbarsherlock.app.SherlockActivity. Как мне заставить этих двух работать вместе, не меняя свой main_activity.xml, как в моем ответе? – nommer