繁体   English   中英

不幸的是,当该应用在genymotion模拟器上运行时,android已停止工作

[英]Unfortunately android has stopped working when the app is run on genymotion emulator

我试图制作一个非常简单的音频播放器,但稍后在模拟器上运行该应用程序时,单击播放按钮时会弹出错误“不幸的是,android已停止工作”并崩溃了。

这是我的代码。

MainActivity.java

package toast.akappstudio.com.audiodemo;

import android.media.MediaPlayer;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;

public class MainActivity extends AppCompatActivity {

    MediaPlayer player;

    public void playAudio(View view){


        player.start();

    }
    public void pauseAudio(View view){

        player.pause();
    }

    public void stopAudio(View view){

        player.stop();
    }
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        MediaPlayer player = MediaPlayer.create(this, R.raw.audio);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.menu_main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    } }

content.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="toast.akappstudio.com.audiodemo.MainActivity"
    tools:showIn="@layout/activity_main">

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Play"
        android:id="@+id/playbutton"
        android:layout_marginLeft="67dp"
        android:layout_marginStart="67dp"
        android:layout_marginTop="176dp"
        android:onClick="playAudio"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Pause"
        android:id="@+id/pausebutton"
        android:layout_marginLeft="55dp"
        android:layout_marginStart="55dp"
        android:onClick="pauseAudio"
        android:layout_alignTop="@+id/playbutton"
        android:layout_toRightOf="@+id/playbutton"
        android:layout_toEndOf="@+id/playbutton" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="STOP"
        android:id="@+id/stopbutton"
        android:layout_centerVertical="true"
        android:layout_centerHorizontal="true"
        android:onClick="stopAudio" />
</RelativeLayout>

LOGCAT:

java.lang.IllegalStateException:无法执行android:onClick的方法
在android.support.v7.app.AppCompatViewInflater $ DeclaredOnClickListener.onClick(AppCompatViewInflater.java:275)在android.view.View.performClick(View.java:4438)在android.view.View $ PerformClick.run(View.java :18422),位于android.os.Handler.handleCallback(Handler.java:733),位于android.os.Handler.dispatchMessage(Handler.java:95),位于android.os.Looper.loop(Looper.java:136),位于android .app.ActivityThread.main(ActivityThread.java:5001)(位于java.lang.reflect.Method.invokeNative(本机方法)(位于java.lang.reflect.Method.invoke(Method.java:515))(位于com.android.internal) .os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:785)在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)在dalvik.system.NativeStart.main(本机方法)由:java android.support.v7.app.AppCompatViewInflater $ DeclaredOnClickListener处的java.lang.reflect.Method.invoke(Method.java:515)处的java.lang.reflect.Method.invokeNative(本机方法)处的.lang.reflect.InvocationTargetException。 onClick(AppCompatViewInflater。 android.view.View.performClick(View.java:4438)上的java:270)android.os.Handler.handleCallback(Handler.java:733)上android.view.View $ PerformClick.run(View.java:18422)上的)在android.os.Handler.dispatchMessage(Handler.java:95)在android.os.Looper.loop(Looper.java:136)在android.app.ActivityThread.main(ActivityThread.java:5001)在java.lang com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:785)上java.lang.reflect.Method.invoke(Method.java:515)上的.reflect.Method.invokeNative(本机方法) android.internal.os.ZygoteInit.main(ZygoteInit.java:601)在dalvik.system.NativeStart.main(本机方法)由以下原因引起:toast.akappstudio.com.audiodemo.MainActivity.playAudio()上的java.lang.NullPointerException MainActivity.java:17),位于java.lang.reflect.Method.invokeNative(原生方法),位于android.support.v7.app.AppCompatViewInflater $ DeclaredOnClickListener处的java.lang.reflect.Method.invoke(Method.java:515)。 Android上的onClick(AppCompatViewInflater.java:270)。 android.os.Handler.handleCallback(Handler.java:733)上的android.view.View $ PerformClick.run(View.java:18422)上的android.os.Handler.handleCallback(Handler.java:733)上的view.View.performClick(View.java:4438) .dispatchMessage(Handler.java:95)在android.os.Looper.loop(Looper.java:136)在android.app.ActivityThread.main(ActivityThread.java:5001)在java.lang.reflect.Method.invokeNative( com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:785)处java.lang.reflect.Method.invoke(Method.java:515)处的本机方法)。 ZygoteInit.main(ZygoteInit.java:601)位于dalvik.system.NativeStart.main(本机方法)06-28 13:40:39.326 2477-2477 /? I / Process:正在发送信号。 PID:2477 SIG:9

更改

`MediaPlayer player = MediaPlayer.create(this, R.raw.audio);`

`player = MediaPlayer.create(this, R.raw.audio);` 

在您的onCreate()方法中。

原因

您正在创建全局变量mediaPlayer并且还在onCreate()中声明了另一个同名变量。 onCreate()将成为局部变量实例,并且由于您没有初始化全局变量,因此它将为null。 因此,当您尝试在play()pause()stop()访问它时,将获得空指针异常。 希望我的解释让您清楚:)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM