У меня проблема с реализацией прослушивателя кнопок в отдельном классе. Код:
<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.
что случилось?
журнал информации logcat
02-07 11:43:54.887: E/AndroidRuntime(9048): НЕИСПРАВНОЕ ИСКЛЮЧЕНИЕ: main 02-07 11:43:54.887: E/AndroidRuntime(9048): java.lang.RuntimeException: невозможно создать экземпляр активности ComponentInfo{com. Например. -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): в 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): at dalvik.system.NativeStart.main(собственный метод) 02-07 11:43:54.887: E/AndroidRuntime( 9048): Вызвано: java.lang.NullPointerException 02-07 11:43:54.887: E/AndroidRuntime(9048): at android.content.ContextWrapper.getApplicationContext(ContextWrapper.java:109) 02-07 11:43:54.887 : E/AndroidRuntime(9048): at com.example.buttoneventlistener.MainActivity.(MainActivity.java:13) 02-07 1 1: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