setOnClickListener 崩溃

Posted

技术标签:

【中文标题】setOnClickListener 崩溃【英文标题】:setOnClickListener crash 【发布时间】:2014-04-26 10:10:37 【问题描述】:

我在 *** 上阅读了一些关于此的问题,但它并没有解决我的问题。

我正在关注关于在点击命令上烘烤消息的指南.. 但它崩溃了(我想知道如果我只是复制指南会怎样)

代码是:

  @Override
    protected void onCreate(Bundle savedInstanceState) 
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    ImageView red_view=(ImageView)findViewById(R.id.imageView3);

    red_view.setOnClickListener(new View.OnClickListener() 
        @Override
         public void onClick(View v) 
             Toast t=Toast.makeText(MainActivity.this,"ROSSO",Toast.LENGTH_SHORT);
                        t.show();
         

         );

我错过了什么? :/

Logcat 这是 logcat(我不知道如何引用它:/)

04-26 12:50:36.360: E/androidRuntime(928): 致命异常: main 04-26 12:50:36.360: E/AndroidRuntime(928): Process: com.example.firstapp, PID: 928 04-26 12:50:36.360: E/AndroidRuntime(928): java.lang.RuntimeException: 无法启动活动 ComponentInfocom.example.firstapp/com.example.firstapp.MainActivity: java.lang.NullPointerException 04- 26 12:50:36.360: E/AndroidRuntime(928): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android.app。 ActivityThread.handleLaunchActivity(ActivityThread.java:2245) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android.app.ActivityThread.access$800(ActivityThread.java:135) 04-26 12:50:36.360 : E/AndroidRuntime(928): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android.os.Handler.dispatchMessage( Handler.java:102) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android.os.Looper.loop(Looper.java:136) 0 4-26 12:50:36.360: E/AndroidRuntime(928): at android.app.ActivityThread.main(ActivityThread.java:5017) 04-26 12:50:36.360: E/AndroidRuntime(928): at java. lang.reflect.Method.invokeNative(Native Method) 04-26 12:50:36.360: E/AndroidRuntime(928): at java.lang.reflect.Method.invoke(Method.java:515) 04-26 12:50 :36.360: E/AndroidRuntime(928): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 04-26 12:50:36.360: E/AndroidRuntime(928): at com. android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 04-26 12:50:36.360: E/AndroidRuntime(928): at dalvik.system.NativeStart.main(Native Method) 04-26 12:50 :36.360: E/AndroidRuntime(928): 由: java.lang.NullPointerException 04-26 12:50:36.360: E/AndroidRuntime(928): at com.example.firstapp.MainActivity.onCreate(MainActivity.java:25) ) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android.app.Activity.performCreate(Activity.java:5231) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android .app.Instrumentation.callAct ivityOnCreate(Instrumentation.java:1087) 04-26 12:50:36.360: E/AndroidRuntime(928): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159) 04-26 12:50:36.360: E/ AndroidRuntime(928): ... 11 更多 04-26 12:50:38.660: I/Process(928): 发送信号。 PID: 928 SIG: 9 04-26 12:50:42.540: D/AndroidRuntime(980): 关闭 VM 04-26 12:50:42.540: W/dalvikvm(980): threadid=1: 线程以未捕获的异常退出(group=0xb2a87ba8) 04-26 12:50:42.550: E/AndroidRuntime(980): 致命异常: main 04-26 12:50:42.550: E/AndroidRuntime(980): Process: com.example.firstapp, PID : 980 04-26 12:50:42.550: E/AndroidRuntime(980): java.lang.RuntimeException: 无法启动活动 ComponentInfocom.example.firstapp/com.example.firstapp.MainActivity: java.lang.NullPointerException 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2195) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android. app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.app.ActivityThread.access$800(ActivityThread.java:135) 04-26 12:50 :42.550: E/AndroidRuntime(980): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.os.Handler.dispatchMessage(Handler.java:102) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.os.Looper .loop(Looper.java:136) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.app.ActivityThread.main(ActivityThread.java:5017) 04-26 12:50:42.550: E /AndroidRuntime(980): at java.lang.reflect.Method.invokeNative(Native Method) 04-26 12:50:42.550: E/AndroidRuntime(980): at java.lang.reflect.Method.invoke(Method.java :515) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 04-26 12:50:42.550: E /AndroidRuntime(980): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 dalvik.system.NativeStart.main(本机方法)04-26 12:50:42.550:E/AndroidRuntime(980):引起:java.lang.NullPointerException 04-26 12:50:42.550:E/AndroidRuntime(980):在 com.example.firstapp。 MainActivity.onCreate(MainActivity.java:25) 04 -26 12:50:42.550: E/AndroidRuntime(980): 在 android.app.Activity.performCreate(Activity.java:5231) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.app .Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 04-26 12:50:42.550: E/AndroidRuntime(980): 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159) 04-26 12:50:42.550 : E/AndroidRuntime(980): ... 11 更多 04-26 12:50:44.760: I/Process(980): 发送信号。 PID:980 SIG:9

(我试图使对象可点击并崩溃)这是我的布局文件http://it.tinypic.com/r/t0j5u1/8

【问题讨论】:

可能activity_main没有id为imageView3的视图 发布您的布局文件 能否请您发布您的 logcat sn-p 和布局 xml 文件? activity_main 中是否有 ID 为 imageView3 的 ImageView? 【参考方案1】:

您的imageView3 位于片段布局中,而不是activity_main 布局中。因此在您的活动onCreate() 中找不到它。

将代码移动到片段onCreateView() 并在您刚刚膨胀的片段布局上调用findViewById(),例如

View rootView = inflater.inflate(R.layout.your_fragment_layout);
ImageView red_view=(ImageView)rootView.findViewById(R.id.imageView3);
red_view.setOnClickListener(...);
return rootView;

【讨论】:

【参考方案2】:

看到这个

public void onCreate(Bundle savedInstanceState) 

        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        button = (Button) findViewById(R.id.buttonToast);

        button.setOnClickListener(new OnClickListener() 

              @Override
              public void onClick(View arg0) 

                 Toast.makeText(getApplicationContext(), 
                               "Button is clicked", Toast.LENGTH_LONG).show();

              
        );
    

【讨论】:

【参考方案3】:

如果你在 ImageView 中设置了点击事件,那么设置属性

android:clickable="true" 

在您的布局 xml 文件中。

【讨论】:

以上是关于setOnClickListener 崩溃的主要内容,如果未能解决你的问题,请参考以下文章

片段崩溃与 setOnClickListener

setOnClickListener 使我的应用程序崩溃 [重复]

setOnClickListener导致APP崩溃

Android 弹出经典的Date框(年日期到今天为止)

JAudioTagger Android 标签更新不会在库刷新时显示

相机意图应用程序崩溃