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

简介:

前言

  新版本的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

     

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

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

  

结束

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


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

目录
相关文章
|
1月前
|
存储 缓存 Android开发
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【远程url】音频,搭配Okhttp库进行下载和缓存,播放完随机播放下一首
这是一个Kotlin项目,使用Jetpack Compose和ExoPlayer框架开发Android应用,功能是播放远程URL音频列表。应用会检查本地缓存,如果文件存在且大小与远程文件一致则使用缓存,否则下载文件并播放。播放完成后或遇到异常,会随机播放下一首音频,并在播放前随机设置播放速度(0.9到1.2倍速)。代码包括ViewModel,负责音频管理和播放逻辑,以及UI层,包含播放和停止按钮。
148 0
|
1月前
|
存储 数据库 Android开发
安卓Jetpack Compose+Kotlin,支持从本地添加音频文件到播放列表,支持删除,使用ExoPlayer播放音乐
为了在UI界面添加用于添加和删除本地音乐文件的按钮,以及相关的播放功能,你需要实现以下几个步骤: 1. **集成用户选择本地音乐**:允许用户从设备中选择音乐文件。 2. **创建UI按钮**:在界面中创建添加和删除按钮。 3. **数据库功能**:使用Room数据库来存储音频文件信息。 4. **更新ViewModel**:处理添加、删除和播放音频文件的逻辑。 5. **UI实现**:在UI层支持添加、删除音乐以及播放功能。
108 1
|
1月前
|
XML 存储 数据库
如何使用Android Studio创建一个基本的音乐播放器应用
如何使用Android Studio创建一个基本的音乐播放器应用
41 0
|
1月前
|
缓存 Android开发 Kotlin
【安卓app开发】kotlin Jetpack Compose框架 | 先用OKhttp下载远程音频文件再使用ExoPlayer播放
使用 Kotlin 的 Jetpack Compose 开发安卓应用时,可以结合 OkHttp 下载远程音频文件和 ExoPlayer 进行播放。在 `build.gradle` 添加相关依赖后,示例代码展示了如何下载音频并用 ExoPlayer 播放。代码包括添加依赖、下载文件、播放文件及简单的 Compose UI。注意,示例未包含完整错误处理和资源释放,实际应用需补充这些内容。
|
1月前
|
安全 Java API
Android获取Wi-Fi网络列表
【6月更文挑战第21天】
|
1月前
|
存储 Android开发 Kotlin
Kotlin开发安卓app,在使用 MediaPlayer 播放 res/raw 中的音乐时遇到突然中断的问题,而 onErrorListener 没有接收到任何报错
在使用 Android MediaPlayer 播放 res/raw 中的音乐时遇到中断问题,可能的原因包括资源问题、媒体文件编码格式、生命周期管理和设备资源配置。要排查问题,检查音频文件是否正确包含,格式编码是否支持,MediaPlayer 是否正确管理及释放,以及设备是否有足够存储和配置。通过设置 onErrorListener 日志和确保在 onDestroy 中释放资源来调试。如果文件过大,考虑使用 AssetManager。遵循这些步骤可帮助诊断并解决播放中断的问题。
|
1月前
|
Android开发 Kotlin
安卓Jetpack Compose+Kotlin, 使用ExoPlayer播放多个【本地】音频,播放完随机播放下一首,遇到播放错误,也自动播放下一首
使用Kotlin和Jetpack Compose开发的安卓应用中,实现了两个EvoPlayer同时播放res/raw目录下的音频。一个音轨播放人声(顺序播放),另一个播放背景音乐(随机播放)。每个音轨都有独立的播放和停止控制,且在播放结束或遇到错误时会自动切换到下一首。MediaPlayer置于ViewModel中,UI界面包含播放和停止按钮,控制两个音轨。每次切换音频前,还会随机调整播放速度在0.9到1.2之间。代码示例展示了如何创建ViewModel和UI以实现这一功能。
103 0
|
12天前
|
Android开发 Kotlin
kotlin开发安卓app,如何让布局自适应系统传统导航和全面屏导航
使用`navigationBarsPadding()`修饰符实现界面自适应,自动处理底部导航栏的内边距,再加上`.padding(bottom = 10.dp)`设定内容与屏幕底部的距离,以完成全面的布局适配。示例代码采用Kotlin。
57 15