user1007522
user1007522

Reputation: 8118

Mediaplayer streams perfectly from internet but not from localhost

I'm having a mediaplayer that receives an Audio stream. It all works perfectly when I'm using an internet stream. When I switch for testing purposes to my mamp localhost url. It gives me errors.

This is my code:

  private void initMediaPlayer() {
        mPlayer = new MediaPlayer();
        mPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
        startMP3(URL);
    }

    private void startMP3(String URL) {
        if (intialStage) {
            new Player().execute(URL);
        }
    }

    class Player extends AsyncTask<String, Void, Boolean> {

        @Override
        protected Boolean doInBackground(String... params) {
            Boolean prepared;
            try {
                Log.d(TAG, "MP3 URL: " + params[0]);
                mPlayer.setDataSource(params[0]);
                mPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
                    @Override
                    public void onCompletion(MediaPlayer mp) {
                        intialStage = true;
                        mPlayer.stop();
                        mPlayer.reset();
                        songPositionHandler.removeCallbacks(UpdateSongTime);
                    }
                });

                mPlayer.prepare();
                prepared = true;
            } catch (IllegalArgumentException e) {
                prepared = false;
                e.printStackTrace();
            } catch (SecurityException e) {
                prepared = false;
                e.printStackTrace();
            } catch (IllegalStateException e) {
                prepared = false;
                e.printStackTrace();
            } catch (IOException e) {
                prepared = false;
                e.printStackTrace();
            }
            return prepared;
        }

        @Override
        protected void onPostExecute(Boolean result) {
            super.onPostExecute(result);
            Log.d(TAG, "Prepared status:" + " " + result);
            mPlayer.start();
            intialStage = false;
            songPositionHandler = new Handler();
            songPositionHandler.postDelayed(UpdateSongTime, 1000);
        }
    }

    private Runnable UpdateSongTime = new Runnable() {
        public void run() {
            Log.d(TAG, "Current sec in song: " + TimeUnit.MILLISECONDS.toSeconds(mPlayer.getCurrentPosition()));
            songPositionHandler.postDelayed(this, 1000);
        }
    };

This is my URL:

public static final String URL = "http://localhost:8888/test.mp3";

It gives me this exceptions:

09-02 09:17:19.294    1835-1847/com.example.test E/MediaPlayer﹕ error (1, -2147483648)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ java.io.IOException: Prepare failed.: status=0x1
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at android.media.MediaPlayer.prepare(Native Method)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at com.example.test.AudioWaveForm$Player.doInBackground(AudioWaveForm.java:122)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at com.example.test.AudioWaveForm$Player.doInBackground(AudioWaveForm.java:104)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at android.os.AsyncTask$2.call(AsyncTask.java:288)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at java.util.concurrent.FutureTask.run(FutureTask.java:237)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:231)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
09-02 09:17:19.294    1835-1848/com.example.test W/System.err﹕ at java.lang.Thread.run(Thread.java:841)

Can someone give me an explanation why it is working with online urls and not with my mamp?

Upvotes: 1

Views: 396

Answers (1)

user468311
user468311

Reputation:

localhost is your android host. Either refer to this if you're running emulator: How to connect to my http://localhost web server from Android Emulator in Eclipse or specify your pc's ip if you're using android device.

Upvotes: 2

Related Questions