- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在使用以下代码时遇到问题。我在我的 MediaController 上调用了 setPrevNextListener 并为 Prev 和 Next 定义了两个 onClickListeners。当我单击下一个按钮而不是前进一首轨道时,我前进了两首轨道。这似乎是由于以某种方式调用了 onCompletion。 MediaPlayer.reset() 是否调用 onCompletion?我包含了 logcat 输出和我的代码。如果我做错了什么,请告诉我。提前致谢。
日志:
02-24 00:36:34.826: D/MP(6675): Next Button Clicked, index was: 0
02-24 00:36:34.837: D/MP(6675): About to call Reset()
02-24 00:36:34.906: D/MP(6675): Inside setUpPlayer
02-24 00:36:34.917: D/MP(6675): Called setDataSource with index: 1
02-24 00:36:34.917: D/MP(6675): Leaving setUpPlayer
02-24 00:36:34.917: D/MP(6675): About to call prepareAsync()
02-24 00:36:34.937: D/MP(6675): Leaving next button
02-24 00:36:35.226: E/MediaPlayer(6675): Attempt to call getDuration without a valid mediaplayer
02-24 00:36:35.226: E/MediaPlayer(6675): error (-38, 0)
02-24 00:36:35.276: E/MediaPlayer(6675): Error (-38,0)
02-24 00:36:35.287: D/MP(6675): Inside onCompletion
02-24 00:36:35.337: D/MP(6675): About to call Reset()
02-24 00:36:35.347: D/MP(6675): Inside setUpPlayer
02-24 00:36:35.356: D/MP(6675): Called setDataSource with index: 2
02-24 00:36:35.356: D/MP(6675): Leaving setUpPlayer
02-24 00:36:35.356: D/MP(6675): About to call prepareAsync()
02-24 00:36:35.377: D/MP(6675): Leaving onCompletion
02-24 00:36:36.517: D/MP(6675): Inside onPrepared, index is: 2
02-24 00:36:36.577: D/MP(6675): Leaving onPrepared
代码:
public class MusicPlayerActivity extends Activity implements OnPreparedListener, OnCompletionListener, MediaController.MediaPlayerControl {
private MediaPlayer mp;
private MediaController mc;
private SonarDatabase db;
private SubsonicAPIConnector sonic;
ArrayList<String> songs;
int index = 0;
private Handler handler = new Handler();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.music_player);
// Get params from intent
Intent i = getIntent();
String albumId = i.getStringExtra("albumId");
String artistId = i.getStringExtra("artistId");
String albumName = i.getStringExtra("albumName");
String songName = i.getStringExtra("songName");
String songId = i.getStringExtra("songId");
String coverArt = "al-"+albumId+".jpeg";
String duration = i.getStringExtra("duration");
Log.d("MP", "results: albumName:" + albumName + ", songName: " + songName + ", songId: "
+ songId + ", duration: " + duration + ", coverArt: " + coverArt + ", artistId: "
+ artistId + ", albumId: " + albumId);
db = new SonarDatabase(getApplicationContext());
sonic = new SubsonicAPIConnector(db.getURL(), db.getUsername(), db.getPassword());
String artistName = db.getArtistNameById(artistId);
setTitle("Now Playing");
songs = db.getSongListForAlbum(albumId);
index = songs.indexOf(songId);
Log.d("MP", "songid: " + songId + ", index: " + index);
// Update text views with song information
TextView txtArtist = (TextView) findViewById(R.id.txtArtistName);
txtArtist.setText(artistName);
TextView txtAlbum = (TextView) findViewById(R.id.txtAlbumName);
txtAlbum.setText(albumName);
TextView txtSong = (TextView) findViewById(R.id.txtSongName);
txtSong.setText(songName);
// Show the album art
File img = new File(this.getFilesDir()+"/covers/"+coverArt);
if(img.exists()) {
Log.d("MP", "Found image at: " + img.toString());
ImageView imgView = (ImageView) findViewById(R.id.cover_art);
imgView.setImageBitmap(BitmapFactory.decodeFile(img.getPath()));
} else {
Log.d("MP", "Couldn't find image: " + img.toString());
}
// Create the media player and controller
mp = new MediaPlayer();
mp.setOnPreparedListener(this);
mp.setOnCompletionListener(this);
mc = new NonHidingMediaController(this);
mc.setPrevNextListeners(new View.OnClickListener() {
@Override
public void onClick(View v) {
// next button clicked
Log.d("MP", "Next Button Clicked, index was: " + index);
playNextTrack();
Log.d("MP", "Leaving next button");
}
}, new View.OnClickListener() {
@Override
public void onClick(View v) {
// previous button clicked
Log.d("MP", "Previous button clicked, index was: " + index);
if(mp.isPlaying() && mp.getCurrentPosition() < 2000 && index != 0) {
Log.d("MP", "Start the prior song.");
playPreviousTrack();
} else {
Log.d("MP", "Restart this song.");
restartCurrentTrack();
}
Log.d("MP", "Leaving previous button");
}
});
mc.setMediaPlayer(this);
setUpPlayer();
Log.d("MP", "About to call prepareAsync()");
mp.prepareAsync();
}
@Override
public void onCompletion(MediaPlayer mp) {
Log.d("MP", "Inside onCompletion");
//TODO add code for scrobbling here.
playNextTrack();
Log.d("MP", "Leaving onCompletion");
}
private void playNextTrack() {
index++;
TextView txtSong = (TextView) findViewById(R.id.txtSongName);
txtSong.setText(db.getSongNameById(songs.get(index)));
Log.d("MP", "About to call Reset()");
mp.reset();
setUpPlayer();
Log.d("MP", "About to call prepareAsync()");
mp.prepareAsync();
}
private void playPreviousTrack() {
index--;
TextView txtSong = (TextView) findViewById(R.id.txtSongName);
txtSong.setText(db.getSongNameById(songs.get(index)));
Log.d("MP", "About to call Reset()");
mp.reset();
setUpPlayer();
Log.d("MP", "About to call prepareAsync()");
mp.prepareAsync();
}
private void restartCurrentTrack() {
mp.seekTo(0);
}
public void onPrepared(MediaPlayer mp) {
Log.d("MP", "Inside onPrepared, index is: " + index);
mc.setMediaPlayer(this);
mc.setAnchorView(findViewById(R.id.music_player_view));
mp.start();
handler.post(new Runnable() {
public void run() {
mc.setEnabled(true);
mc.show();
}
});
Log.d("MP", "Leaving onPrepared");
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.activity_music_player, menu);
return true;
}
@Override
public boolean onTouchEvent(MotionEvent event) {
Log.d("MP", "OnTouchEvent called");
mc.show();
return false;
}
private void setUpPlayer() {
Log.d("MP", "Inside setUpPlayer");
mp.setAudioStreamType(AudioManager.STREAM_MUSIC);
try {
mp.setDataSource(sonic.streamString("&id=" + songs.get(index)));
Log.d("MP", "Called setDataSource with index: " + index);
} catch (IllegalArgumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (SecurityException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IllegalStateException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
Log.d("MP", "Leaving setUpPlayer");
}
@Override
protected void onStop() {
super.onStop();
mc.hide();
mp.stop();
mp.release();
}
public void start() {
mp.start();
}
public void pause() {
mp.pause();
}
public int getDuration() {
return mp.getDuration();
}
public int getCurrentPosition() {
return mp.getCurrentPosition();
}
public void seekTo(int i) {
mp.seekTo(i);
}
public boolean isPlaying() {
return mp.isPlaying();
}
public int getBufferPercentage() {
return 0;
}
public boolean canPause() {
return true;
}
public boolean canSeekBackward() {
return true;
}
public boolean canSeekForward() {
return true;
}
public class NonHidingMediaController extends MediaController {
public NonHidingMediaController(Context context, AttributeSet attrs) {
super(context, attrs);
}
public NonHidingMediaController(Context context, boolean useFastForward) {
super(context, useFastForward);
}
public NonHidingMediaController(Context context) {
super(context);
}
@Override
public void show(int timeout) {
super.show(0);
}
}
}
最佳答案
我深入研究了 android 源代码,发现任何未处理的错误都会导致 MediaPlayer 调用 onCompletion 处理程序。在这种情况下,您似乎是在空闲、已初始化或错误状态下调用 getDuration。可能从媒体 Controller 内部。我建议在任何调用 getDuration 的地方之前添加一些 Log.d() 以查看导致问题的调用位置。
关于Android MediaPlayer.reset() 正在调用 onCompletion,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15049097/
我在 logcat 中收到一条警告消息 W/MediaPlayer-JNI(16795): MediaPlayer finalized without being released 请告诉我我错在哪里
我有以下代码。 例如: if(player1 != null){ if(player1.isPlaying()){ //check if it playing //other
我在安卓系统工作。我正在创建一个正在运行音频文件的 mediaPlayer。我有 10 个按钮。我为每个按钮分配了不同的 url。因此,当我按下按钮 1 时,将播放与按钮 1 相关的 url 歌曲。然
我正在使用 MediaPlayer。我想制作在线流媒体广播。现在我有这个 mediaPlayer 对象(MediaPlayer 的),在 fragment 1 中说,当我在 fragment 1 上时
我使用了以下代码: mp = MediaPlayer.create(this, Uri.parse("file://"+filePath)); mp.start(); 这很好用。然后我想播放文件夹中的
我通过下载新文件来启动我的应用程序,如果有任何文件开始播放循环。然后我每 x 秒触发一个任务来寻找新媒体。调用任务后,视频将停止播放,并显示错误 MediaPlayer finalized witho
我的应用程序允许用户从多个音频流中进行选择,当用户点击其中一个播放按钮时,将调用以下代码: @Override public void onClick(View view) { mMediaP
我正在尝试在我的 ViewController 中播放视频。 Mediaplayer.framework 和所有 Headers 都在我的 Frameworks 文件夹中,包括 MediaPlayer
我正在使用 MediaPlayer 和 SurfaceView 播放本地视频文件。 SurfaceView 是 Activity 中的唯一控件,而我的视频文件是 QVGA 或其他。问题是视频被拉伸(s
我正在使用 JavaFX 的 MediaPlayer 播放 mp3 文件,getCurrentTime() 工作正常,但是当我在某个时候使用 seek() 方法时, getCurrentTime()
我将音量设置为 0.0,然后在 while 循环中一点一点地改变音量。然而,音量从 0.0 跳到 1.0?如何顺利改变音量?我试过了 public class EngineSound extends
我为“播放”和“暂停”按钮创建了两个 onClick 方法,但如果先点击“暂停”,然后点击“播放”按钮,则音乐不会播放。下面是代码 package com.example.myaudio; impor
我用 MediaPlayer 控件创建了一个绑定(bind)服务,它可以加载和播放音频。但碰巧的是,有时 mediaPlayer.prepare(); 速度不够快,并不总是准备好播放。 那么我怎样才能
我正在我的应用程序中播放从网络流式传输的 mp3 文件,一些 mp3 文件有奇怪的行为:mediaPlayer.getCurrentPosition() 大于 mediaPlayer.getDurat
我想制作广播播放器示例,但我有一些错误。我无法修复它。 我的源代码 String url = ""; //Shoutcast Radio URL mp = new MediaPlayer();
我知道有一些类似的问题,但没有一个回答我的问题。当我点击一个按钮时,媒体播放器被调用,并且它出现在日志中。 06-02 00:20:38.980 26035-26035/myapp.com.facad
我正在尝试从 URL 流式传输音频。该代码适用于其他 URL,但其中一个 URL 在 OnPrepared 方法中失败,返回此错误代码:(1, -2147483648)。我看过一些人说这是因为权限,但
我在我的 Android 应用程序中使用 MediaPlayer 来播放视频。当通过 mediaPlayer.pause() 方法暂停播放并调用 mediaPlayer.seekTo(msec) 时,
我的应用程序在 MediaPlayer 流媒体方面存在问题,特别是在 Nexus 5 上。我不确定这是 Nexus 5 还是 API 级别 19 导致的问题。基本上我的 MediaPlayer 准备好
不过,我正在使用 RingtoneManager 来获取 Ringtone。 此信息已包含在 this question and answer 中,但 Google 员工不太可能找到它,除非他们已经知
我是一名优秀的程序员,十分优秀!