在videoView中播放YouTube视频

时间:2012-12-01 00:33:46

标签: android youtube android-videoview

我正在尝试在videoView中播放YouTube视频。

我在这里找到了一个完成这项工作的示例: http://code.google.com/p/android-youtube-player/

对于某些视频ID,它运行正常,对于其他一些视频我正在进行对话:

通信错误:在检索视频期间出现错误。这可能是由于网络问题或Youtube协议造成的。请稍后再试。

我会一次又一次地尝试这些视频ID,但它不起作用。

这是我在logcat中得到的异常:

12-01 01:24:20.871: E/QueryYouTubeTask(21326): Error occurred while retrieving information from YouTube.
12-01 01:24:20.871: E/QueryYouTubeTask(21326): java.lang.NullPointerException
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at libcore.net.UriCodec.decode(UriCodec.java:153)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at java.net.URLDecoder.decode(URLDecoder.java:45)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at com.keyes.youtube.YouTubeUtility.calculateYouTubeUrl(YouTubeUtility.java:137)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at com.keyes.youtube.OpenYouTubePlayerActivity$QueryYouTubeTask.doInBackground(OpenYouTubePlayerActivity.java:385)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at com.keyes.youtube.OpenYouTubePlayerActivity$QueryYouTubeTask.doInBackground(OpenYouTubePlayerActivity.java:1)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at android.os.AsyncTask$2.call(AsyncTask.java:287)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at java.util.concurrent.FutureTask.run(FutureTask.java:137)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569)
12-01 01:24:20.871: E/QueryYouTubeTask(21326):  at java.lang.Thread.run(Thread.java:856)
12-01 01:24:20.902: E/QueryYouTubeTask(21326): Error playing video!
12-01 01:24:20.902: E/QueryYouTubeTask(21326): java.lang.RuntimeException: Invalid NULL Url.
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at com.keyes.youtube.OpenYouTubePlayerActivity$QueryYouTubeTask.onPostExecute(OpenYouTubePlayerActivity.java:418)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at com.keyes.youtube.OpenYouTubePlayerActivity$QueryYouTubeTask.onPostExecute(OpenYouTubePlayerActivity.java:1)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at android.os.AsyncTask.finish(AsyncTask.java:631)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at android.os.AsyncTask.access$600(AsyncTask.java:177)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at android.os.Handler.dispatchMessage(Handler.java:99)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at android.os.Looper.loop(Looper.java:137)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at android.app.ActivityThread.main(ActivityThread.java:4745)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at java.lang.reflect.Method.invokeNative(Native Method)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at java.lang.reflect.Method.invoke(Method.java:511)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
12-01 01:24:20.902: E/QueryYouTubeTask(21326):  at dalvik.system.NativeStart.main(Native Method)

任何人都有想法,这里有什么问题? 你有解释,为什么一些视频工作正常,其他不起作用?可能有视频私人和视频公开吗?

最后我得到了解决方案:有些视频无效,因为视频所有者没有将视频视频移动到手机上:)

2 个答案:

答案 0 :(得分:0)

这不是YouTube正式支持的功能,因此可能会出现此库无法正常处理的情况,在谷歌I / O 2012期间谷歌表示他们将“很快”发布官方YouTube库,这将使Android开发人员从他们的应用程序内播放视频。

答案 1 :(得分:0)

最后我得到了解决方案:有些视频无效,因为视频所有者没有将视频视频移动到手机上:)