我会明白这一点。
我在自己的文件DynamicMapLoader.java中有这个类:
public class DynamicMapLoader extends Activity{
public void Load(int mapInt) {
int mapArr[] = {
R.id.map1,
R.id.map2
//TODO:expand
};
int mapToLoad = mapArr[mapInt];
FrameLayout flContainer = (FrameLayout) findViewById(R.id.frameLayout3);
LinearLayout flContent = (LinearLayout) findViewById(mapToLoad);
flContainer.addView(flContent);
}
}
我有这个代码,在主要活动中调用DynamicMapLoader:
DynamicMapLoader ml = new DynamicMapLoader();
ml.Load(0);
frameLayout3位于main.xml中:
<FrameLayout
android:layout_width="wrap_content"
android:id="@+id/frameLayout3"
android:layout_below="@+id/editText1"
android:layout_alignParentLeft="true"
android:layout_height="350dp">
</FrameLayout>
和map1是其自己的.xml中的父LinearLayout:
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/map1"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<HorizontalScrollView
android:id="@+id/scrollView1"
android:layout_height="match_parent"
android:layout_width="match_parent">
<LinearLayout
android:orientation="horizontal"
android:layout_height="match_parent"
android:layout_width="match_parent">
<ImageView
android:id="@+id/imageView1"
android:src="@drawable/map_1_road"
android:layout_width="wrap_content"
android:layout_height="match_parent"
/>
<ImageView
android:id="@+id/imageView2"
android:src="@drawable/map_1_road"
android:layout_width="wrap_content"
android:layout_height="match_parent"
/>
</LinearLayout>
</HorizontalScrollView>
</LinearLayout>
当我在AVD中启动时,LogCat会在主要活动中显示FATAL EXCEPTION: main
并指向ml.Load(0);
,如下所示:
10-01 06:20:36.891: ERROR/AndroidRuntime(992): FATAL EXCEPTION: main
10-01 06:20:36.891: ERROR/AndroidRuntime(992): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.cep/com.cep.MapricotActivity}: java.lang.NullPointerException
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.os.Handler.dispatchMessage(Handler.java:99)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.os.Looper.loop(Looper.java:123)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.ActivityThread.main(ActivityThread.java:3683)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at java.lang.reflect.Method.invokeNative(Native Method)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at java.lang.reflect.Method.invoke(Method.java:507)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at dalvik.system.NativeStart.main(Native Method)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): Caused by: java.lang.NullPointerException
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.Activity.findViewById(Activity.java:1647)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at com.cep.DynamicMapLoader.Load(DynamicMapLoader.java:31)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at com.cep.MapricotActivity.onCreate(MapricotActivity.java:207)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
10-01 06:20:36.891: ERROR/AndroidRuntime(992): ... 11 more
有什么建议吗?提前谢谢。
答案 0 :(得分:1)
在致电setContentView(R.Layout. the layout file )
之前,您必须findViewByID()
或者将布局扩展到视图,然后view.findViewByID()
以获得所需的视图
答案 1 :(得分:0)
而不是
int mapArray[]...
试
Integer mapArray[]...
另外请在FATAL EXCEPTION:main下发布完整输出,这样我们就可以在更详细的级别看到出了什么问题