Android 使用Vitamio打造自己的万能播放器(6)——在线播放(播放列表)
前言
新版本的vplayer由设计转入开发阶段,预计开发周期为一个月,这也意味着新版本的vitamio将随之发布,开发者们可以和本系列文章一样,先开发其他功能。本章内容为"在线视频播放列表",集合了主流各大视频网站的手机版,欢迎给"开播视频"反馈改进建议!
系列
1、android 使用vitamio打造自己的万能播放器(1)——准备
2、android 使用vitamio打造自己的android万能播放器(2)—— 手势控制亮度、音量、缩放
3、android 使用vitamio打造自己的android万能播放器(3)——本地播放(主界面、视频列表)
4、android 使用vitamio打造自己的android万能播放器(4)——本地播放(快捷搜索、数据存储)
5、android 使用vitamio打造自己的android万能播放器(5)——在线播放(播放优酷视频)
正文
一、目标
集成各大视频网站的手机版,截图:
二、实现代码
public class fragmentonline extends fragmentbase implements onitemclicklistener { /** 缓存视频列表 */ private static arraylist<string[]> monlinelist = new arraylist<string[]>(); /** 缓存视频logo列表 */ private static arraylist<integer> monlinelogolist = new arraylist<integer>(); private webview mwebview; private listview mlistview; @override public view oncreateview(layoutinflater inflater, viewgroup container, bundle savedinstancestate) { view mview = inflater.inflate(r.layout.fragment_online, container, false); mlistview = (listview) mview.findviewbyid(android.r.id.list); mwebview = (webview) mview.findviewbyid(r.id.webview); mlistview.setonitemclicklistener(this); initwebview(); mlistview.setadapter(new dataadapter(getactivity())); return mview; } @override public void onitemclick(adapterview<?> parent, view view, int position, long id) { final string[] f = monlinelist.get(position); mwebview.clearview(); mwebview.loadurl(f[1]); mwebview.clearhistory(); mlistview.setvisibility(view.gone); mwebview.setvisibility(view.visible); } @override public boolean onbackpressed() { if (mlistview == null || mlistview.getvisibility() == view.visible) return super.onbackpressed(); else { mlistview.setvisibility(view.visible); mwebview.setvisibility(view.gone); return true; } } /** 初始化webview */ private void initwebview() { mwebview.setscrollbarstyle(view.scrollbars_outside_overlay); mwebview.getsettings().setjavascriptenabled(true); mwebview.getsettings().setpluginsenabled(true); mwebview.setwebviewclient(new webviewclient() { @override public void onpagefinished(webview view, string url) { }; /** 页面跳转 */ @override public boolean shouldoverrideurlloading(webview view, string url) { if (fileutils.isvideooraudio(url)) { intent intent = new intent(getactivity(), videoplayeractivity.class); intent.putextra("path", url); startactivity(intent); return true; } return false; }; }); mwebview.setonkeylistener(new onkeylistener() { @override public boolean onkey(view v, int keycode, keyevent event) { if ((keycode == keyevent.keycode_back) && mwebview != null && mwebview.cangoback()) { mwebview.goback(); return true; } return false; } }); } private class dataadapter extends arrayadapter<string[]> { public dataadapter(context ctx) { super(ctx, monlinelist); } @override public view getview(int position, view convertview, viewgroup parent) { final string[] f = getitem(position); if (convertview == null) { final layoutinflater minflater = getactivity() .getlayoutinflater(); convertview = minflater.inflate(r.layout.fragment_online_item, null); } ((imageview) convertview.findviewbyid(r.id.thumbnail)) .setimageresource(monlinelogolist.get(position)); ((textview) convertview.findviewbyid(r.id.title)).settext(f[0]); return convertview; } } static { // 120 60 monlinelist.add(new string[] { "优酷视频", "http://3g.youku.com" }); monlinelogolist.add(r.drawable.logo_youku); // 104 43 monlinelist.add(new string[] { "搜狐视频", "http://m.tv.sohu.com" }); monlinelogolist.add(r.drawable.logo_sohu); // monlinelist.add(new string[] { "乐视tv", "http://m.letv.com" }); monlinelogolist.add(r.drawable.logo_letv); // 174 48 monlinelist.add(new string[] { "爱奇异", "http://3g.iqiyi.com/" }); monlinelogolist.add(r.drawable.logo_iqiyi); monlinelist.add(new string[] { "pptv", "http://m.pptv.com/" }); monlinelogolist.add(r.drawable.logo_pptv); // 181 60 monlinelist.add(new string[] { "腾讯视频", "http://3g.v.qq.com/" }); monlinelogolist.add(r.drawable.logo_qq); monlinelist.add(new string[] { "56.com", "http://m.56.com/" }); monlinelogolist.add(r.drawable.logo_56); monlinelist.add(new string[] { "新浪视频", "http://video.sina.cn/" }); monlinelogolist.add(r.drawable.logo_sina); monlinelist.add(new string[] { "土豆视频", "http://m.tudou.com" }); monlinelogolist.add(r.drawable.logo_tudou); } }
代码说明:
a). 各主流网站的3g版都提供了mp4格式的播放链接,这里集成即可。
b). 处理后退事件,按back键应该先处理webview的网页跳转至上一页。
c). 清空历史记录,切换各视频网站时防止后退到其他网站。
其他代码参考项目源码。
三、其他更新日志
新增:启用了新的logo
修复:播放完后自动关闭窗口
修复:切换本地视频与在线视频错误的问题
结束
再次提醒各位开发者,使用vitamio播放有问题的视频请使用最新版的vplayer进行测试,如果没有问题新版发布的vitamio也不会有问题。
推荐阅读
-
Android 使用Vitamio打造自己的万能播放器(8)——细节优化
-
Android 使用Vitamio打造自己的万能播放器(10)—— 本地播放 (缩略图、视频信息、视频扫描服务)
-
Android 使用Vitamio打造自己的万能播放器(3)——本地播放(主界面、播放列表)
-
Android 使用Vitamio打造自己的万能播放器(5)——在线播放(播放优酷视频)
-
Android 使用Vitamio打造自己的万能播放器(4)——本地播放(快捷搜索、数据存储)
-
Android 使用Vitamio打造自己的万能播放器(2)—— 手势控制亮度、音量、缩放
-
Android 使用Vitamio打造自己的万能播放器(1)——准备
-
Android 使用Vitamio打造自己的万能播放器(3)——本地播放(主界面、播放列表)
-
Android 使用Vitamio打造自己的万能播放器(10)—— 本地播放 (缩略图、视频信息、视频扫描服务)
-
Android 使用Vitamio打造自己的万能播放器(8)——细节优化