ボタンリスナーを別のクラスに実装する際に問題があります。コード:
<Button
android:id ="@+button/bottone"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text = "Button"
/>
メインクラス:
public class MainActivity extends Activity {
private final Context main_context = this.getApplicationContext();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
Button b = (Button)findViewById(R.button.bottone);
Log.i("AAAAAAAAAAAA", "1");
OnClickListener l = new MyClickListener(this);
b.setOnClickListener(l);
Log.i("AAAAAAAAAAAA", "2");
setContentView(R.layout.activity_main);
}
public Context getContext() {
return main_context;
}
およびリスナーの実装
public class MyClickListener implements OnClickListener {
private final Context cntx;
public MyClickListener(Context c) {
cntx = c;
}
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
Log.i("ONCLICK", "bottone cliccato");
Toast t = Toast.makeText(cntx, "OK", Toast.LENGTH_LONG);
t.show();
}
実行しようとすると、電話でアプリケーションがクラッシュし、logcat が通知します
mainactivity でアクティビティ componentinfo をインスタンス化できません。
どうしたの?
logcat 情報のログ
02-07 11:43:54.887: E/AndroidRuntime(9048): 致命的な例外: メイン 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.RuntimeException: アクティビティ ComponentInfo{com をインスタンス化できません。 example.buttoneventlistener/com.example.buttoneventlistener.MainActivity}: java.lang.NullPointerException 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106) で 02 -07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app で.ActivityThread.access$600(ActivityThread.java:141) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 02-07 11: 43:54.887: E/AndroidRuntime(9048): android.os.Handler で。dispatchMessage(Handler.java:99) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.os.Looper.loop(Looper.java:137) 02-07 11:43:54.887: E/ AndroidRuntime(9048): android.app.ActivityThread.main(ActivityThread.java:5039) 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.reflect.Method.invokeNative(ネイティブ メソッド) で02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.reflect.Method.invoke(Method.java:511) 02-07 11:43:54.887: E/AndroidRuntime(9048): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 02-07 11:43:54.887: E/AndroidRuntime(9048): com.android.internal.os.ZygoteInit.main(ZygoteInit) で.java:560) 02-07 11:43:54.887: E/AndroidRuntime(9048): dalvik.system.NativeStart.main(ネイティブ メソッド) 02-07 11:43:54.887: E/AndroidRuntime(9048): 原因by: java.lang.NullPointerException 02-07 11:43:54.887: E/AndroidRuntime(9048): android.content.ContextWrapper.getApplicationContext(ContextWrapper.java:109) 02-07 11:43:54.887: E/AndroidRuntime(9048): com .example.buttoneventlistener.MainActivity.(MainActivity.java:13) 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.Class.newInstanceImpl(ネイティブ メソッド) 02-07 11:43:54.887 で: E/AndroidRuntime(9048): java.lang.Class.newInstance(Class.java:1319) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.Instrumentation.newActivity(Instrumentation. java:1054) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/AndroidRuntime(9048) : ... 11件以上content.ContextWrapper.getApplicationContext(ContextWrapper.java:109) 02-07 11:43:54.887: E/AndroidRuntime(9048): com.example.buttoneventlistener.MainActivity.(MainActivity.java:13) 02-07 11:43 :54.887: E/AndroidRuntime(9048): at java.lang.Class.newInstanceImpl(Native Method) 02-07 11:43:54.887: E/AndroidRuntime(9048): at java.lang.Class.newInstance(Class.java :1319) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.Instrumentation.newActivity(Instrumentation.java:1054) 02-07 11:43:54.887: E/AndroidRuntime(9048): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/AndroidRuntime(9048): ... 11 もっと見るcontent.ContextWrapper.getApplicationContext(ContextWrapper.java:109) 02-07 11:43:54.887: E/AndroidRuntime(9048): com.example.buttoneventlistener.MainActivity.(MainActivity.java:13) 02-07 11:43 :54.887: E/AndroidRuntime(9048): at java.lang.Class.newInstanceImpl(Native Method) 02-07 11:43:54.887: E/AndroidRuntime(9048): at java.lang.Class.newInstance(Class.java :1319) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.Instrumentation.newActivity(Instrumentation.java:1054) 02-07 11:43:54.887: E/AndroidRuntime(9048): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/AndroidRuntime(9048): ... 11 もっと見るMainActivity.(MainActivity.java:13) 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.Class.newInstanceImpl(ネイティブ メソッド) 02-07 11:43:54.887: E/AndroidRuntime( 9048): java.lang.Class.newInstance(Class.java:1319) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.Instrumentation.newActivity(Instrumentation.java:1054) 02 -07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/AndroidRuntime(9048): ... 11もっとMainActivity.(MainActivity.java:13) 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.Class.newInstanceImpl(ネイティブ メソッド) 02-07 11:43:54.887: E/AndroidRuntime( 9048): java.lang.Class.newInstance(Class.java:1319) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.Instrumentation.newActivity(Instrumentation.java:1054) 02 -07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/AndroidRuntime(9048): ... 11もっとnewActivity(Instrumentation.java:1054) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/ AndroidRuntime(9048): ... 11 続きnewActivity(Instrumentation.java:1054) 02-07 11:43:54.887: E/AndroidRuntime(9048): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097) 02-07 11:43:54.887: E/ AndroidRuntime(9048): ... 11 続き