tom*_*Dev 3 android audio-streaming android-mediaplayer android-studio
我正在开发一个广播流应用程序,几分钟后音频总是在后台停止。
显现:
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.WAKE_LOCK"/>
Run Code Online (Sandbox Code Playgroud)
服务等级:
public class StreamService extends Service implements MediaPlayer.OnPreparedListener, MediaPlayer.OnErrorListener, MediaPlayer.OnInfoListener {
private static final String STREAM_URL = "http://bbcwssc.ic.llnwd.net/stream/bbcwssc_mp1_ws-einws";
MediaPlayer mediaPlayer = null;
private WifiManager.WifiLock mWifiLock;
public int onStartCommand(Intent intent, int flags, int startId) {
mediaPlayer = new MediaPlayer();
mediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
try {
mediaPlayer.setDataSource(STREAM_URL);
} catch (IOException e) {
e.printStackTrace();
}
mediaPlayer.setWakeMode(getApplicationContext(), PowerManager.PARTIAL_WAKE_LOCK);
mediaPlayer.setOnErrorListener(this);
mediaPlayer.setOnBufferingUpdateListener(this);
mediaPlayer.setOnInfoListener(this);
mediaPlayer.setOnPreparedListener(this);
mediaPlayer.setLooping(true);
if (mWifiLock == null) {
mWifiLock = ((WifiManager) Objects.requireNonNull(getApplicationContext().getSystemService(Context.WIFI_SERVICE)))
.createWifiLock(WifiManager.WIFI_MODE_FULL, "mediaplayerlock");
}
mediaPlayer.setWakeMode(getApplicationContext(), PowerManager.PARTIAL_WAKE_LOCK);
mediaPlayer.prepareAsync();
return START_STICKY;
}
public void onPrepared(MediaPlayer player) {
Log.e(TAG, "Service onPrepared");
mediaPlayer.start();
}
Run Code Online (Sandbox Code Playgroud)
在 MainActivity 上我启动流:
Intent i = new Intent(this, StreamService.class);
i.setAction("play");
startService(i);
Run Code Online (Sandbox Code Playgroud)
设备锁定几分钟后,会出现此错误并停止播放:
W/MediaPlayerNative: info/warning (703, 0)
W/MediaPlayerNative: info/warning (701, 0)
Run Code Online (Sandbox Code Playgroud)
703 和 701 与缓冲和播放音频有关,但它每次都会永久停止一切,即使 Wi-Fi 连接良好。如果您保持应用程序打开,则一切都会永久有效,但如果您在几分钟内关闭应用程序,则会出现此错误。然后您必须重新打开应用程序,停止并重新启动流。
有一个关于流的警告,但代码上的所有内容似乎都是正确的:
W/MediaPlayer: Use of stream types is deprecated for operations other than volume control
W/MediaPlayer: See the documentation of setAudioStreamType() for what to use instead with android.media.AudioAttributes to qualify your playback use case
Run Code Online (Sandbox Code Playgroud)
我错过了什么吗?有任何想法吗?
谢谢!
编辑:
发现当流启动和收到 703 错误时 onInfo 被调用:
@Override
public boolean onInfo(MediaPlayer mp, int what, int extra) {
Log.e(TAG, "Service onInfo");
return false;
}
Run Code Online (Sandbox Code Playgroud)
当您的应用程序进入后台时,它很快就会停止。要继续播放音频,您必须将该服务作为前台服务启动。
显现:
<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
Run Code Online (Sandbox Code Playgroud)
活动:
startForegroundService(i)
Run Code Online (Sandbox Code Playgroud)
服务:
onCreate() {
super.onCreate()
startForeground(ID, createNotification())
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2618 次 |
| 最近记录: |