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

转自:http://www.cnblogs.com/over140/archive/2012/06/20/2553494.html

前言

  新版本的VPlayer由设计转入开发阶段,预计开发周期为 一个月,这也意味着新版本的Vitamio将随之发布,开发者们可以和本系列文章一样,先开发其他功能。本章内容为"在线视频播放列表",集合了主流各大视频网站的手机版,欢迎给"开播视频"反馈改进建议!
 
声明
  欢迎转载,但请保留文章原始出处:) 
    博客园:http://www.cnblogs.com
    农民伯伯: http://over140.cnblogs.com 
 
系列
  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


 修复:播放完后自动关闭窗口

     修复:切换本地视频与在线视频错误的问题

 

  四、下载

    OPlayer20120620.zip

     (后续版本将托管至github.com)  

 

结束

   再次提醒各位开发者,使用Vitamio播放有问题的视频请使用最新版的VPlayer进行测试,如果没有问题新版发布的Vitamio也不会有问题。



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android Vitamio是一个开源的跨平台多媒体播放框架,它支持播放多种音频格式,包括WAV格式。要在Android Vitamio中播放WAV文件,可以按以下步骤进行: 第一步:添加Vitamio库文件到项目中。在build.gradle文件中添加Vitamio库的依赖项。 第二步:在代码中初始化Vitamio库。在App的入口处(如MainActivity的onCreate方法中),调用Vitamio库的初始化方法,确保Vitamio库已经正确初始化。 第三步:创建一个MediaPlayer对象,用于播放音频文件。可以使用VitamioVitamio.createPlayer方法创建一个MediaPlayer对象。 第四步:设置音频文件的路径。使用MediaPlayer对象的setDataSource方法,传入要播放的WAV文件的路径。 第五步:准备MediaPlayer对象。调用MediaPlayer对象的prepareAsync方法,准备音频文件的播放。 第六步:设置MediaPlayer的监听器。可以注册一个MediaPlayer.OnPreparedListener监听器,用于在音频准备完成后播放音频。 第七步:开始播放音频。调用MediaPlayer对象的start方法,开始播放音频。 第八步:在适当的时机释放MediaPlayer对象。当音频播放完成或不再需要播放时,调用MediaPlayer对象的release方法,释放资源。 通过上述步骤,就可以使用Android Vitamio播放WAV文件了。需要注意的是,确保WAV文件的路径正确,并且要在AndroidManifest.xml文件中添加适当的权限,以允许访问存储器中的音频文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值