emulated content android stream media-player radio

android - emulated - filenotfoundexception>: no content provider



Android Media Stream Error? java.io.FileNotFoundException: no hay proveedor de contenido: http:// (4)

Seguí this para Play Stream Radio en Android

Aquí está funcionando bien, pero el reproductor carga poco después de hacer clic. Necesito esperar más de 30 segundos.

Pero estoy recibiendo este error en la consola

MediaPlayer: setDataSource IOException happend : java.io.FileNotFoundException: No content provider: http://www.example.com:8000/live.ogg at android.content.ContentResolver.openTypedAssetFileDescriptor(ContentResolver.java:1074) at android.content.ContentResolver.openAssetFileDescriptor(ContentResolver.java:927) at android.content.ContentResolver.openAssetFileDescriptor(ContentResolver.java:854) at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1087) at android.media.MediaPlayer.setDataSource(MediaPlayer.java:1061) at org.oucho.radio.Player.playLaunch(Player.java:237) at org.oucho.radio.Playlist.onPostExecute(Playlist.java:98) at org.oucho.radio.Playlist.onPostExecute(Playlist.java:35) at android.os.AsyncTask.finish(AsyncTask.java:632) at android.os.AsyncTask.access$600(AsyncTask.java:177) at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:145) at android.app.ActivityThread.main(ActivityThread.java:5951) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1400) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1195)

En el enlace puedes ver todos los archivos como el player etc.

Debido a este error mi flujo es lento. Por favor alguien me ayude en este tipo.

Aquí este error no es con el archivo .ogg que probé con .mp3 y Just /live

http://www.example.com:8000/beet.ogg http://www.example.com:8000/mouthorgan.mp3 http://www.example.com:8000/live

El audio se está reproduciendo, pero después de este error se está demorando unos 30 segundos. Algunas veces se está demorando ... Cuando reproduzco, muestra este error y luego se conecta al servidor ... y se reproduce

por favor ayúdame a arreglar esto


java.io.FileNotFoundException: no hay proveedor de contenido: http://www.example.com:8000/live.ogg

Debido a que se está cargando como un archivo desde el dispositivo, el proveedor de contenido se basa en el contexto y se pasa como una URL.

Parece que su problema está en la configuración de la fuente de datos para el reproductor multimedia. Mientras intenta reproducir la url o la transmisión, lo que se requiere para el método setDataSource sin contexto.

Estaba enfrentando el mismo problema mientras jugaba en vivo. y debajo del código resolví mi problema.

PlayerScreen

public class PlayerScreen extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.player); startService(new Intent(this, MediaPlayerService.class)); findViewById(R.id.btnChangeTrack).setOnClickListener(clickListener); findViewById(R.id.btnStartMediaPlayer).setOnClickListener(clickListener); findViewById(R.id.btnStopMediaPlayer).setOnClickListener(clickListener); ToggleButton toggleButton = (ToggleButton) findViewById(R.id.togglePauseResume); toggleButton.setOnCheckedChangeListener(checkedChangeListener); /* * To get url which is passing from the previous activity listitem click. * If url which is pass from listitem click is not empty it will start player * */ String url = getIntent().getStringExtra("url"); if (!TextUtils.isEmpty(url)) startMediaPlayer(url); } private ToggleButton.OnCheckedChangeListener checkedChangeListener = new ToggleButton.OnCheckedChangeListener() { @Override public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) { if (!isChecked) { Intent intent = new Intent(); intent.setAction(MediaPlayerService.BROADCAST_TO_SERVICE); intent.putExtra(MediaPlayerService.PLAYER_FUNCTION_TYPE, MediaPlayerService.PAUSE_MEDIA_PLAYER); sendBroadcast(intent); } else { Intent intent = new Intent(); intent.setAction(MediaPlayerService.BROADCAST_TO_SERVICE); intent.putExtra(MediaPlayerService.PLAYER_FUNCTION_TYPE, MediaPlayerService.RESUME_MEDIA_PLAYER); sendBroadcast(intent); } } }; private View.OnClickListener clickListener = new View.OnClickListener() { @Override public void onClick(View v) { Intent intent; switch (v.getId()) { case R.id.btnChangeTrack: intent = new Intent(); intent.setAction(MediaPlayerService.BROADCAST_TO_SERVICE); intent.putExtra(MediaPlayerService.PLAYER_FUNCTION_TYPE, MediaPlayerService.CHANGE_PLAYER_TRACK); intent.putExtra(MediaPlayerService.PLAYER_TRACK_URL, "http://www.example.com:8000/live"); sendBroadcast(intent); break; case R.id.btnStartMediaPlayer: startMediaPlayer("http://www.example.com:8000/beet.ogg"); //startMediaPlayer("http://108.163.197.114:8071/listen.pls"); break; case R.id.btnStopMediaPlayer: intent = new Intent(); intent.setAction(MediaPlayerService.BROADCAST_TO_SERVICE); intent.putExtra(MediaPlayerService.PLAYER_FUNCTION_TYPE, MediaPlayerService.STOP_MEDIA_PLAYER); sendBroadcast(intent); break; } } }; @Override protected void onResume() { super.onResume(); registerReceiver(receiverFromservice, new IntentFilter(MediaPlayerService.SERVICE_TO_ACTIVITY)); } private String currentPlayerStatus = "N/A"; private BroadcastReceiver receiverFromservice = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { String action = intent.getAction(); if (MediaPlayerService.SERVICE_TO_ACTIVITY.equalsIgnoreCase(action)) { /* * To get current status of player * */ currentPlayerStatus = intent.getStringExtra(MediaPlayerService.PLAYER_STATUS_KEY); Log.e("Player Mode", "" + currentPlayerStatus); } } }; @Override protected void onPause() { super.onPause(); unregisterReceiver(receiverFromservice); } /** * TO start media player.It will send broadcast to Service & from service player will start * * @param url */ public void startMediaPlayer(String url) { Intent intent = new Intent(); intent.setAction(MediaPlayerService.BROADCAST_TO_SERVICE); intent.putExtra(MediaPlayerService.PLAYER_FUNCTION_TYPE, MediaPlayerService.PLAY_MEDIA_PLAYER); intent.putExtra(MediaPlayerService.PLAYER_TRACK_URL, url); sendBroadcast(intent); } }

MediaPlayerService

public class MediaPlayerService extends Service { public static final String BROADCAST_TO_SERVICE = "com.mediaplayer.playerfunction"; public static final String SERVICE_TO_ACTIVITY = "com.mediaplayer.currentPlayerStatus"; public static final String PLAYER_FUNCTION_TYPE = "playerfunction"; public static final String PLAYER_TRACK_URL = "trackURL"; public static final int PLAY_MEDIA_PLAYER = 1; public static final int PAUSE_MEDIA_PLAYER = 2; public static final int RESUME_MEDIA_PLAYER = 3; public static final int STOP_MEDIA_PLAYER = 4; public static final int CHANGE_PLAYER_TRACK = 5; public static final String PLAYER_STATUS_KEY = "PlayerCurrentStatus"; @Nullable @Override public IBinder onBind(Intent intent) { return null; } @Override public int onStartCommand(Intent intent, int flags, int startId) { IntentFilter intentFilter = new IntentFilter(BROADCAST_TO_SERVICE); registerReceiver(playerReceiver, intentFilter); if (mPlayer != null && mPlayer.isPlaying()) { sendPlayerStatus("playing"); } return START_STICKY; } private BroadcastReceiver playerReceiver = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { String action = intent.getAction(); if (BROADCAST_TO_SERVICE.equalsIgnoreCase(action)) { String trackURL = intent.hasExtra(PLAYER_TRACK_URL) ? intent.getStringExtra(PLAYER_TRACK_URL) : ""; int function = intent.getIntExtra(PLAYER_FUNCTION_TYPE, 0); switch (function) { case CHANGE_PLAYER_TRACK: changeTrack(trackURL); break; case STOP_MEDIA_PLAYER: stopPlayer(); break; case PLAY_MEDIA_PLAYER: startMediaPlayer(trackURL); break; case PAUSE_MEDIA_PLAYER: pausePlayer(); break; case RESUME_MEDIA_PLAYER: resumePlayer(); break; } } } }; private MediaPlayer mPlayer; private void pausePlayer() { if (mPlayer != null && mPlayer.isPlaying()) { mPlayer.pause(); sendPlayerStatus("pause"); } } private void resumePlayer() { if (mPlayer != null && !mPlayer.isPlaying()) { mPlayer.start(); sendPlayerStatus("playing"); } } private void changeTrack(String url) { stopPlayer(); startMediaPlayer(url); } private void stopPlayer() { if (mPlayer != null) { mPlayer.stop(); mPlayer.release(); mPlayer = null; sendPlayerStatus("stopped"); } } public void startMediaPlayer(String url) { if (TextUtils.isEmpty(url)) return; if (mPlayer == null) mPlayer = new MediaPlayer(); try { mPlayer.setDataSource(url); mPlayer.setOnErrorListener(new MediaPlayer.OnErrorListener() { @Override public boolean onError(MediaPlayer mp, int what, int extra) { if (extra == MediaPlayer.MEDIA_ERROR_SERVER_DIED || extra == MediaPlayer.MEDIA_ERROR_MALFORMED) { sendPlayerStatus("erroronplaying"); } else if (extra == MediaPlayer.MEDIA_ERROR_IO) { sendPlayerStatus("erroronplaying"); return false; } return false; } }); mPlayer.setOnBufferingUpdateListener(new MediaPlayer.OnBufferingUpdateListener() { public void onBufferingUpdate(MediaPlayer mp, int percent) { Log.e("onBufferingUpdate", "" + percent); } }); mPlayer.prepareAsync(); mPlayer.setOnPreparedListener(new MediaPlayer.OnPreparedListener() { public void onPrepared(MediaPlayer mp) { mPlayer.start(); sendPlayerStatus("playing"); } }); mPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() { @Override public void onCompletion(MediaPlayer mp) { Log.e("onCompletion", "Yes"); sendPlayerStatus("completed"); } }); mPlayer.setOnInfoListener(new MediaPlayer.OnInfoListener() { @Override public boolean onInfo(MediaPlayer mp, int what, int extra) { return false; } }); } catch (IllegalArgumentException e) { e.printStackTrace(); } catch (IllegalStateException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } private void sendPlayerStatus(String status) { Intent intent = new Intent(); intent.setAction(SERVICE_TO_ACTIVITY); intent.putExtra(PLAYER_STATUS_KEY, status); sendBroadcast(intent); } }

player.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/section_label" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/ab_tool" android:text="Home" /> <Button android:id="@+id/btnStartMediaPlayer" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/section_label" android:text="Start Player" /> <ToggleButton android:id="@+id/togglePauseResume" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/btnStartMediaPlayer" android:checked="true" android:textOff="Resume" android:textOn="Pause" /> <Button android:id="@+id/btnChangeTrack" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/togglePauseResume" android:text="Chanage Track" /> <Button android:id="@+id/btnStopMediaPlayer" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/btnChangeTrack" android:text="STOP" /> </RelativeLayout>

Manifiesto

<activity android:name=".PlayerScreen"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <service android:name=".MediaPlayerService"></service>

Para obtener datos de los datos de encabezado de url de transmisión, puede [verificar esta respuesta] [2]

Para propósitos de prueba aquí he usado dos urls

ACTUALIZAR PlayerActivity

public class PlayerScreen extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.player); startService(new Intent(this, MediaPlayerService.class)); /* * To get url which is passing from the previous activity listitem click. * If url which is pass from listitem click is not empty it will start player * */ String url = getIntent().getStringExtra("url"); if (!TextUtils.isEmpty(url)) startMediaPlayer(url); } @Override protected void onResume() { super.onResume(); registerReceiver(receiverFromservice, new IntentFilter(MediaPlayerService.SERVICE_TO_ACTIVITY)); } private String currentPlayerStatus = "N/A"; private BroadcastReceiver receiverFromservice = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { String action = intent.getAction(); if (MediaPlayerService.SERVICE_TO_ACTIVITY.equalsIgnoreCase(action)) { /* * To get current status of player * */ currentPlayerStatus = intent.getStringExtra(MediaPlayerService.PLAYER_STATUS_KEY); Log.e("Player Mode", "" + currentPlayerStatus); } } }; @Override protected void onPause() { super.onPause(); unregisterReceiver(receiverFromservice); } /** * TO start media player.It will send broadcast to Service & from service player will start * * @param url */ public void startMediaPlayer(String url) { Intent intent = new Intent(); intent.setAction(MediaPlayerService.BROADCAST_TO_SERVICE); intent.putExtra(MediaPlayerService.PLAYER_FUNCTION_TYPE, MediaPlayerService.PLAY_MEDIA_PLAYER); intent.putExtra(MediaPlayerService.PLAYER_TRACK_URL, url); sendBroadcast(intent); } }

Déjame saber si algo



Este error también ocurre si este permiso de Internet no está en el Manifest.xml

<uses-permission android:name="android.permission.INTERNET" />


Vaya a este archivo https://github.com/Old-Geek/Radio/blob/master/app/src/main/java/org/oucho/radio/Player.java#L234 y cambie

player.setDataSource(context, Uri.parse(url));

a

player.setDataSource(url)

El problema es que void setDataSource (String path) establece el origen de datos (ruta de archivo o URL de http / rtsp) que se va a usar.

cadena de ruta: la ruta del archivo o la URL http / rtsp de la secuencia que desea reproducir

el código github usa void setDataSource (Context context, Uri uri) que asume que uri es de alguna forma de ContentProvider

contexto Contexto: el contexto a usar al resolver el Uri
uri Uri: la URI de contenido de los datos que desea reproducir