这是 activity_main.xml 文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/layoutRoot"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<LinearLayout
android:id="@+id/L1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical" >
<Button
android:id="@+id/addButton"
android:layout_width="74dp"
android:layout_height="wrap_content"
android:text="Add" />
<EditText
android:id="@+id/newEditText"
android:layout_width="174dp"
android:layout_height="wrap_content"
android:layout_weight="3.24"
android:ems="10"
android:inputType="text" />
</LinearLayout>
<ListView
android:id="@+id/List"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
</ListView>
</LinearLayout>
这是名为 second.xml 的自定义复合控件的 xml 文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/jokeView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<Button
android:id="@+id/expandButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.44"
android:text = "One Click"/>
<TextView
android:id="@+id/txtView"
android:layout_width="253dp"
android:layout_height="wrap_content"
android:layout_weight="0.56"
android:ems="10"
android:text = "LOL This is a sample code"/>
</LinearLayout>
<RadioGroup
android:id="@+id/ratingRadioGroup"
android:layout_width="321dp"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<RadioButton
android:id="@+id/likeButton"
android:layout_width="145dp"
android:layout_height="wrap_content"
android:checked="true"
android:text="Like" />
<RadioButton
android:id="@+id/dislikeButton"
android:layout_width="147dp"
android:layout_height="wrap_content"
android:text="Dislike" />
</RadioGroup>
</LinearLayout>
这是扩展 second.xml 的 java 文件:
public class Second extends View
{
private Button mExpandButton;
private RadioButton mLikeButton;
private RadioButton mDislikeButton;
private TextView mText;
private RadioGroup mLikeGroup;
private ViewGroup vGroup;
OnClickListener myClickListener = new OnClickListener()
{
@Override
public void onClick(View v)
{
String s= mExpandButton.getText().toString();
if (s.equals("One Click"))
mExpandButton.setText("Other Click");
else
mExpandButton.setText("One Click");
}
};
OnCheckedChangeListener myCkeckListener = new OnCheckedChangeListener()
{
@Override
public void onCheckedChanged(RadioGroup group, int checkedId)
{
if (mLikeButton.isChecked())
mText.setText("I Like it");
if (mDislikeButton.isChecked())
mText.setText("I Don't Like it");
}
};
public Second(Context context)
{
super(context);
mExpandButton = (Button) this.findViewById(R.id.expandButton);
mText = (TextView)this.findViewById(R.id.txtView);
mLikeGroup = (RadioGroup)this.findViewById(R.id.ratingRadioGroup);
mExpandButton.setOnClickListener(myClickListener);
mLikeGroup.setOnCheckedChangeListener(myCkeckListener);
LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
inflater.inflate(R.layout.second, null);
}
}
最后,这是 activity_main.xml 的 java 代码:
public class MainActivity extends Activity
{
protected ListView mLayout;
protected EditText mEditText;
protected Button mButton;
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mLayout = (ListView)findViewById(R.id.List);
mEditText = (EditText)findViewById(R.id.newEditText);
mButton = (Button)findViewById(R.id.addButton);
for (int i =0; i< 4; i++)
{
Second sec = new Second(this);
mLayout.addView(sec);
setContentView(sec);
}
}
@Override
public boolean onCreateOptionsMenu(Menu menu)
{
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
}
这是生成的 logcat(更新。我的包的名称是 nullextry):
04-24 16:33:30.072: E/AndroidRuntime(1759): FATAL EXCEPTION: main
04-24 16:33:30.072: E/AndroidRuntime(1759): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.nullextry/com.example.nullextry.MainActivity}: java.lang.NullPointerException
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.ActivityThread.access$600(ActivityThread.java:141)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.os.Handler.dispatchMessage(Handler.java:99)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.os.Looper.loop(Looper.java:137)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.ActivityThread.main(ActivityThread.java:5041)
04-24 16:33:30.072: E/AndroidRuntime(1759): at java.lang.reflect.Method.invokeNative(Native Method)
04-24 16:33:30.072: E/AndroidRuntime(1759): at java.lang.reflect.Method.invoke(Method.java:511)
04-24 16:33:30.072: E/AndroidRuntime(1759): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
04-24 16:33:30.072: E/AndroidRuntime(1759): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
04-24 16:33:30.072: E/AndroidRuntime(1759): at dalvik.system.NativeStart.main(Native Method)
04-24 16:33:30.072: E/AndroidRuntime(1759): Caused by: java.lang.NullPointerException
04-24 16:33:30.072: E/AndroidRuntime(1759): at com.example.nullextry.Second.<init>(Second.java:58)
04-24 16:33:30.072: E/AndroidRuntime(1759): at com.example.nullextry.MainActivity.onCreate(MainActivity.java:31)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.Activity.performCreate(Activity.java:5104)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080)
04-24 16:33:30.072: E/AndroidRuntime(1759): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144)
04-24 16:33:30.072: E/AndroidRuntime(1759): ... 11 more
04-24 16:33:30.192: D/dalvikvm(1759): GC_CONCURRENT freed 110K, 9% free 2858K/3112K, paused 79ms+5ms, total 232ms
04-24 16:33:32.793: I/Process(1759): Sending signal. PID: 1759 SIG: 9
在调试的时候,我发现在 second.java 构造函数中对 second.xml 进行了膨胀之后抛出了这个异常,这里的监听器被分配给了各自的控件。我错过了什么吗?我不是宣布了什么吗?
愚蠢的错误:我没有声明 mExpandButton 和 mLikeGroup。我修复了 second.java 代码,(感谢 ZouZou!)。但是我遇到了同样的异常(logcat 已经更新)。