открыть http соединение для потокового аудио - PullRequest
0 голосов
/ 26 мая 2011

Я пытаюсь создать приложение для воспроизведения живого радио. Я использую следующий метод для открытия http-соединения и выдаю этот URL-адрес "http://64.62.xxx.xxxx:xxx/" Но я получаю исключение nullpointer,

                public InputStream OpenHttpConnection(String urlString) throws IOException
{
    InputStream in = null;
    int response = -1;

    URL url = new URL(urlString); 
    URLConnection conn = url.openConnection();


    if (!(conn instanceof HttpURLConnection))                     
        throw new IOException("Error connecting");

    try{
        HttpURLConnection httpConn = (HttpURLConnection) conn;
        httpConn.setAllowUserInteraction(false);
        conn.setDoInput(true);
        httpConn.setInstanceFollowRedirects(true);
        httpConn.setRequestMethod("GET");
        httpConn.connect(); 
        response = httpConn.getResponseCode();
        System.out.println("Response : "+response);
        if (response == HttpURLConnection.HTTP_OK) 
        {
            in = httpConn.getInputStream();
        }     
    }
    catch (Exception ex)
    {
        throw new IOException("Error connecting");            
    }
    return in;     
}

Есть ли другой способ для потоковой передачи данных с такого рода URL или мне нужно добавить что-нибудь еще в вышеупомянутом методе ??

Я создал экземпляр MediaPlayer. Мой logcat отображает следующую ошибку:

05-25 15: 50: 08.067: DEBUG / MediaPlayer (1032): не удалось открыть файл на стороне клиента, пытается на стороне сервера 05-25 15: 50: 08.189: WARN / MediaPlayer (1032):информация / предупреждение (1, 26) 05-25 15: 50: 08.217: ОШИБКА / PlayerDriver (31): команда PLAYER_INIT завершена с ошибкой или информация PVMFFailure 05-25 15: 50: 08.217: ОШИБКА / MediaPlayer (1032): ошибка(1, -1) 05-25 15: 50: 08.237: WARN / PlayerDriver (31): PVMFInfoErrorHandlingComplete 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): ошибка создания: 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): java.io.IOException: подготовка не удалась .: status = 0x1 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.media.MediaPlayer.prepare (собственный метод) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.media.MediaPlayer.create (MediaPlayer.java:608) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.media.MediaPlayer.create (MediaPlayer.java:585) 05-25 15: 50: 08.357: ОТЛАДКА/ MediaPlayer (1032): at org.sample.AudioPlayer.AudioPlayer.PlayRadio (AudioPlayer.java:190) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): at org.sample.AudioPlayer.AudioPlayer.access $ 1(AudioPlayer.java:123) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на org.sample.AudioPlayer.AudioPlayer $ 3.onClick (AudioPlayer.java:77) 05-25 15: 50: 08.357:DEBUG / MediaPlayer (1032): на android.view.View.performClick (View.java:2364) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.view.View.onTouchEvent (View.java: 4179) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): at android.widget.TextView.onTouchEvent (TextView.java:6541) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032):на android.view.View.dispatchTouchEvent (View.java:3709) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:884) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:884) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.view.ViewGroup.dispatchTouchEvent (ViewGroup.Java: 884) 05-25: 15: 50: 08.357: DEBUG / MediaPlayer (1032): at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:884) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на com.android.internal.policy.impl.PhoneWindow $ DecorView.superDispatchTouchEvent (PhoneWindow.java:1659) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent (PhoneWindow.java:1107) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): в android.app.Activity.dispatchTouchEvent (Activity.java:2061) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на com.android.internal.policy.impl.PhoneWindow $ DecorView.dispatchTouchEvent(PhoneWindow.java:1643) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.view.ViewRoot.handleMessage (ViewRoot.java:1691) 05-25 15: 50: 08.357: DEBUG / MediaPlayer(1032): на android.os.Handler.dispatchMessage (Handler.java:99) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.os.Looper.loop (Looper.java:123)05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на android.app.ActivityThread.main (ActivityThread.java:4363) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на java.lang.reflect.Method.invokeNative (собственный метод) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): в java.lang.reflect.Method.invoke (Method.java:521) 05-25 15:50: 08.357: DEBUG / MediaPlayer (1032): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:860) 05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): на ком.android.internal.os.ZygoteInit.main (ZygoteInit.java:618)05-25 15: 50: 08.357: DEBUG / MediaPlayer (1032): в dalvik.system.NativeStart.main (собственный метод) 05-25 15: 51: 05.277: DEBUG / dalvikvm (97): сборщик мусора освободил 14 объектов / 560 байт за 127 мс 05-25 15: 51: 13.280: DEBUG / AndroidRuntime (1032): выключение виртуальной машины 05-25 15: 51: 13.280: WARN / dalvikvm (1032): threadid = 3: поток завершается с необработанным исключением (группа = 0x4001b188) 05-25 15: 51: 13.280: ОШИБКА / AndroidRuntime (1032): необработанный обработчик: выход из основного потока из-за необработанного исключения

Спасибо !!

1 Ответ

0 голосов
/ 26 мая 2011

Прежде всего, проверьте соединение с сервера. Вы можете использовать отладчик HTTP. Как ты хочешь играть аудио Создайте экземпляр медиаплеера и установите дескриптор файла в SetDataSource

m_player.setOnPreparedListener(this);
m_player.setAudioStreamType(AudioManager.STREAM_MUSIC);
m_player.setDataSource(filedescriptor fd);
m_player.prepareAsync();
...