6

エラーの奇妙なリストが表示されていますが、外見上断線していますが、デバッグするためにアプリケーションをロードできないため、これは非常にシンプルなアプリで、ラジオグループの3つのラジオボタンで、それぞれが再生する別の曲をトリガーします。Androidファイルを開いているときにトレースファイルがありません:そのようなファイルやディレクトリがありません。

私はマニフェスト、アクティビティファイル、レイアウトを投稿し、エラーログを投稿することから始めます。

マニフェスト:

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

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

    <application 
     android:allowBackup="true" 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" 
     android:theme="@style/AppTheme" > 

     <activity 
      android:label = "@string/app_name" 
      android:name = ".LayoutActivity"> 
      <intent-filter > 
       <action android:name = "android.intent.action.MAIN" /> 

       <category android:name = "android.intent.category.LAUNCHER" /> 

      </intent-filter> 
      ></activity> 
    </application> 

</manifest> 

LayoutActivity:

package com.cis298.lab2; 

import java.io.IOException; 

import com.cis298.lab2.R; 

import android.app.Activity; 
import android.os.Bundle; 
import android.media.MediaPlayer; 
import android.widget.RadioGroup; 

public class LayoutActivity extends Activity { 

    int song; 
    MediaPlayer mediaplayer = MediaPlayer.create(this, song); 

    public void onCreate(Bundle savedInstanceState){ 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.layout); 
     try { 
      mediaplayer.prepare(); 
     } catch (IllegalStateException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
     RadioGroup radgrp = (RadioGroup) findViewById(R.id.radiogroup); 
     radgrp.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { 

      @Override 
      public void onCheckedChanged(RadioGroup group, int checkedId) { 
       switch (checkedId){ 
       case R.id.dance: 
        song = R.raw.redalert; 
        mediaplayer.start(); 
        break; 
       case R.id.rap: 
        song = R.raw.cannedheat; 
        break; 
       case R.id.rock: 
        song = R.raw.movmou8105; 
        break;} 
      } 
     }); 
    } 
} 

レイアウト:

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" > 

    <RadioGroup 
     android:id="@+id/radiogroup" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_alignParentLeft="true" 
     android:layout_alignParentTop="true" 
     android:orientation="vertical" > 

     <RadioButton 
      android:id="@+id/rock" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:text="Play Rock" /> 

     <RadioButton 
      android:id="@+id/rap" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:text="Play Rap" 
      android:checked="true"/> 

     <RadioButton 
      android:id="@+id/dance" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content" 
      android:text="Play Dance" 
      android:textAlignment="center" /> 

    </RadioGroup> 

</RelativeLayout> 

ログ:

2月21日20:34:05.0 44:D/AndroidRuntime(322):VMをシャットダウン02-21 20:34:05.044:W/dalvikvm(322):threadid = 1:スレッドが終了する 未知の例外(グループ= 0x4001d800)02-21 20:34 :05.094: はE/AndroidRuntime(322):致命的な例外:メイン2月21日20:34:05.094: E/AndroidRuntime(322):java.lang.RuntimeException: インスタンス化活性ComponentInfo {com.cis298できません。 lab2/com.cis298.lab2.LayoutActivity}: java.lang.NullPointerException 02-21 20:34:05.094: E/AndroidRuntime(322): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585) 02-21 20:34:05.094:E/AndroidRuntime(322): android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2) Android/AndroidRuntime(322): android.app.ActivityThread.access $ 2300(ActivityThread.java:125)02-21 20:34:05.094:E/AndroidRuntime(679) 02-21 20:34:05.094: 322): android.app.ActivityThread $ H.handleMessage(ActivityThread.java:2033) 02-21 20:34:05.094:E/AndroidRuntime(322): android.os.Handler.dispatchMessage(Handler。 Android/AndroidRuntime(322): android.os.Looper.loop(Looper.java:123)02-21 20:34:05.094: E/AndroidRuntime(Java:99)02-21 (322): android.app.ActivityThread.main(ActivityThread.java:4627)02-21 20:34:05.094:E/AndroidRuntime(322): でjava.lang.reflect.Method.invokeNative(ネイティブ方法) 02-21 20:34:05.094:E/AndroidRuntime(322): の場合java.lang.reflect.Method.invoke(Method.java:521)02-21 20:34:05.094: E/AndroidRuntime(322 ): でcom.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:868) 02-21 20:34:05.094:E/AndroidRuntime(322): でcom.android.internal.os .ZygoteInit.main(ZygoteInit.java:626)02から21 20:34:05.094:E/AndroidRuntime(322): dalvik.system.NativeStart.main(ネイティブメソッド)で2月21日20:34:05.094: E/AndroidRuntime(322):原因:java.lang.NullPointerException 02-21 20:34:05.094:E/AndroidRuntime(322): android.content.ContextWrapper.getResources(ContextWrapper.java:80) 2月21日20:34:05.094:E/AndroidRuntime(322): android.media.MediaPlayer.create(MediaPlayer.java:641)で02から21 20:34:05.094:E/AndroidRuntime(322)。 com.cis298.lab2.LayoutActivity。(LayoutActivity.java:15)02-21 20:34:05。094:E/AndroidRuntime(322):at java.lang.Class.newInstanceImpl(ネイティブメソッド)02-21 20:34:05.094: E/AndroidRuntime(322): java.lang.Class.newInstance(Class .java:1429)02-21 20:34:05.094: E/AndroidRuntime(322): android.app.Instrumentation.newActivity(Instrumentation.java:1021) 02-21 20:34:05.094:E/AndroidRuntime(322): android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)で 2月21日20:34:05.094:E/AndroidRuntime(322)... 11もっと

任意助けていただければ幸いです。

+0

アクティビティで何かを初期化しないでください。それは私がこれから言うことができるすべてです! – smk

+1

LayoutActivity.javaの15行目とは何ですか? –

+0

BTW私が削除した閉じるアクティビティタグの前に余分な>があり、私はまだ同じエラーを受けています。 –

答えて

3

mediaplayer = MediaPlayer.create(this, song);onCreate()に移動してみてください。

アクティビティがonCreate()まで完全に初期化されていないため、これがNPEの原因である可能性があります。

しかし、次の問題は、あなたが(それはインスタンス変数であるとき、intは0のデフォルト値を持っている)曲が最初に0ているとのMediaPlayerを作成することです。したがって、MediaPlayer.createを移動するとがこの NPEを解決する場合、次のエラーはリソースを見つけることができないことになります。したがって、song有用なに保持されてからMediaPlayer.createを呼び出すと、

多分このようなものが動作します。

public class LayoutActivity extends Activity { 

    int song; 
    MediaPlayer mediaPlayer; 

    public void onCreate(Bundle savedInstanceState){ 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.layout); 

    RadioGroup radgrp = (RadioGroup) findViewById(R.id.radiogroup); 
    radgrp.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() { 

     @Override 
     public void onCheckedChanged(RadioGroup group, int checkedId) { 
     switch (checkedId){ 
      case R.id.dance: 
      song = R.raw.redalert; 
      break; 
      case R.id.rap: 
      song = R.raw.cannedheat; 
      break; 
      case R.id.rock: 
      song = R.raw.movmou8105; 
      break; 
     } 


     mediaplayer = MediaPlayer.create(LayoutActivity.this, song); 
     try { 
      mediaplayer.prepare(); 
      mediaplayer.start(); 
     } catch (IllegalStateException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
     } 
    }); 
    } 
} 

そして、曲がどこにも使用されていない場合、あなたはonCheckedChanged()の範囲でそれを維持することができます。

+0

これは私の問題でした(onCreateメソッドに移動する必要があります)。また、毎回APKをアップロードするには5分以上かかります。私はそれを調べ、人々は約90秒間不平を言っていたので、何かが本当に間違っていなければなりません。 –

+1

私はすべて新しいもので、あなたの質問は素敵で細かいものでした:-)新しいユーザーと、私はいつもそのメタ質問にリンクしています。とにかく、歓迎! –

関連する問題