我有一个用户(Samsung Galaxy S5,Android 4.4)报告的崩溃,我不明白发生了什么。这似乎是可以吸收的,但也许有些人遇到了同样的问题,或类似的问题。MediaPlayer.setDataSource中的java.lang.IllegalStateException,使用铃声类
这里是跟踪:
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 {
@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();
...
getRingtone()是我的功能之一,并返回一个铃声对象是在活动的onResume中使用RingtoneManager光标获得的,我认为那里没有任何问题。
在Android源代码中,Ringtone.setStreamType调用Ringtone.setURI。这里是setURI:
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();
...
所以,setURI创建一个新的MediaPlayer,然后调用MediaPlayer上的setDataSource。 android doc告诉我们,使用新的MediaPlayer()将其设置为“空闲”状态,而“空闲”状态是调用setDataSource的正确状态。 我真的不明白如何,显然有一次在一千,我得到这个错误。我无法联系有错误的用户,从未在我的终端上复制它,所以我发现自己被阻止。 我正在考虑在我的代码中捕获错误,当它发生时,请使用我的Ringtone.setStreamType再次尝试,因为系统的瞬态“状态”可能会在几毫秒后改变。总之我很绝望:)
任何帮助或相似的经历,将不胜感激:)
2014-10-17
jtag
+1
错误来自您身边的媒体播放器无法获得正确格式的来源。你是否支持你的代码中的所有格式。 –
2014-10-17 08:52:22
+0
什么是destroyLocalPlayer();? 以上评论可能是正确的,检查支持的格式,由于您的操作系统版本.http://developer.android.com/guide/appendix/media-formats.html 也尝试调试您的URL,硬编码和尝试与它 –
2014-10-17 09:23:04
+0
谢谢therealprashant和Hunkeone,我会试着朝这个方向努力,但对于我来说,数据源格式的问题导致出现IllegalStateException错误而不是IOException等并不合逻辑。 –
2014-10-17 11:23:52