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.
Nie zainicjalizowałeś czegoś w swojej działalności. to wszystko, co mogę z tego powiedzieć! – smk
Co to jest linia 15 programu LayoutActivity.java? –
BTW Przed tagiem zamykającym aktywność usunięto dodatkowe> i nadal otrzymuję te same błędy. –