使用Vitamio打造自己的Android万能播放器(6)——在线播放(播放列表)

前言

  新版本的VPlayer由设计转入开发阶段,预计开发周期为一个月,这也意味着新版本的Vitamio将随之发布,开发者们可以和本系列文章一样,先开发其他功能。本章内容为"在线视频播放列表",集合了主流各大视频网站的手机版,欢迎给"开播视频"反馈改进建议!

声明

  欢迎转载,但请保留文章原始出处:)

    博客园:http://www.cnblogs.com

    农民伯伯: http://over140.cnblogs.com

系列

  1、使用Vitamio打造自己的Android万能播放器(1)——准备

  2、使用Vitamio打造自己的Android万能播放器(2)—— 手势控制亮度、音量、缩放

  3、使用Vitamio打造自己的Android万能播放器(3)——本地播放(主界面、视频列表)

  4、使用Vitamio打造自己的Android万能播放器(4)——本地播放(快捷搜索、数据存储)  5、使用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也不会有问题。

时间: 2024-08-25 08:27:39

使用Vitamio打造自己的Android万能播放器(6)——在线播放(播放列表)的相关文章

使用Vitamio打造自己的Android万能播放器(2)—— 手势控制亮度、音量、缩放

前言 本章继续完善播放相关播放器的核心功能,为后续扩展打好基础. 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 系列 1.使用Vitamio打造自己的Android万能播放器(1)——准备 正文 一.实现目标 1.1 亮度控制 模仿VPlayer界面: 1.2 声音控制 模仿VPlayer界面: 1.3 画面缩放 根据下面API提供画面的拉伸.剪切.100%.全屏 二.Vitami

使用Vitamio打造自己的Android万能播放器(5)——在线播放(播放优酷视频)

前言 为了保证每周一篇的进度,又由于Vitamio新版本没有发布, 决定推迟本地播放的一些功能(截图.视频时间.尺寸等),跳过直接写在线播放部分的章节.从Vitamio的介绍可以看得出,其支持http.m3u8等多种网络协议,本章将编写播放优酷视频的例子. 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 系列 1.使用Vitamio打造自己的Android万能播放器(1)——准备 2

使用Vitamio打造自己的Android万能播放器(3)——本地播放(主界面、播放列表)

前言 打造一款完整可用的Android播放器有许多功能和细节需要完成,也涉及到各种丰富的知识和内容,本章将结合Fragment.ViewPager来搭建播放器的主界面,并实现本地播放基本功能.系列文章提供截图.代码说明.源码下载,欢迎交流! 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 系列 1.使用Vitamio打造自己的Android万能播放器(1)——准备 2.使用Vitam

使用Vitamio打造自己的Android万能播放器(7)——在线播放(下载视频)

前言 本章将实现非常实用的功能——下载在线视频.涉及到多线程.线程更新UI等技术,还需思考产品的设计,如何将新加的功能更好的融入到现有的产品中,并不是简单的加一个界面就行了,欢迎大家交流产品设计和技术细节实现! 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 系列 1.使用Vitamio打造自己的Android万能播放器(1)——准备 2.使用Vitamio打造自己的Android万

使用Vitamio打造自己的Android万能播放器(4)——本地播放(快捷搜索、数据存储)

前言 关键字:Vitamio.VPlayer.Android播放器.Android影音.Android开源播放器 本章节把Android万能播放器本地播放的主要功能(缓存播放列表和A-Z快速查询功能)完成,和播放组件关系不大,但用到一些实用的技术,欢迎交流! 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 系列 1.使用Vitamio打造自己的Android万能播放器(1)——准备

使用Vitamio打造自己的Android万能播放器

前言 虽然Android已经内置了VideoView组件和MediaPlayer类来支持开发视频播放器,但支持格式.性能等各方面都十分有限,这里与大家一起利用免费的Vitamio来打造属于自己的Android万能播放器! 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 正文 一.实现目标 1.1 支持格式 支持主流的视音频格式:mp3/mp4/mkv/avi/3gp/rmvb/mov

Vitamio打造自己的Android万能播放器

前言 虽然Android已经内置了VideoView组件和MediaPlayer类来支持开发视频播放器,但支持格式.性能等各方面都十分有限,这里与大家一起利用免费的Vitamio来打造属于自己的Android万能播放器! 声明 欢迎转载,但请保留文章原始出处:) 石攻玉 :http://www.cnblogs.com/stone4/ 正文 一.实现目标 1.1 支持格式 支持主流的视音频格式:mp3/mp4/mkv/avi/3gp/rmvb/mov/flv等. 1.2 支持功能 1.2.1 当然

使用Vitamio打造自己的Android万能播放器(1)——准备

前言 虽然Android已经内置了VideoView组件和MediaPlayer类来支持开发视频播放器,但支持格式.性能等各方面都十分有限,这里与大家一起利用免费的Vitamio来打造属于自己的Android万能播放器! 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com 正文 一.实现目标 1.1 支持格式 支持主流的视音频格式:mp3/mp4/mkv/avi/3gp/rmvb/mov

android求助:关于播放器中的“播放/暂停”键: 用ImageButton来设置点击效果时的问题

============问题描述============ 大家好,我最近遇到个问题: 大家都知道,播放器中的播放/暂停键是这样的逻辑:当用户点击了这个键,如果当前显示的是"播放"图案,会变为"暂停"图案:反之,如果当前是"暂停"图案,会变为"播放"图案 , 如此反复... 现在我正在实现这个效果,我是这样做的: 在以上的基本效果的基础上,我还添加了点击过程中的效果,就是当点下还木有松开时,会有一个点击效果(比如给当前图片加个光