Android MediaPlayer.setDataSource中的java.lang.IllegalStateException,使用Ringtone类
我有一个用户(三星Galaxy S5,安卓4.4)报告了一次崩溃,我不知道发生了什么。这似乎很重要,但也许有些人遇到了同样的问题,或类似的问题 以下是跟踪:Android MediaPlayer.setDataSource中的java.lang.IllegalStateException,使用Ringtone类,android,android-mediaplayer,illegalstateexception,ringtone,Android,Android Mediaplayer,Illegalstateexception,Ringtone,我有一个用户(三星Galaxy S5,安卓4.4)报告了一次崩溃,我不知道发生了什么。这似乎很重要,但也许有些人遇到了同样的问题,或类似的问题 以下是跟踪: java.lang.RuntimeException: An error occured while executing doInBackground() at android.os.AsyncTask$3.done(AsyncTask.java:300) at java.util.concurrent.FutureTask.finishC
java.lang.RuntimeException: An error occured while executing doInBackground()
at android.os.AsyncTask$3.done(AsyncTask.java:300)
at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:355)
at java.util.concurrent.FutureTask.setException(FutureTask.java:222)
at java.util.concurrent.FutureTask.run(FutureTask.java:242)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
at java.lang.Thread.run(Thread.java:841)
Caused by: java.lang.IllegalStateException
at android.media.MediaPlayer._setDataSource(Native Method)
at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1383)
at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1367)
at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1302)
at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1240)
at android.media.MediaPlayer.setDataSource(MediaPlayer.java:986)
at android.media.MediaPlayer.setDataSource(MediaPlayer.java:951)
at android.media.Ringtone.setUri(Ringtone.java:219)
at android.media.Ringtone.setStreamType(Ringtone.java:89)
at com.aasfet.clocklight.WakeActivity$RingAsyncTask.doInBackground(WakeActivity.java:510)
at com.aasfet.clocklight.WakeActivity$RingAsyncTask.doInBackground(WakeActivity.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:288)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
... 3 more
以下是错误代码中的部分:
private class RingAsyncTask extends AsyncTask<Integer, Integer, Integer> {
@Override
protected Integer doInBackground(Integer... params) {
int previousVolume = audioManager.getStreamVolume(AudioManager.STREAM_ALARM);
int maxVolume = audioManager.getStreamMaxVolume(AudioManager.STREAM_ALARM);
int newVolume = (int)(volume * (float)maxVolume);
if(newVolume < 1){
newVolume = 1;
}
if(progressive){
audioManager.setStreamVolume(AudioManager.STREAM_ALARM, 1, 0);
}else{
audioManager.setStreamVolume(AudioManager.STREAM_ALARM, newVolume, 0);
}
getRingtone().setStreamType(AudioManager.STREAM_ALARM);
getRingtone().play();
...
因此,setURI创建一个新的MediaPlayer,然后在MediaPlayer上调用setDataSource。android文档告诉我们,使用new MediaPlayer()将其设置为“空闲”状态,“空闲”状态是调用setDataSource的正确状态。
我真的不明白,我怎么会犯这个错误,显然是千载难逢的。我无法联系有错误的用户,也从未在我这端复制过,所以我发现自己被阻止了。
我正在考虑捕获代码中的错误,当它发生时,请使用我的Ringtone.setStreamType重试,假设它是由于系统的瞬态“状态”而发生的,该状态可能在几毫秒后发生了更改。简言之,我非常绝望:)
任何帮助或类似经验都将不胜感激:)在我的情况下,我必须在
MediaPlayer
实例上调用reset()
,然后才能为其提供不同的url
就目前而言,setDataSource仅在空闲状态下有效
您也可以访问,使用图表进行了很好的解释 在我的例子中,我必须在
MediaPlayer
实例上调用reset()
,然后才能为它提供不同的url
就目前而言,setDataSource仅在空闲状态下有效
您也可以访问,使用图表进行了很好的解释 错误来自您这边,mediaplayer没有获得正确格式的源。您是否支持代码中的所有格式。destroyLocalPlayer();?上面的评论可能是正确的,请根据您的操作系统版本检查支持的格式。试着调试你的URL,硬编码一个,并尝试使用它谢谢你Thealprashant和Hunkeone,我会朝这个方向尝试,但我认为数据源格式的问题导致非法状态异常错误,而不是,IOException.mediaplayer无法获取正确格式的源代码,这是您这边的错误。您是否支持代码中的所有格式。destroyLocalPlayer();?上面的评论可能是正确的,请根据您的操作系统版本检查支持的格式。试着调试你的URL,硬编码一个,并尝试使用它谢谢你Thealprashant和Hunkeone,我会朝这个方向尝试,但数据源格式的问题导致一个非法状态异常错误,而不是,比如说,IOException,这似乎不合逻辑。
public void setUri(Uri uri) {
168 destroyLocalPlayer();
169
170 mUri = uri;
171 if (mUri == null) {
172 return;
173 }
174
175 // TODO: detect READ_EXTERNAL and specific content provider case, instead of relying on throwing
176
177 // try opening uri locally before delegating to remote player
178 mLocalPlayer = new MediaPlayer();
179 try {
180 mLocalPlayer.setDataSource(mContext, mUri);
181 mLocalPlayer.setAudioStreamType(mStreamType);
182 mLocalPlayer.prepare();
...