首先使用Webview獲取VideoID和VideoData(src),然後將VideoData傳遞給VideoPlayer並播放它。
webView.setWebViewClient(new WebViewClient()
{
@Override
public void onPageFinished(WebView view, String url)
{
//query_string = "" + url;
//showtoast("URL loaded :"+url);
// view.loadUrl("javascript:(function() { document.getElementsByTagName('video')[0].play(); })()");
}
@Override
public void onLoadResource(WebView view, String url)
{
// query_string=""+url;
webView.loadUrl("javascript:function PlayVideo(src,id)" +
"{"
+"FBDownloader.processVideo(src,id);"
+"var video=document.getElementById(id);"
+"video.play();"
+"}" +
"(function prepareVideo() " +
"{ "
+ "var el = document.querySelectorAll('div[data-sigil]');"
+"var ID;"
+"var SRC;"
+ "for(var i=0;i<el.length; i++)"
+ "{"
+ "var sigil = el[i].dataset.sigil;"
+ "if(sigil.indexOf('inlineVideo') > -1)" +
"{"
+ "delete el[i].dataset.sigil;"
+ "console.log(i);"
+ "var jsonData = JSON.parse(el[i].dataset.store);"
+"ID=jsonData['videoID'];"
+"SRC=jsonData['src'];"
// +"document.getElementById(\"'+jsonData['videoID']+'\")[0].play();"
// +"var video = document.getElementById(\"'+jsonData['videoID']+'\");"
// +"video.play();"
// +"FBDownloader.processVideo(ID,SRC);"
+ "el[i].setAttribute('onClick','PlayVideo(\\\"'+jsonData['src']+'\\\",\\\"'+jsonData['videoID']+'\\\");');"//'document.getElementsByTagName('video')[0].play(); ');"
// +"'FBDownloader.processVideo(\"'+jsonData['src']+'\",\"'+jsonData['videoID']+'\");');"
// + "el[i].setAttribute('onClick', 'FBDownloader.processVideo(\"'+jsonData['src']+'\",\"'+jsonData['videoID']+'\");');"
+ "}"
+ "}"
+ "})()");
//*/
}
});
@JavascriptInterface
public void processVideo(final String vidData, final String vidID)
{
this.vidData=vidData;
this.vidID=vidID;
//PLAY VIDEO HERE
videoView.play(vidId);
}
感謝您的回覆。它支持YouTube視頻和Facebook視頻嗎? – Weijia
是的,它太好了。 –
謝謝!我很高興嘗試這個!但我有錯誤emVideoView.setOnPreparedListener(this); OnPreparedListener canot可以應用於mainactivity,我在使用com.devbrackets.android.exomedia.listener.OnPreparedListener之後使用了實現MediaPlayer.OnPreparedListener – Weijia