2013-03-25 2 views
1

환경 설정 활동으로 전환 할 때마다 실행 시간 오류가 발생합니다. 나는 안드로이드 프로그래밍을 배우려고 노력 중이며, 내가 가진 문제를 해결할 수 있었지만, 도움을 찾고있는 시간이 길어서 내가 뭘 잘못하고 있는지 이해할 수 없었다.addPrefencesFromResource 원인 FC : Error inflating class CheckboxPreference

package com.wisp.sudokuapp; 

import android.os.Bundle; 
import android.preference.PreferenceActivity; 

public class Settings extends PreferenceActivity { 
    @SuppressWarnings("deprecation") 
    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     addPreferencesFromResource(R.xml.settings); 
    } 

} 

내 Settings.XML의 :

<?xml version="1.0" encoding="utf-8"?> 
<PreferenceScreen 
    xmlns:android="http://schemas.android.com/apk/res/android" > 

    <CheckboxPreference 
     android:key="hints" 
     android:title="@string/settings_hints_title" 
     android:summary="@string/settings_hints_summary" 
     android:defaultValue="true" /> 

    <CheckboxPreference 
     android:key="music" 
     android:title="@string/settings_music_title" 
     android:summary="@string/settings_music_summary" 
     android:defaultValue="true" /> 

</PreferenceScreen> 

내 매니페스트 :

(...) 
     <activity android:name="com.wisp.sudokuapp.Settings" 
      android:label="@string/settings_title"> 
     </activity> 
(...) 

그리고 로그 캣 :

03-25 17:22:22.637: W/dalvikvm(440): threadid=1: thread exiting with uncaught exception (group=0x40015560) 
03-25 17:22:22.687: E/AndroidRuntime(440): FATAL EXCEPTION: main 
03-25 17:22:22.687: E/AndroidRuntime(440): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.wisp.sudokuapp/com.wisp.sudokuapp.Settings}: android.view.InflateException: Binary XML file line #5: Error inflating class CheckboxPreference 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.os.Handler.dispatchMessage(Handler.java:99) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.os.Looper.loop(Looper.java:123) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.ActivityThread.main(ActivityThread.java:3683) 
03-25 17:22:22.687: E/AndroidRuntime(440): at java.lang.reflect.Method.invokeNative(Native Method) 
03-25 17:22:22.687: E/AndroidRuntime(440): at java.lang.reflect.Method.invoke(Method.java:507) 
03-25 17:22:22.687: E/AndroidRuntime(440): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 
03-25 17:22:22.687: E/AndroidRuntime(440): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 
03-25 17:22:22.687: E/AndroidRuntime(440): at dalvik.system.NativeStart.main(Native Method) 
03-25 17:22:22.687: E/AndroidRuntime(440): Caused by: android.view.InflateException: Binary XML file line #5: Error inflating class CheckboxPreference 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.createItemFromTag(GenericInflater.java:441) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.rInflate(GenericInflater.java:481) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.inflate(GenericInflater.java:326) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.inflate(GenericInflater.java:263) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.PreferenceManager.inflateFromResource(PreferenceManager.java:251) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.PreferenceActivity.addPreferencesFromResource(PreferenceActivity.java:262) 
03-25 17:22:22.687: E/AndroidRuntime(440): at com.wisp.sudokuapp.Settings.onCreate(Settings.java:11) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 
03-25 17:22:22.687: E/AndroidRuntime(440): ... 11 more 
03-25 17:22:22.687: E/AndroidRuntime(440): Caused by: java.lang.ClassNotFoundException: android.preference.CheckboxPreference in loader dalvik.system.PathClassLoader[/data/app/com.wisp.sudokuapp-1.apk] 
03-25 17:22:22.687: E/AndroidRuntime(440): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:240) 
03-25 17:22:22.687: E/AndroidRuntime(440): at java.lang.ClassLoader.loadClass(ClassLoader.java:551) 
03-25 17:22:22.687: E/AndroidRuntime(440): at java.lang.ClassLoader.loadClass(ClassLoader.java:511) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.createItem(GenericInflater.java:375) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.onCreateItem(GenericInflater.java:417) 
03-25 17:22:22.687: E/AndroidRuntime(440): at android.preference.GenericInflater.createItemFromTag(GenericInflater.java:428) 
03-25 17:22:22.687: E/AndroidRuntime(440): ... 19 more 

는 Settings.java의 코드

이 방법은 쓸모가 없다는 것을 알고 있지만, 2.3.x에서 사용하고 싶습니다. 안드로이드 개발을 배우기 위해 나는 책을 읽고 책을 읽는다고 생각합니다. addPreferencesFromResource라는 줄을 주석 처리하면 앱이 손상되는 것을 방지 할 수 있지만 UI가로드되지 않습니다.

정말 감사드립니다.

영어로 죄송합니다.

답변

5

문제는 xml 파일의 오타가있는 것입니다. CheckboxPreference를 CheckBoxPreference로 변경하십시오.

+0

오, 나는 어리 석다. 특히 몇 시간이 지난 후에 문제를 찾으려고 길을 잃었습니다. 고맙습니다. – Adelaiglesia

0

맞춤법 오류가 있습니다. 사실, 둘. 시도 :

<?xml version="1.0" encoding="utf-8"?> 
<PreferenceScreen 
    xmlns:android="http://schemas.android.com/apk/res/android" > 

    <CheckBoxPreference 
     android:key="hints" 
     android:title="@string/settings_hints_title" 
     android:summary="@string/settings_hints_summary" 
     android:defaultValue="true" /> 

    <CheckBoxPreference 
     android:key="music" 
     android:title="@string/settings_music_title" 
     android:summary="@string/settings_music_summary" 
     android:defaultValue="true" /> 

</PreferenceScreen> 

안드로이드 XML은 대소 문자를 구분하므로 CheckboxPreferenceCheckBoxPreference과는 다른, 존재하지 않는 것입니다.