首先使用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