0

なぜこれが機能しないのか誰かが知っていますか?logcatで非常に基本的なエラーが発生するので、追加する必要はないと思います。

MainActivity.java:

package com.sydcul.badluckboris;

import android.media.MediaPlayer;
import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.widget.ImageButton;

public class MainActivity extends Activity {

    ImageButton boris;
    MediaPlayer mp = MediaPlayer.create(getApplicationContext(), R.raw.ouch);
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        boris = (ImageButton) findViewById(R.id.ibBoris);

        boris.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                mp.start();
            }
        });
        }
}

activity_main.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <ImageButton
        android:id="@+id/ibBoris"
        android:layout_width="250dp"
        android:layout_height="300dp"
        android:layout_alignParentTop="true"
        android:layout_centerHorizontal="true"
        android:contentDescription="@string/boris"
        android:scaleType="fitXY"
        android:src="@drawable/badluckboris2" />

</RelativeLayout>

そしてAndroidManifest.xml:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.sydcul.badluckboris"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

編集:LogCat:

10-31 17:15:05.670: E/AndroidRuntime(6500): FATAL EXCEPTION: main
10-31 17:15:05.670: E/AndroidRuntime(6500): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.sydcul.badluckboris/com.sydcul.badluckboris.MainActivity}: java.lang.NullPointerException
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1573)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:935)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.os.Handler.dispatchMessage(Handler.java:99)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.os.Looper.loop(Looper.java:130)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.ActivityThread.main(ActivityThread.java:3691)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at java.lang.reflect.Method.invokeNative(Native Method)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at java.lang.reflect.Method.invoke(Method.java:507)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:912)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:670)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at dalvik.system.NativeStart.main(Native Method)
10-31 17:15:05.670: E/AndroidRuntime(6500): Caused by: java.lang.NullPointerException
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.content.ContextWrapper.getApplicationContext(ContextWrapper.java:100)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at com.sydcul.badluckboris.MainActivity.<init>(MainActivity.java:12)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at java.lang.Class.newInstanceImpl(Native Method)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at java.lang.Class.newInstance(Class.java:1409)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.Instrumentation.newActivity(Instrumentation.java:1024)
10-31 17:15:05.670: E/AndroidRuntime(6500):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1565)
10-31 17:15:05.670: E/AndroidRuntime(6500):     ... 11 more
10-31 17:15:05.680: E/(1749): Dumpstate > /data/log/dumpstate_app_error
10-31 17:15:05.680: W/ActivityManager(1749):   Force finishing activity com.sydcul.badluckboris/.MainActivity

前もって感謝します。私はAndroidの初心者であることに注意してください。ほぼVB.NETthoを行いました。

4

1 に答える 1

2

エラーで簡単になります。私が見た限りでは、あなたは MediaPlayer を用意していないのではないかと推測していますが、確かではありません。MediaPlayer が onCreate の外に設定されているのを見るのも少し奇妙です。その時点でコンテキストがまだ完全に有効ではない可能性がありますが、それが本当に問題を引き起こすかどうかはわかりません。

于 2012-10-31T16:10:30.853 に答える