MediaPlayer 使用prepareAsync的正确姿势

    mediaPlayer.reset();
                                        mediaPlayer.setDataSource(url);
//                                mediaPlayer.prepare();
                                        mediaPlayer.prepareAsync();

                                        mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
                                            @Override
                                            public void onPrepared(MediaPlayer mp) {
                                                Log.e("wy", "onPrepared: ");
                                                mp.start();
                                            }
                                        });

全代码

    private MediaPlayer mediaPlayer = new MediaPlayer();
    if (url.contains("http")) {
//                             load = soundPool.load(url, 1);
                                    try {
                                        mediaPlayer.reset();
                                        mediaPlayer.setDataSource(url);
//                                mediaPlayer.prepare();
                                        mediaPlayer.prepareAsync();

                                        mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
                                            @Override
                                            public void onPrepared(MediaPlayer mp) {
                                                Log.e("wy", "onPrepared: ");
                                                mp.start();
                                            }
                                        });
//                                mediaPlayer.start();

                                        mediaPlayer.setOnErrorListener(new MediaPlayer.OnErrorListener() {
                                            @Override
                                            public boolean onError(MediaPlayer mp, int what, int extra) {
                                                Log.e("wy", "onError what: " + what + "  extra: " + extra);
                                                ToastUtils.showShortToast(context, context.getString(R.string.file_dismiss));
                                                animations.stop();
                                                return false;
                                            }
                                        });
                                        mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
                                            @Override
                                            public void onCompletion(MediaPlayer mp) {
                                                Log.e("wy", "mediaPlayer 播放完成 onCompletion: ");
                                                animations.stop();
                                            }
                                        });
                                    } catch (Exception e) {
                                        Log.e("wy", "180 onClick: " + e.getMessage());
                                        e.printStackTrace();
                                    }
                                } else {
//                             load = soundPool.load("https:" + url, 1);
                                    try {
                                        mediaPlayer.reset();
                                        mediaPlayer.setDataSource(url);
                                        mediaPlayer.prepareAsync();
                                        mediaPlayer.start();
                                    } catch (Exception e) {
                                        e.printStackTrace();
                                    }
                                }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值