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

前言

  新版本的VPlayer由設計轉入開發階段,預計開發週期爲一個月,這也意味着新版本的Vitamio將隨之發佈,開發者們可以和本系列文章一樣,先開發其他功能。本章內容爲"在線視頻播放列表",集合了主流各大視頻網站的手機版,歡迎給"開播視頻"反饋改進建議!
 
聲明
  歡迎轉載,但請保留文章原始出處:) 
    博客園:http://www.cnblogs.com
    農民伯伯: http://over140.cnblogs.com 

 
正文
  一、目標
    集成各大視頻網站的手機版,截圖:

    

 

  二、實現代碼 
複製代碼
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也不會有問題。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章