前言

打造一款完整可用的Android播放器有许多功能和细节需要完成,也涉及到各种丰富的知识和内容,本章将结合Fragment、ViewPager来搭建播放器的主界面,并实现本地播放基本功能。系列文章提供截图、代码说明、源码下载,欢迎交流!

声明
欢迎转载,但请保留文章原始出处:) 
  博客园:http://www.cnblogs.com

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

系列

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

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

正文

一、目标

1.1 使用Fragment、ViewPager搭建主界面

主功能区分为:本地视频、在线视频,允许滑动切换模块

1.2 用ListView显示sdcard所有视频

效果截图:

(声明:图标均来自网络,仅供学习研究之用!)

二、实现代码

2.1 xml

  1.  
  2. <?xml version="1.0" encoding="utf-8"?>
  3. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  4.     android:orientation="vertical" android:gravity="center_horizontal"
  5.     android:layout_width="match_parent" android:layout_height="match_parent">
  6.     <RadioGroup android:gravity="center_vertical"
  7.         android:layout_width="fill_parent" android:layout_height="wrap_content"
  8.         android:orientation="horizontal">
  9.         <RadioButton android:id="@+id/radio_file" android:checked="true"
  10.             style="@style/main_tab_bottom" android:drawableTop="@drawable/video_file"
  11.             android:text="@string/title_file" />
  12.         <RadioButton android:id="@+id/radio_online"
  13.             android:drawableTop="@drawable/video_online" style="@style/main_tab_bottom"
  14.             android:text="@string/title_online" />
  15.     </RadioGroup>
  16.     <android.support.v4.view.ViewPager
  17.         android:background="@color/background" android:id="@+id/pager"
  18.         android:layout_width="match_parent" android:layout_height="match_parent">
  19.     </android.support.v4.view.ViewPager>
  20. </LinearLayout>

这是整体布局,使用RadioButton切换本地视频和在线视频功能,具体样式请下载项目。ViewPager支持左右侧滑切换功能。

2.2 class

MainFragmentActivity

  1.  
  2. public class MainFragmentActivity extends FragmentActivity {
  3.  
  4.     private ViewPager mPager;
  5.  
  6.     @Override
  7.     protected void onCreate(Bundle savedInstanceState) {
  8.         super.onCreate(savedInstanceState);
  9.         setContentView(R.layout.fragment_pager);
  10.         mPager = (ViewPager) findViewById(R.id.pager);
  11.         mPager.setAdapter(mAdapter);
  12.     }
  13.  
  14.     private FragmentPagerAdapter mAdapter = new FragmentPagerAdapter(getSupportFragmentManager()) {
  15.  
  16.         /** 仅执行一次 */
  17.         @Override
  18.         public Fragment getItem(int position) {
  19.             Fragment result = null;
  20.             switch (position) {
  21.             case 1:
  22.                 result = new FragmentOnline();//在线视频
  23.                 break;
  24.             case 0:
  25.             default:
  26.                 result = new FragmentFile();//本地视频
  27.                 break;
  28.             }
  29.             return result;
  30.         }
  31.  
  32.         @Override
  33.         public int getCount() {
  34.             return 2;
  35.         }
  36.     };
  37. }

这里是Fragment与ViewPager结合使用的简单例子。

FragmentFile

  1.  
  2. public class FragmentFile extends FragmentBase implements OnItemClickListener {
  3.  
  4.     private FileAdapter mAdapter;
  5.  
  6.     @Override
  7.     public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
  8.         View v = super.onCreateView(inflater, container, savedInstanceState);
  9.         mAdapter = new FileAdapter(getActivity(), null);
  10.         mListView.setAdapter(mAdapter);
  11.         mListView.setOnItemClickListener(this);
  12.         new ScanVideoTask().execute();
  13.         return v;
  14.     }
  15.  
  16.     /** 单击启动播放 */
  17.     @Override
  18.     public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
  19.         final File f = mAdapter.getItem(position);
  20.         Intent intent = new Intent(getActivity(), VideoViewDemo.class);
  21.         intent.putExtra("path", f.getPath());
  22.         startActivity(intent);
  23.     }
  24.  
  25.     /** 扫描SD卡 */
  26.     private class ScanVideoTask extends AsyncTask<Void, File, Void> {
  27.  
  28.         @Override
  29.         protected Void doInBackground(Void... params) {
  30.             eachAllMedias(Environment.getExternalStorageDirectory());
  31.             return null;
  32.         }
  33.  
  34.         @Override
  35.         protected void onProgressUpdate(File... values) {
  36.             mAdapter.add(values[0]);
  37.             mAdapter.notifyDataSetChanged();
  38.         }
  39.  
  40.         /** 遍历所有文件夹,查找出视频文件 */
  41.         public void eachAllMedias(File f) {
  42.             if (!= null && f.exists() && f.isDirectory()) {
  43.                 File[] files = f.listFiles();
  44.                 if (files != null) {
  45.                     for (File file : f.listFiles()) {
  46.                         if (file.isDirectory()) {
  47.                             eachAllMedias(file);
  48.                         } else if (file.exists() && file.canRead() && FileUtils.isVideoOrAudio(file)) {
  49.                             publishProgress(file);
  50.                         }
  51.                     }
  52.                 }
  53.             }
  54.         }
  55.     }
  56.  
  57.     private class FileAdapter extends ArrayAdapter<File> {
  58.  
  59.         public FileAdapter(Context ctx, ArrayList<File> l) {
  60.             super(ctx, l);
  61.         }
  62.  
  63.         @Override
  64.         public View getView(int position, View convertView, ViewGroup parent) {
  65.             final File f = getItem(position);
  66.             if (convertView == null) {
  67.                 final LayoutInflater mInflater = getActivity().getLayoutInflater();
  68.                 convertView = mInflater.inflate(R.layout.fragment_file_item, null);
  69.             }
  70.             ((TextView) convertView.findViewById(R.id.title)).setText(f.getName());
  71.             return convertView;
  72.         }
  73.     }

}

代码说明:

a).  这里是本章的主要功能,扫描所有视音频文件,并显示出来。

b).  ArrayAdapter和FileUtils这里不一一贴代码,主要是工具和辅助类,请下载项目查看。

c).  注意mAdapter.add操作应放到主线程中,否则可能出错。

三、 代码下载

Vitamio-Demo2012-5-30.zip

结束

这几天装了双系统win7 + ubuntu,以后工作也会接触到更多linux相关的内容,希望有机会能写写这方面的文章。下章节将添加A-Z的快速搜索,也欢迎大家把感兴趣的东西告诉我,考虑加入后续功能开发。

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

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

    前言 新版本的VPlayer由设计转入开发阶段,预计开发周期为一个月,这也意味着新版本的Vitamio将随之发布,开发者们可以和本系列文章一样,先开发其他功能.本章内容为"在线视频播放列表& ...

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

    前言 为了保证每周一篇的进度,又由于Vitamio新版本没有发布, 决定推迟本地播放的一些功能(截图.视频时间.尺寸等),跳过直接写在线播放部分的章节.从Vitamio的介绍可以看得出,其支持http ...

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

    前言 关键字:Vitamio.VPlayer.Android播放器.Android影音.Android开源播放器 本章节把Android万能播放器本地播放的主要功能(缓存播放列表和A-Z快速查询功能) ...

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

    前言 本章继续完善播放相关播放器的核心功能,为后续扩展打好基础.   声明 欢迎转载,但请保留文章原始出处:)  博客园:http://www.cnblogs.com 农民伯伯: http://ove ...

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

    前言 本章将实现非常实用的功能——下载在线视频.涉及到多线程.线程更新UI等技术,还需思考产品的设计,如何将新加的功能更好的融入到现有的产品中,并不是简单的加一个界面就行了,欢迎大家交流产品设计和技术 ...

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

    前言 虽然Android已经内置了VideoView组件和MediaPlayer类来支持开发视频播放器,但支持格式.性能等各方面都十分有限,这里与大家一起利用免费的Vitamio来打造属于自己的And ...

  7. H5播放器内置播放视频(兼容绝大多数安卓和ios)

    关于H5播放器内置播放视频,这个问题一直困扰我很长一段时间,qq以前提供白名单已经关闭,后来提供了同层属性的控制,或多或少也有点差强人意. 后来一次偶然发现一个非常简单的方法可以实现. 只需要给vid ...

  8. (1)H5实现音乐播放器【正在播放-歌词篇】

    近期闲来无事,就想着复习一下前端的东西,然后正好跟朋友搞了一个公共开放的音乐api接口,就想着写一个音乐播放器玩玩! 话不多说,直接上图,然后上代码 [播放器显示正在播放] 实现功能: 1:歌词随着歌 ...

  9. android音乐播放器开发 SweetMusicPlayer 播放本地音乐

    上一篇写了载入歌曲列表,http://blog.csdn.net/huweigoodboy/article/details/39856411,如今来总结下播放本地音乐. 一,MediaPlayer 首 ...

随机推荐

  1. atomic_compare_exchange

    atomic_compare_exchange 分为两个版本 atomic_compare_exchange_strong 和 atomic_compare_exchange_weak,语义如下 bo ...

  2. Android-PullToRefresh下拉刷新库基本用法

    How:(使用) 转自:http://blog.csdn.net/hantangsongming/article/details/42490277 PullToRefresh是一套实现非常好的下拉刷新 ...

  3. windows2003 64位注册码 序列号 激活码

    Windows 2003 R2 64bit Enterprise VOL Edition 企业版 MR78C-GF2CY-KC864-DTG74-VMT73 VPT7T-77D38-KWVW2-2G3 ...

  4. system函数遇到的问题 - 程序死掉

    system函数遇到的问题 解决方案见最下边 http://blog.csdn.net/yangzhenzhen/article/details/51505176 这几天调程序(嵌入式linux),发 ...

  5. GDB 多进程调试

    启动: $gdb <file>  || $gdb 然后(gdb)file <file> 运行: (gdb)run <该程序本身的命令行参数> 查看代码: (gdb) ...

  6. iOS使用ffmpeg播放rstp实时监控视频数据流

    一.编译针对iOS平台的ffmpeg库(kxmovie) 最近有一个项目.须要播放各种格式的音频.视频以及网络摄像头实时监控的视频流数据,经过多种折腾之后,最后选择了kxmovie,kxmovie项目 ...

  7. PhoneGap或者Cordova框架下实现Html5中JS调用Android原生代码

    PhoneGap或者Cordova框架下实现Html5中JS调用Android原生代码 看看新闻网>看引擎>开源产品 0人收藏此文章, 发表于8小时前(2013-09-06 00:39) ...

  8. 具体解释HTML中的window对象和document对象

    Window -- 代表浏览器中一个打开的窗体: 对象属性 window //窗体自身 window.self //引用本窗户window=window.self window.name //为窗体命 ...

  9. Jquery实现鼠标hover图片遮罩弹出提示层特效

    1.引入JS文件和所需要的样式文件 2.简单的写上以下18行代码就可以实现了 $(document).ready(function() { $("div.tip_trigger a.img& ...

  10. linux常用命令详解 (二)文件处理命令

    ◆ 文件处理命令:file.mkdir.grep.dd.find.mv.ls.diff.cat.ln: 系统信息存放在文件里,文件与普通的公务文件类似.每个文件都有自己的名字.内容.存放地址及其它一些 ...