Android-测试设备的 Mediaplayer 流媒体问题

标签 android streaming media-player android-mediaplayer

我目前有一个媒体播放器,它具有可流式数据源。我有两台测试设备:HTC Thunderbolt 和三星 Galaxy SII Skyrocket。

HTC 设备能够完美地传输文件;然而,Galaxy SII 根本不能,并且给了我一堆媒体播放器错误代码。

我正在正确实现与媒体播放器相关的所有内容...但是,我无法解决这个问题...为什么它可以在一部手机上运行,​​但不能在另一部手机上运行?它是相同的链接。

有什么想法吗?来自以下设备的日志。如果需要的话也可以发布我的代码。

谢谢!

从 HTC 设备登录:

06-25 18:19:23.192: D/MainAudioService(23564): next song is: http://soundcloud.com/stopdroprave/chromeo-night-by-night/download/s-bpPu1
06-25 18:19:26.675: W/MediaPlayer(23564): info/warning (1, 902)
06-25 18:19:28.497: D/dalvikvm(23564): GC_EXTERNAL_ALLOC freed 515K, 50% free 3544K/7047K, external 477K/989K, paused 22ms
06-25 18:19:31.250: D/MainAudioService(23564): Song length in minutes is: -6:5
06-25 18:19:31.250: D/MediaPlayer(23564): start() in
06-25 18:19:31.250: D/MediaPlayer(23564): start() out
06-25 18:19:31.310: I/MediaPlayer(23564): Info (1,902)
06-25 18:19:31.310: D/MainAudioService(23564): On Info in MP: 1and 902
06-25 18:19:50.909: D/MediaPlayer(23564): stop() in
06-25 18:19:50.919: D/MediaPlayer(23564): stop() out
06-25 18:19:50.919: D/MediaPlayer(23564): reset() in
06-25 18:19:50.929: D/MediaPlayer(23564): reset() out
06-25 18:19:50.939: D/MainAudioService(23564): next song is: http://soundcloud.com/stopdroprave/subvibe-mizukis-last-chance/download/s-Jaezp
06-25 18:19:55.433: W/MediaPlayer(23564): info/warning (1, 902)
06-25 18:19:58.656: D/dalvikvm(23564): GC_EXTERNAL_ALLOC freed 503K, 57% free 3099K/7047K, external 1102K/1614K, paused 45ms
06-25 18:20:00.338: D/MainAudioService(23564): Song length in minutes is: -6:39
06-25 18:20:00.338: D/MediaPlayer(23564): start() in
06-25 18:20:00.338: D/MediaPlayer(23564): start() out
06-25 18:20:00.408: I/MediaPlayer(23564): Info (1,902)

从 SGSII 登录:

06-25 18:27:32.797: E/MediaPlayer(24277): stop called in state 0
06-25 18:27:32.797: E/MediaPlayer(24277): error (-38, 0)
06-25 18:27:32.807: D/MainAudioService(24277): next song is: http://soundcloud.com/stopdroprave/doctor-p-watch-out-crazes-locd/download/s-qQhJP
06-25 18:27:32.807: E/MediaPlayer-JNI(24277): setDataSource: outside path in JNI is �x@
06-25 18:27:33.498: E/MediaPlayer(24277): error (1, -2147483648)
06-25 18:27:33.498: E/MediaPlayer(24277): Error (1,-2147483648)
06-25 18:27:33.498: D/MainAudioService(24277): Error in MP: 1 and -2147483648
06-25 18:27:33.498: E/MediaPlayer(24277): stop called in state 0
06-25 18:27:33.498: E/MediaPlayer(24277): error (-38, 0)
06-25 18:27:33.508: D/MainAudioService(24277): next song is: http://soundcloud.com/stopdroprave/digitalism-circle-eric-prydz/download/s-XlYFv
06-25 18:27:33.508: E/MediaPlayer-JNI(24277): setDataSource: outside path in JNI is �x@
06-25 18:27:34.149: E/MediaPlayer(24277): error (1, -2147483648)
06-25 18:27:34.149: E/MediaPlayer(24277): Error (1,-2147483648)
06-25 18:27:34.149: D/MainAudioService(24277): Error in MP: 1 and -2147483648

编辑:

这是我设置数据源的地方......

SdrPlaylist p = mPlaylist.get(currentNum);

            String path = p.songUrl;

            artistInfo = p.songName;
            nextSong = Toast.makeText(getApplicationContext(),
                    "Buffering Next Song...", Toast.LENGTH_LONG);
            nextSong.setGravity(Gravity.TOP, 0, 110);
            nextSong.show();

            try {
                Log.d(TAG, "next song is: " + path);

                mediaPlayer.setDataSource(path);

                mediaPlayer.prepareAsync();
            } catch (IllegalArgumentException e) {
                e.printStackTrace();
            } catch (IllegalStateException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }

最佳答案

docs for MediaPlayer状态:

For streams, you should call prepareAsync(), which returns immediately, rather than blocking until enough data has been buffered.

所以我会从尝试开始。您需要使用 OnPreparedListener 为您调用 start(),而不是假设准备在返回后完成。

private MediaPlayer mp = new MediaPlayer();
mp.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
    @Override
    public void onPrepared(MediaPlayer arg0) {
        mp.start();

    }
});

mp.reset(); //<--- you probably shouldn't need this here.
mp.setDataSource(soundUri);
mp.prepareAsync();

这样就可以保证在 MediaPlayer 准备好之前不会调用 start()。

如果您在进行此更改后仍然遇到问题,我的下一个猜测是它与编解码器相关。 Android 上的媒体播放有点挑剔,对于流媒体来说更是如此。您想播放什么类型的文件?

关于Android-测试设备的 Mediaplayer 流媒体问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11198992/

相关文章:

python - Hadoop 流 : Mapper 'wrapping' a binary executable

带有未安装在数据节点上的导入包的 Python Hadoop 流式传输

Android MediaPlayer 文件的完整路径

android - 更改 MediaPlayer URI

android - 在 firemonkey 中播放声音

android - 如何在Android上的SQLite数据库中实现 "Inheritance"关系

java - Android:如何使用 Intent 发送超过 1 个变量?

android - Android 上类似 teamviewer 的应用程序技术

android - Android Webview客户端证书和Http授权

android - 当已知的 SSIS wifi 网络进入/超出范围时,有什么方法可以得到通知吗?