Android:音频流中的prepareAsync()延迟

3

我正在尝试从以下URL播放音频:http://mtl2.liveatc.net/lbbg 以下是我的代码:

public void setConnection(String url) {
    String url = http://mtl2.liveatc.net/lbbg;
    mediaPlayer = new MediaPlayer();
    mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
    new Player().execute(url);
}

private class Player extends AsyncTask<String, Void, Void> {
    @Override
    protected Void doInBackground(String... strings) {

        try {
            mediaPlayer.setDataSource(strings[0]);
            mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
                @Override
                public void onCompletion(MediaPlayer mediaPlayer) {
                    mediaPlayer.stop();
                    mediaPlayer.reset();
                }
            });

            mediaPlayer.prepareAsync();

        } catch (Exception e) {
            Log.e("MyAudioStreamingApp", e.getMessage());
        }

        return null;
    }

    @Override
    protected void onPostExecute(Void result) {
        super.onPostExecute(result);
        mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener(){

            @Override
            public void onPrepared(MediaPlayer mp) {
                progressBar.setVisibility(View.INVISIBLE);
                mp.start();
            }
        });

    }

    @Override
    protected void onPreExecute() {
        super.onPreExecute();
        progressBar.setVisibility(View.VISIBLE);
    }
}

一切都正常,但是有很大的延迟。如果我在浏览器中打开此网址,则需要将近20秒才能开始流式传输,但是当我在我的应用程序中运行它时,则需要长达5-7分钟。

更新:还要添加我的日志:

07-24 01:12:52.820 25918-25961/com.example I/OpenGLRenderer: Initialized EGL, version 1.4
07-24 01:12:52.843 25918-25961/com.example E/HAL: hw_get_module_by_class: module name gralloc
07-24 01:12:52.843 25918-25961/com.example E/HAL: hw_get_module_by_class: module name gralloc
07-24 01:12:59.171 25918-25918/com.example E/ExtMediaPlayer-JNI: env->IsInstanceOf fails
07-24 01:12:59.171 25918-25918/com.example E/MediaPlayer-JNI: JNIMediaPlayerFactory: bIsQCMediaPlayerPresent 0
07-24 01:12:59.171 25918-25918/com.example E/ExtMediaPlayer-JNI: env->IsInstanceOf fails
07-24 01:12:59.171 25918-25918/com.example E/MediaPlayer-JNI: JNIMediaPlayerFactory: bIsQCMediaPlayerPresent 0
07-24 01:12:59.188 25918-25931/com.example D/MediaHTTPConnection: filterOutInternalHeaders: key=User-Agent, val= stagefright/1.2 (Linux;Android 6.0.1)
07-24 01:12:59.191 25918-26002/com.example D/MediaHTTPConnection: proxy null port 0
07-24 01:12:59.192 25918-26002/com.example I/DpmTcmClient: RegisterTcmMonitor from: com.android.okhttp.TcmIdleTimerMonitor
07-24 01:15:42.557 25918-25925/com.example W/art: Suspending all threads took: 31.418ms
07-24 01:17:48.107 25918-25918/com.example D/MediaPlayer: setSubtitleAnchor in MediaPlayer
UPD2: 我的“解决方案”:我找不到这个问题的解决方案,所以我决定使用下一个方法:我在需要播放按钮的地方放置了一个小的 WebView,并获得了完整的音频播放器,它可以在10-15秒内加载并播放此流。
2个回答

1

检查您的线程优先级。

Thread.currentThread().getPriority();

根据我的经验,一些老旧的设备(例如LG..)在使用AsyncTask等工作线程准备或启动mediaPlayer时会出现问题。在这种情况下,需要将优先级设置得更高或使用主线程。在我的案例中,我将prepareAsync移到了主线程。

更新

我测试了代码并发现优先级不是问题。我认为Android mediaPlayer不是“那个”URL的好选择。我过去在流媒体项目中选择ffmpeg或google/exoplayer。

响应头

HTTP/1.1 200 OK
Server: nginx/1.12.1
Content-Type: audio/mpeg
Connection: close
icy-br: 16
ice-audio-info: ice-samplerate=11025;ice-bitrate=16;ice-channels=1
icy-br: 16
icy-description: LBBG Burgas, Bulgaria
icy-genre: ATC
icy-name: Burgas Tower, Approach
icy-private: 0
icy-pub: 1
icy-url: http://www.liveatc.net
...

媒体信息

Input #0, mp3, from 'http://mtl2.liveatc.net/lbbg':
Duration: N/A, start: 0.000000, bitrate: 16 kb/s
Stream #0.0: Audio: mp3, 11025 Hz, mono, s16, 16 kb/s

我正在使用ExoPlayer在Kotlin项目中从Shoutcast流式传输广播音乐,效果非常好。当我使用MediaPlayer时也遇到了同样的延迟问题。 - Jose Ricardo Citerio Alcala

0

不使用任务,你可以简单地完成它:

MediaPlayer mediaPlayer = new MediaPlayer();

mediaPlayer.setOnErrorListener(new MediaPlayer.OnErrorListener() {
    public boolean onError(MediaPlayer mp, int what, int extra) {
        mp.reset();
        return false;
    }
});

mediaPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() {
    public void onPrepared(MediaPlayer mp) {
        mp.start();
    }
});

try {
    mediaPlayer.setDataSource("http://yoururl");
    mediaPlayer.prepareAsync();
} catch (IllegalArgumentException e) {
} catch (IllegalStateException e) {
} catch (IOException e) {
}

尝试这个简单的方法,检查延迟是否仍然存在。


谢谢,但不幸的是结果还是一样。 - JohnA
refer:https://developer.android.com/reference/android/media/AudioTrack.html - Ranjith KP

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接