Android 2.3.3 Eclipse Version: 3.7.0 LogCat
LogCat 报错信息:
03-06 16:20:10.788: ERROR/AndroidRuntime(163): Caused by: java.lang.IllegalStateException: ScrollView can host only one direct child 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.widget.ScrollView.addView(ScrollView.java:229) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.view.LayoutInflater.rInflate(LayoutInflater.java:627) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.view.LayoutInflater.rInflate(LayoutInflater.java:626) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.view.LayoutInflater.inflate(LayoutInflater.java:408) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.view.LayoutInflater.inflate(LayoutInflater.java:320) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.view.LayoutInflater.inflate(LayoutInflater.java:276) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:207) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.app.Activity.setContentView(Activity.java:1657) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at com.taobao.htc.manage.CopyRight.onResume(CopyRight.java:50) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1150) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.app.Activity.performResume(Activity.java:3832) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): at android.app.ActivityThread.performResumeActivity(ActivityThread.java:2110) 03-06 16:20:10.788: ERROR/AndroidRuntime(163): ... 12 more
发生错误原因分析:
ScrollView仅支持一个子项。
查看对应的layout xml,发现ScrollView中有两个子项。
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:scrollbars="vertical"> <TextView android:id="@+id/textView2" android:layout_gravity="center" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/text_CRdesc_title"></TextView> <TextView android:id="@+id/textView2" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/text_CRdesc"></TextView> </ScrollView>
解决办法:
在ScrollView 中设LinearLayout为子项 ,将其它View放入LinearLayout。
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:scrollbars="vertical"> <LinearLayout android:id="@+id/linearLayout1" android:layout_width="fill_parent" android:layout_height="wrap_content" android:orientation="vertical"> <TextView android:id="@+id/textView2" android:layout_gravity="center" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="@string/text_CRdesc_title"></TextView> <TextView android:id="@+id/textView2" android:layout_gravity="center" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/text_CRdesc"></TextView> </LinearLayout> </ScrollView>
PS. 在Error Log中有错误提示。但在编辑layout xml 时未开启“Error Log”窗口,未发现报错。
其实“Graphical Layout” 中也会有报错提示
ScrollView can host only one direct child Exception details are logged in Window > Show View > Error Log