安卓UDP视频流传输

6
我有一个安卓项目,需要构建客户端应用程序来接收UDP或RTP单播视频流并播放它们。不幸的是,我似乎无法使其正常工作,并且已经广泛搜索了解决方案! 我一直在Xoom(Android 3.2)和Nexus S(Android 2.3.6)上进行测试,并且知道当使用MX Player(第三方媒体播放器应用程序)作为客户端时,它们可以播放内容,但我无法让本机媒体播放器回放内容。我尝试使用简单的VideoView和MediaPlayer,但两者都失败并显示相同的错误代码,我无法找到任何有用的信息。 视频采用H.264编码与AAC音频。此外,服务器是由第三方提供的解决方案,我无权访问(除了指定UDP或RTP),但如我所说,当使用MX Player时,可以播放流。以下是我的代码中的媒体播放器部分:
public class Main extends Activity {

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    try {
        MediaPlayer player = new MediaPlayer();
        SurfaceView surface = (SurfaceView) findViewById(R.id.video);

        player.setDisplay(surface.getHolder());

        player.setDataSource(this, Uri.parse("udp://192.168.0.78:1234"));

        player.prepare();

        player.setOnPreparedListener(new OnPreparedListener() {

            @Override
            public void onPrepared(MediaPlayer mp) {
                Log.d("SimpleVideoPlayer", "Starting player");
                mp.start();
            }
        });

        player.setOnErrorListener(new OnErrorListener() {

            @Override
            public boolean onError(MediaPlayer mp, int what, int extra) {
                Log.d("SimpleVideoPlayer", "error with code: " + what);
                return false;
            }
        });

    }catch(Exception e) {
        e.printStackTrace();
    }
}

我收到的错误是:
11-29 15:44:14.660: D/MediaPlayer(15451): Couldn't open file on client side, trying server side
11-29 15:44:14.670: E/MediaPlayer(15451): error (1, -2147483648)
11-29 15:44:14.670: W/System.err(15451): java.io.IOException: Prepare failed.: status=0x1
11-29 15:44:14.670: W/System.err(15451):    at android.media.MediaPlayer.prepare(Native Method)
11-29 15:44:14.670: W/System.err(15451):    at com.android.vidplayer.Main.onCreate(Main.java:26)
11-29 15:44:14.670: W/System.err(15451):    at android.app.Activity.performCreate(Activity.java:4397)
11-29 15:44:14.670: W/System.err(15451):    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1048)
11-29 15:44:14.670: W/System.err(15451):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1804)
11-29 15:44:14.670: W/System.err(15451):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1856)
11-29 15:44:14.670: W/System.err(15451):    at android.app.ActivityThread.access$500(ActivityThread.java:125)
11-29 15:44:14.670: W/System.err(15451):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1049)
11-29 15:44:14.670: W/System.err(15451):    at android.os.Handler.dispatchMessage(Handler.java:99)
11-29 15:44:14.670: W/System.err(15451):    at android.os.Looper.loop(Looper.java:132)
11-29 15:44:14.670: W/System.err(15451):    at android.app.ActivityThread.main(ActivityThread.java:4157)
11-29 15:44:14.670: W/System.err(15451):    at java.lang.reflect.Method.invokeNative(Native Method)
11-29 15:44:14.670: W/System.err(15451):    at java.lang.reflect.Method.invoke(Method.java:491)
11-29 15:44:14.670: W/System.err(15451):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
11-29 15:44:14.670: W/System.err(15451):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
11-29 15:44:14.670: W/System.err(15451):    at dalvik.system.NativeStart.main(Native Method)

我已经设置了互联网权限。

请问有人有什么建议吗?我无法在任何地方找到有用的信息。

谢谢。


你尝试过使用player.prepareAsync()而不是player.prepare()吗?播放流时应该使用prepareAsync() - Squonk
2个回答

5

是的,看起来是这样!我看过那个页面,但希望有人能提出自己的解决方案! - theChumpus
1
@theChumpus,Alex,你们用过哪个FFmpeg库吗?你们使用了预编译库吗?你们尝试过流式播放H264视频吗? - Derzu
@Derzu 我已经在Unix下编译了ffmpeg,就像http://code.google.com/p/dolphin-player/上所做的那样。它可以播放h264。 - Alexander Kulyakhtin

1

我已经删除了之前的帖子,因为我在我的平板电脑(Nexus-7)上测试了Vitamio,并且它表现良好。 - user1767754
请问您能否检查一下 https://stackoverflow.com/questions/45521175/vitamio-unable-to-play-udp-streaming-in-android 这个链接? - Mithun Sarker Shuvro
我得找一下我4年前做的某个项目的POC代码;当然,我没有实际完成这个项目的工作,因为我不拥有它。我不能保证一定能找到,但我会尽力。 - Paul Gregoire

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接