0

我有一些问题。当我更改任何 xml 文件时,我在主布局初始化时遇到错误(我确定只有小布局)。例如,如果我在 setup-wizard 片段上再添加一个字段,则会收到以下错误:

09-15 20:33:49.697: E/AndroidRuntime(3529): FATAL EXCEPTION: main
09-15 20:33:49.697: E/AndroidRuntime(3529): java.lang.RuntimeException: Unable to start activity ComponentInfo{org.linphone/org.linphone.LinphoneActivity}: android.view.InflateException: Binary XML file line #81: Error inflating class fragment
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1651)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.os.Handler.dispatchMessage(Handler.java:99)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.os.Looper.loop(Looper.java:130)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.ActivityThread.main(ActivityThread.java:3687)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at java.lang.reflect.Method.invokeNative(Native Method)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at java.lang.reflect.Method.invoke(Method.java:507)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at dalvik.system.NativeStart.main(Native Method)
09-15 20:33:49.697: E/AndroidRuntime(3529): Caused by: android.view.InflateException: Binary XML file line #81: Error inflating class fragment
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:587)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:623)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.rInflate(LayoutInflater.java:626)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.inflate(LayoutInflater.java:408)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.inflate(LayoutInflater.java:320)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.inflate(LayoutInflater.java:276)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:209)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.Activity.setContentView(Activity.java:1657)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at org.linphone.LinphoneActivity.onCreate(LinphoneActivity.java:151)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1615)
09-15 20:33:49.697: E/AndroidRuntime(3529):     ... 11 more
09-15 20:33:49.697: E/AndroidRuntime(3529): Caused by: java.lang.ClassCastException: android.widget.ImageView
09-15 20:33:49.697: E/AndroidRuntime(3529):     at org.linphone.StatusFragment.onCreateView(StatusFragment.java:80)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:846)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1061)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.support.v4.app.FragmentManagerImpl.addFragment(FragmentManager.java:1160)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.support.v4.app.FragmentActivity.onCreateView(FragmentActivity.java:272)
09-15 20:33:49.697: E/AndroidRuntime(3529):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:563)
09-15 20:33:49.697: E/AndroidRuntime(3529):     ... 21 more

我可以在哪里获取一些关于我做错了什么的信息?

更新 1

StatusFragment.java 中的第 80 行

statusText = (TextView) view.findViewById(R.id.statusText);

它真的是TextView。此外,我什至不碰那些文件。

初学者:_

您可以从 git 获取代码:

git clone git://git.linphone.org/linphone-android.git

如果您想要整个项目,准备好构建,请使用--recursive标签。

4

1 回答 1

0

在 Eclipse 中转到 Project->Clean,让它完成然后再次运行您的应用程序,一切都会正常工作。

Eclipse 根据视图在布局中的顺序缓存资源 ID。如果你改变它,就有可能得到一个classcastexception。清理您的项目会强制 Eclipse 正确地重新缓存您的所有 ID。

于 2013-09-16T11:27:21.723 回答