我在手机的内部存储空间中播放 .mp3 文件时遇到了一些麻烦。 我正在为这个应用程序开发我正在关注的课程,但我似乎无法弄清楚为什么我的 .mp3 文件无法播放。
以下是该应用的基本设置:
我必须用4个按钮创建一个屏幕;三个链接到本地存储上的 .mp3 文件,另一个用于打开浏览器,可以浏览 .mp3 文件。 在浏览屏幕上,当选择一个文件并且它是 .mp3 时,会出现三个按钮,让您定义一个新链接,以便播放音频。
我正在使用文件/文件夹从这里浏览: http://custom-android-dn.blogspot.nl/2013/01/create-simple-file-explore-in-android.html ,这非常有效。 我可以毫无问题地拿起我的 .mp3 文件,一直到我内部存储的基本路径。
然后我看了我应该如何播放存储中的音频文件,这里: Play mp3 sounds from SD card (接受的答案),虽然我不得不调整它有点,因为文件路径已经在不同的类中定义。
我正在使用的代码(在描述之后定义的类名)..
..播放音频( MainActivity.java ):
if(R.id.mp3_1_btn == b.getId()){
a.PlayAudio(0);
}
..功能PlayAudio()( Audio.java )
public void PlayAudio(int audioFile){
mp.setAudioStreamType(AudioManager.STREAM_MUSIC);
if(AudioArray[audioFile] != ""){
if(mp != null){
mp.release();
}
try{
FileDescriptor fd =null;
FileInputStream fis = new FileInputStream(AudioArray[audioFile]);
fd = fis.getFD();
if(fd != null){
mp.setDataSource(fd);
mp.prepare();
mp.start();
Message("Play");
}
}catch(Exception e){
e.printStackTrace();
}
}
}
..浏览器的onCreate( FileExplorerActivity.java ):
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
currentDir = new File(Environment.getExternalStorageDirectory().getAbsolutePath());
fill(currentDir);
}
..将音频文件分配给按钮( FileExplorerActivity.java ):
if(R.id.AssignBtn1 == b.getId()){
a.setAudioString(0, fullDirectory);
this.finish();
}
..与 fullDirectory 相关的事情( FileExplorerActivity.java/FileBrowser.java )
fullDirectory = data.getStringExtra("GetPath")+"/"+data.getStringExtra("GetFileName");
intent.putExtra("GetPath",currentDir.toString());
intent.putExtra("GetFileName",o.getName());
..与 AudioArray 相关的事情( Audio.java )
private static String AudioArray[] = {"", "", ""};
public void setAudioString(int index, String dir){
AudioArray[index] = dir;
}
这是我的 fullDirectory 变量的输出字符串:
/storage/emulated/0/Music/<name>.mp3
我也从错误和消息中得到了一些日志。
当我将.mp3指定给按钮时
08-24 22:44:11.468: D/MediaPlayer(10327): release() in
08-24 22:44:11.468: D/MediaPlayer(10327): release() out
08-24 22:44:11.478: W/System.err(10327): java.lang.IllegalStateException
08-24 22:44:11.478: W/System.err(10327): at android.media.MediaPlayer._setDataSource(Native Method)
08-24 22:44:11.478: W/System.err(10327): at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1282)
08-24 22:44:11.478: W/System.err(10327): at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1254)
08-24 22:44:11.478: W/System.err(10327): at com.example.mp3.Audio.PlayAudio(Audio.java:32)
08-24 22:44:11.478: W/System.err(10327): at com.example.mp3.MainActivity.onClick(MainActivity.java:53)
08-24 22:44:11.478: W/System.err(10327): at android.view.View.performClick(View.java:4480)
08-24 22:44:11.478: W/System.err(10327): at android.view.View$PerformClick.run(View.java:18686)
08-24 22:44:11.478: W/System.err(10327): at android.os.Handler.handleCallback(Handler.java:733)
08-24 22:44:11.478: W/System.err(10327): at android.os.Handler.dispatchMessage(Handler.java:95)
08-24 22:44:11.478: W/System.err(10327): at android.os.Looper.loop(Looper.java:157)
08-24 22:44:11.488: W/System.err(10327): at android.app.ActivityThread.main(ActivityThread.java:5872)
08-24 22:44:11.488: W/System.err(10327): at java.lang.reflect.Method.invokeNative(Native Method)
08-24 22:44:11.488: W/System.err(10327): at java.lang.reflect.Method.invoke(Method.java:515)
08-24 22:44:11.488: W/System.err(10327): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:852)
08-24 22:44:11.488: W/System.err(10327): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:668)
08-24 22:44:11.488: W/System.err(10327): at dalvik.system.NativeStart.main(Native Method)
当试图播放说.mp3(这显然会使应用崩溃)
08-24 22:45:21.628: W/dalvikvm(10327): threadid=1: thread exiting with uncaught exception (group=0x4170ee18)
08-24 22:45:21.628: E/AndroidRuntime(10327): FATAL EXCEPTION: main
08-24 22:45:21.628: E/AndroidRuntime(10327): Process: com.example.mp3, PID: 10327
08-24 22:45:21.628: E/AndroidRuntime(10327): java.lang.IllegalStateException
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.media.MediaPlayer._setAudioStreamType(Native Method)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.media.MediaPlayer.setAudioStreamType(MediaPlayer.java:2135)
08-24 22:45:21.628: E/AndroidRuntime(10327): at com.example.mp3.Audio.PlayAudio(Audio.java:18)
08-24 22:45:21.628: E/AndroidRuntime(10327): at com.example.mp3.MainActivity.onClick(MainActivity.java:53)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.view.View.performClick(View.java:4480)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.view.View$PerformClick.run(View.java:18686)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.os.Handler.handleCallback(Handler.java:733)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.os.Handler.dispatchMessage(Handler.java:95)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.os.Looper.loop(Looper.java:157)
08-24 22:45:21.628: E/AndroidRuntime(10327): at android.app.ActivityThread.main(ActivityThread.java:5872)
08-24 22:45:21.628: E/AndroidRuntime(10327): at java.lang.reflect.Method.invokeNative(Native Method)
08-24 22:45:21.628: E/AndroidRuntime(10327): at java.lang.reflect.Method.invoke(Method.java:515)
08-24 22:45:21.628: E/AndroidRuntime(10327): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:852)
08-24 22:45:21.628: E/AndroidRuntime(10327): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:668)
08-24 22:45:21.628: E/AndroidRuntime(10327): at dalvik.system.NativeStart.main(Native Method)
所以,我们终于提出了这个问题:
我的代码有什么问题,我该如何解决?我应该尝试不同的方法,还是我错过了什么?
我希望有人可以帮助我。如果有人要我将我的项目放在Dropbox上并发布链接,请务必提出并且我很乐意遵守。
答案 0 :(得分:1)
另一种方法是音频服务:
import android.app.Service;
import android.content.Intent;
import android.media.MediaPlayer;
import android.os.IBinder;
public class AudioService extends Service {
MediaPlayer _player;
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public void onCreate() {
_player = MediaPlayer.create(this, R.raw.someaudio);
//where someaudio (someaudio.mp3) is the raw resource id for the resource to use as the datasource
// or _player = MediaPlayer.create(this, ... uri ...);
// where uri is the Uri from which to get the datasource
// see http://developer.android.com/reference/android/media/MediaPlayer.html
_player.setLooping(false);
}
@Override
public void onDestroy() {
if (_player.isPlaying()) {
_player.stop();
}
_player.release();
_player = null;
}
@Override
public void onStart(Intent intent, int startid) {
_player.start();
}
}
在MainActivity中调用服务:
startService(new Intent(this, AudioService.class)); // start service to play mp3 file
// to stop playing: stopService(new Intent(this, AudioService.class));