6

Dostaję dziwną listę błędów, niektóre pozornie nie są połączone, ale nie mam sposobu, aby powiedzieć, ponieważ nie mogę nawet załadować aplikacji do debugowania. Jest to bardzo prosta aplikacja, 3 przyciski radiowe w grupie radiowej, a każda z nich wyzwala inną piosenkę do grania.Android - plik śledzenia otwierania błędu: brak takiego pliku lub katalogu

Zacznę od opublikowania mojego Manifestu, pliku aktywności i układu, a następnie opublikuję dziennik błędów.

Oczywisty:

<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;} 
      } 
     }); 
    } 
} 

układ:

<?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> 

Log:

02-21 20: 34: 05.0 44: D/AndroidRuntime (322): Wyłączanie VM 02-21 20: 34: 05.044: W/dalvikvm (322): threadid = 1: wątek wychodzący z niezatapnięty wyjątek (grupa = 0x4001d800) 02-21 20:34 : 05,094: E/Android Runtime (322) krytyczny wyjątek: główny 21/02 20: 34: 05,094: E/Android Runtime (322) java.lang.RuntimeException: Nie można aktywności Instantiate ComponentInfo {com.cis298. lab2/com.cis298.lab2.LayoutActivity}: java.lang.NullPointerException 02-21 20: 34: 05.094: E/AndroidRuntime (322): at android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2585) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:2 679) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at android.app.ActivityThread.access 2300 USD (ActivityThread.java:125) 02-21 20: 34: 05.094: E/AndroidRuntime (322): pod adresem android.app.ActivityThread $ H.handleMessage (ActivityThread.java:2033) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at android.os.Handler.dispatchMessage (Handler. java: 99) 02-21 20: 34: 05.094: E/AndroidRuntime (322): pod adresem android.os.Looper.loop (Looper.java:123) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at android.app.ActivityThread.main (ActivityThread.java:4627) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at java.lang.reflect.Method.invokeNative (Natywny Metoda) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at java.lang.reflect.Method.invoke (Method.java:521) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:868) 02-21 20: 34: 05.094: E/AndroidRuntime (322): pod numerem com.android.internal.os .ZygoteInit.main (ZygoteInit.java:626) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at dalvik.system.NativeStart.main (Metoda natywna) 02-21 20: 34: 05.094: E/Android Runtime (322) spowodowane przez: java.lang.NullPointerException 02-21 20: 34: 05,094: E/Android Runtime (322) w android.content.ContextWrapper.getResources (ContextWrapper.java:80) 02-21 20: 34: 05.094: E/AndroidRuntime (322): pod adresem android.media.MediaPlayer.create (MediaPlayer.java :641) 02-21 20: 34: 05.094: E/AndroidRuntime (322): pod adresem com.cis298.lab2.LayoutActivity. (LayoutActivity.java:15) 02-21 20:34:05.094: E/AndroidRuntime (322): at java.lang.Class.newInstanceImpl (Metoda natywna) 02-21 20: 34: 05.094: E/AndroidRuntime (322): at java.lang.Class.newInstance (klasa .java: 1429) 02-21 20: 34: 05.094: E/AndroidRuntime (322): pod adresem android.app.Instrumentation.newActivity (Instrumentation.java:1021) 02-21 20: 34: 05.094: E/Android Runtime (322) w android.app.ActivityThread.performLaunchActivity (ActivityThread.java:2577) 21/02 20: 34: 05,094: E/Android Runtime (322) ... 11 więcej

Każda pomoc byłaby bardzo ceniona.

+0

Nie zainicjalizowałeś czegoś w swojej działalności. to wszystko, co mogę z tego powiedzieć! – smk

+1

Co to jest linia 15 programu LayoutActivity.java? –

+0

BTW Przed tagiem zamykającym aktywność usunięto dodatkowe> i nadal otrzymuję te same błędy. –

Odpowiedz

3

Spróbuj przenieść mediaplayer = MediaPlayer.create(this, song); do wnętrza onCreate().

Ponieważ działanie nie zostało w pełni zainicjowane przed onCreate(), może to być przyczyną NPE.

Jednak, kolejnym problemem jest to, że należy utworzyć MediaPlayer z utworu jest początkowo 0 (int ma wartość domyślną 0 gdy jest to zmienna instancji). Jeśli więc przeniesienie rozwiąże problem z NPE, następnym błędem będzie coś, czego nie można znaleźć zasobu. Dlatego zadzwoń pod MediaPlayer.create raz song trzyma się czegoś przydatne.

Może coś takiego zadziała.

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(); 
     } 
     } 
    }); 
    } 
} 

A jeśli utwór nie jest używany nigdzie indziej, można przechowywać go w zakresie onCheckedChanged().

+0

To był mój problem (konieczność przeniesienia go do metody onCreate). Przesyłanie pliku APK za każdym razem zajmuje mi 5 minut. Zajrzałem do tego i ludzie narzekali na 90 sekund, więc coś musi być naprawdę złe, jakiś pomysł? –

+1

Wszyscy byliśmy nowi, a twoje pytanie było miłe i szczegółowe :-) z nowymi użytkownikami, zawsze linkuję do tego meta pytania, jeśli odpowiedzieli mi na moje pytanie, ponieważ nie wszyscy są zaznajomieni z tym, jak działa SO. Tak czy inaczej, witaj! –

Powiązane problemy