2

我一直在努力让ListPreference与HoloEverywhere合作。 我在XML文件中定义了我的设置。我使用holo命名空间作为属性。与首选项相关的所有内容都使用org.holoeverywhere包中的类,所以问题在于别的地方。HoloEverywhere + ListPreference =崩溃

当我在我的应用程序中单击ListPreference时,会出现该问题。首选项应打开一个对话框,其中包含可供选择的选项。相反,它崩溃,给我下面的堆栈跟踪:

12-20 09:42:59.363: E/AndroidRuntime(3005): FATAL EXCEPTION: main 
12-20 09:42:59.363: E/AndroidRuntime(3005): java.lang.NullPointerException 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at org.holoeverywhere.ArrayAdapter.createViewFromResource(ArrayAdapter.java:204) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at org.holoeverywhere.ArrayAdapter.getView(ArrayAdapter.java:250) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.AbsListView.obtainView(AbsListView.java:2267) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.ListView.measureHeightOfChildren(ListView.java:1244) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.ListView.onMeasure(ListView.java:1156) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at org.holoeverywhere.widget.LinearLayout.measureChildWithMargins(LinearLayout.java:233) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1390) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.LinearLayout.measureVertical(LinearLayout.java:681) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.LinearLayout.onMeasure(LinearLayout.java:574) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at org.holoeverywhere.widget.LinearLayout.measureChildWithMargins(LinearLayout.java:233) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1390) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.LinearLayout.measureVertical(LinearLayout.java:681) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.LinearLayout.onMeasure(LinearLayout.java:574) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:4814) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2148) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.View.measure(View.java:15172) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:1848) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1075) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1273) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:998) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4212) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.Choreographer$CallbackRecord.run(Choreographer.java:725) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.Choreographer.doCallbacks(Choreographer.java:555) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.Choreographer.doFrame(Choreographer.java:525) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:711) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.os.Handler.handleCallback(Handler.java:615) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.os.Handler.dispatchMessage(Handler.java:92) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.os.Looper.loop(Looper.java:137) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at android.app.ActivityThread.main(ActivityThread.java:4745) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at java.lang.reflect.Method.invokeNative(Native Method) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at java.lang.reflect.Method.invoke(Method.java:511) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553) 
12-20 09:42:59.363: E/AndroidRuntime(3005):  at dalvik.system.NativeStart.main(Native Method) 

我目前使用PreferenceFragment,但同样的事情发生在我试图直接使用addPreferencesFromResource(int)PreferenceActivity添加偏好。

名单偏好(XML)本身:

<ListPreference 
     holo:defaultValue="false" 
     holo:dialogTitle="@string/sett_inet_access_dial" 
     holo:entries="@array/sett_inet_access_names" 
     holo:entryValues="@array/sett_inet_access_values" 
     holo:key="@string/keysett_inet_access" 
     holo:summary="@string/sett_inet_access_summ" 
     holo:title="@string/sett_inet_access_name" /> 

我还想补充一点,这种情况我所有ListPreference项目(我有多个)。

+0

好的。我发现了一些有趣的东西。这似乎只发生在我的模拟器(在我的情况下,豆类罐)。我已经在两个物理设备(4.2和4.1)上测试过了,它在那里工作......怪异的......只有在物理设备上出现错误的是,首选项的对话框完全忽略了我的应用程序的主题并恢复为库存完整的外观。 – Paul

+0

不幸的是,它不仅仅是一个模拟器问题。我刚刚在运行4.0.4的SGSIII上尝试过,发生同样的问题... – Paul

+0

现在我唯一想到的解决方案是实现我自己的'ListPreference',我想避免这样做。 .. – Paul

回答

2

OK解决。我已经知道了。

事实证明。 HoloEverywhere 1.4.0中存在一个错误。 该问题已经被报告和修复: https://github.com/ChristopheVersieux/HoloEverywhere/issues/203

不幸的是,修复尚未合并到HE GitHub项目的主分支。它正在冷静地坐在dev分支上,最有可能等待下一个版本...

所以,如果你有和我一样的问题,那么你应该使用开发分支,或叉存储库和cherry-pick THIS承诺给你主分支。

样式未正确应用于对话框的问题仍然存在。

0

查找到source code

private View createViewFromResource(int position, View convertView, 
     ViewGroup parent, int resource) { 
    View view; 
    TextView text; 
    if (convertView == null) { 
     view = FontLoader.apply(mInflater.inflate(resource, parent, false)); 
    } else { 
     view = convertView; 
    } 
    try { 
     if (mFieldId == 0) { 
      text = (TextView) view; 
     } else { 
      text = (TextView) view.findViewById(mFieldId); 
     } 
    } catch (ClassCastException e) { 
     Log.e("ArrayAdapter", 
       "You must supply a resource ID for a TextView"); 
     throw new IllegalStateException(
       "ArrayAdapter requires the resource ID to be a TextView", e); 
    } 

    T item = getItem(position); 
    if (item instanceof CharSequence) { 
     text.setText((CharSequence) item); 
    } else { 
     text.setText(item.toString()); 
    } 
    return view; 
} 

似乎TextView的是空的,它不是从布局

+0

我做到了。事实上TextView在这一行中被正确地实例化了:view = FontLoader.apply(mInflater.inflate(resource,parent,false));'但是比较后面'if(mFieldId == 0)'失败,因此'text = (TextView)view.findViewById(mFieldId);'是运行,使文本'空'... – Paul

+0

但是,就我所知...我无法弄清楚为什么发生了......我'我重建了所有的项目,清理了它们等等,以确保'R'文件是新鲜的,但是没有帮助。 – Paul

+0

您的列表条目布局在哪里? –