Android 开发音频组件(Vitamio FAQ)详细介绍

 一、Vitamio介绍

  1.1 Vitamio是什么?

   Vitamio是Android平台视音频播放组件,支持播放几乎格式的视频以及主流网络视频流(http/rtsp/mms等),详细的中文介绍: 这里。

   Vitamio官网:http://vitamio.org/

   Vitamio微博:http://weibo.com/vitamio 

   VPlayer官网:http://vplayer.net

   Vitamio豆瓣:http://site.douban.com/145815/

  1.2 关于Vitamio的名字(摘自豆瓣官网)

   Vitamio 来源于英文单词Vitamin(维他命),希望Vitamio对于安卓多媒体开发者的重要性,就像Vitmain之于人体一样不可缺少。 

   The name of Vitamio comes from Vitamin, We hope the importance of Vitamio for Android multimedia developers as indispensable as Vitamin for human.

  1.3 关于Vitamio的由来(摘自豆瓣官网)

   我们是一拨葱名勤劳的Coder,我们憎恶烦冗的Android多媒体程序开发,从版本升级到不同设 备,刚坑娘的测试完三星,htc,sony,操,又拿来了v880;我们认为这些讨厌的玩意注定会让我们的生活变得愚蠢,新技术神马的也是没有时间去研究 ,最令人发指的是不能专注于实现自己的创意APP。

   经常沉溺于拯救世界的精神世界,平凡的Coder也能变奇葩。作为最早研究Android媒体工具的团队,我们决定把我们的Vitamio框架免费出去,助力安卓多媒体开发者实现自己的创意梦想 :D, 各位少年,我们是来自中国的高品质多媒体框架噢。

   第一版发布日期:2011年9月发布

  1.4 Vitamio相关数据

   从2011年9月发布至今,用户下载量超过2000W,使用Vitamio的开发者超过1500位,使用过Vitamio产品有

   国内:搜狐视频,91熊猫影音(网龙),海底捞,歌华有限 等  

   国外:Pak TV Global,Madani Channel,Deen TV,myTRANS,FPlayer,AnimeFTW.tv,Radio Nepali,GNC LiveWell,MagicTV Streaming Player Free,Hispan TV Mobile,TV Italy等

  1.5 Vitamio有什么优点?

   a). 强大。支持超多格式视频和网络视频播放。(不强大免费也没用,所以排在第一位)

   b). 个人免费。(但企业使用需要购买授权

    (Google Play上已有多款基于Vitamio的收费播放器,大家可以在里面搜索Vitamio关键字)

   c). 无缝集成。仅将Vitamio的Library工程引入即可使用,无需另外下载安装解码包(Vitamio的上一个版本是需要单独下载安装解码包)。

   d). 使用简单。调用非常简单,方便使用。

   e). 自由定制。播放界面的代码已完全开放,方便自定义播放界面、进度条等。

   d). 持续更新。2012-7-9已发布新一版的内测版本,预计8月初能发布下一个版本。

   e). 服务跟进。Vitamio官方QQ群(171570336),提供开发者交流和讨论。论坛还在开发中。

  1.6 Vitamio背后的团队

   Vitamio与VPlayer属同一个团队、同一个公司(yixia.com)。我们在北京,目前团队有5名成员,4名开发,1名设计师,以开发VPlayer为主,Vitamio为辅 :)

  1.7 Vitamio与VPlayer什么关系?

   VPlayer基于Vitamio开发,所以VPlayer能播放的Vitamio也能。

   OPlayer基于Vitamio开发,作为推广Vitamio的使用例子和示范产品,完全开放源代码。虽是业余之作,仍以正式发布到市场为目标。

  1.8 Vitamio与ffmpeg

   FFmpeg提供软件解码器和多路输出(demuxers)。Vitamio使用LGPLv2.1许可下FFmpeg的代码,代码可以从这里下载。

   https://bitbucket.org/ABitNo/ffmpegandroid

 二、Vitamio下载和运行

  2.1 下载

   Vitamio 3.0下载。(2012-10-23更新)

   OPlayer 3.0下载。(2012-10-24更新,没有taocode账户的请注册一个)

  2.2 运行例子

   解压后两个项目:VitamioBundle和Test,其中VitamioBundle是Library(关于Android Library参见这里),运行Test例子即可。

注意:

   1). 例子使用API 16,没有安装升级最新Android 4.1 会报错,大家设置里降低至API 14(Android 4.0) 或API 15(Android 4.0.3) 即可。

   2). 工程文件并没有gen文件夹,请大家自行加上。

   3). 先编译VitamioBundle,后编译Test。如果仍然有错误,把工程Clean一下,依次再编译一下。

   4). 修改VideoViewDemo视频路径为你要测试的视频路径。注意,本地视频用setVideoPath方法,播放网络视频用setVideoURI方法。

  2.3 整合例子

   不希望以Library的方式引用Vitamio,可以直接把VitamioBundle里所有的类、资源拷贝至目标项目。注意src、libs、res目录下的都要拷贝过去,还有AndroidManifest.xml中的配置。

   成功整合例子,大家可以看一下OPlayer的结构。

  2.4 自定义InitActiviy,即正在解压解码包进度条界面。

    这里给出InitActivity代码:  

public class InitActivity extends Activity {
 public static final String FROM_ME = "fromVitamioInitActivity";
 public static final String EXTRA_MSG = "EXTRA_MSG";
 public static final String EXTRA_FILE = "EXTRA_FILE";
 private ProgressDialog mPD;

 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);

  new AsyncTask() {
   protected void onPreExecute() {
    mPD = new ProgressDialog(InitActivity.this);
    mPD.setCancelable(false);
    mPD.setMessage(getString(getIntent().getIntExtra(EXTRA_MSG, R.string.vitamio_init_decoders)));
    mPD.show();
   }

   @Override
   protected Object doInBackground(Object... params) {
    VitamioConnection.initNativeLibs(getApplicationContext(), getIntent().getIntExtra(EXTRA_FILE, R.raw.libarm), new VitamioConnection.OnNativeLibsInitedListener() {
     @Override
     public void onNativeLibsInitCompleted(String libPath) {
      Log.d("Native libs inited at " + libPath);
      uiHandler.sendEmptyMessage(0);
     }
    });
    return null;
   }
  }.execute();
 }

 private Handler uiHandler = new Handler() {
  public void handleMessage(Message msg) {
   mPD.dismiss();
   Intent src = getIntent();
   Intent i = new Intent();
   i.setClassName(src.getStringExtra("package"), src.getStringExtra("className"));
   i.setData(src.getData());
   i.putExtras(src);
   i.putExtra(FROM_ME, true);
   startActivity(i);
   finish();
  }
 };
}

  代码说明:

   主要是VitamioConnection.initNativeLibs,大家自己写一个初始化的界面即可,线程里调用这个代码即可。

 三、Vitamio问题汇总

  3.1 官网怎么打不开?

   由于vplayer.net、vov.io等几个网站都是我们部门自己维护的,目前就一人再改,出点问题来不及弄,你懂的。

 3.2  case : 为什么一直停在正在解码的解码?

    case : Couldn't load vinit: findLibrary returned null

    case : Not allowed to bind to service Intent (act=io.vov.vitmio.IVitamioService)

    case : io.vov.vitmio.VitamioInstaller$VitamioNotFoundException

    case : java.lang.UnsatisfiedLinkError: Library /data/data/null/libs/libvplaer.so not found

    defalut : //各种运行不了的问题

    return 基本就一个问题,2012-7-9发布的Vitamio测试版本无法共存的问题。无法与VPlayer共存、无法与其他Vitamio共存,需要卸载干净了。注意改一下包名(package)就是一个新的APK,需要把之前的卸载掉。

  3.3 视频/视频流(rtp、rtsp等)播放不了。

   可能存在以下几种情况:

   a). 视频本身就存在问题,你可以用其他播放器播放一下,是否能正常播放。

   b). 本地网速不给力/设备本事配置过低,这个没办法

   c). 视频源卡,本事带宽不够,直接访问也很慢,这个也没办法

   d). 用VPlayer与Vitamio同样都有问题,而其他播放器没事,这个可能是我们的问题,我们还在持续改进,尤其是播在线视频这部分,这个可以等新版发布 :)

   e). 等不及了,那就把视频测试地址和简要说明发给我们([email protected]),我们尽可能的抽时间来回复,感谢!

  3.4 Vitamio最低支持的Android版本

   目前我们在运行的项目最低支持Android 2.1,示例工程选的Android API Level 是4.1,但不代表只支持4.0以上,大家可从AndroidManifest.xml中看得出:

   

 如果编译无法运行的话,把VitamioBundle项目下res/values-v11和values-v14删掉即可,其他部分稍作改动即可。

  3.5 为什么会弹出提示框要求安装Vitamio Plugin

   因为你下载和使用的是旧版的Vitamio,请卸载干净后下载2012-7-9日发布的版本,请看本文 2.1 下载。

  3.6 是否支持硬解码?

   目前支持硬解码这部分不是很成熟,也不稳定,暂时不提供。

  3.7 什么时候发布新版本?

   诶,,,请关注我们官方微博(http://weibo.com/vitamio )!!目前集中精力再弄VPlayer,新版顺利上线后应该能加快Vitamio的发布速度,所以大家可以先用VPlayer来测试。

  3.8 E/Vitamio(1557): java.io.FileNotFoundException: No content provider: (2012-8-6)
   这个不是错误,是正常的处理。现在播放视频是这样做的:先把 URL 当做一个 ContentProvider 来打开,如果打不开,就直接当做 URL 来打开

  3.9 Vitamio支持哪些指令集的CPU?(2012-09-07)

   ARMv6、ARMv6 VFP、ARMv7 VFPV3、ARMv7 NEON(注意:2012-8-31发布的版本不支持ARMv6的CPU,VPlayer已经不支持,但下次发版Vitamio会加上)

  3.10 播放网络视频突然中断的问题

   可能是视频网站做了限制,加入了一些不能播的地址,目前Vitamio的处理是播不了就直接关闭了,后续版本会改进,直接跳过。

  3.11 拖动进度条出现回帧现象(本地播放,比如,拖到到1:20,但是播放时,跳到1:15) 【2012-11-20 新增】

   这是正常现象,不是播放器的问题。默认seek要到最近的关键帧,不能保证任何时间点上都有关键帧 。除非你是intra-only 的编码方式 。(――来自GoogleGeek)

 四、已知问题和注意事项(新版指2012-8-31发布的版本)

  4.1 混淆工程时注意,需要忽略vitamio里面的类库!(2012-8-1 update)

 -keep class io.vov.utils.** { *; }
 -keep class io.vov.vitamio.** { *; }

  4.2  不能在包含项目里面使用io.vov.vitamio.provider.MediaProvider

   否则如果安装了VPlayer,会报冲突的错误无法安装。也就是说,可以直接使用VPlayer的MediaProvider,或者自己写扫描服务,但是名字不能相同。

 五、其他

  5.1 调用VPlayer来播放视频的代码:

private void startPlayer(String url, String title) {
	Intent i = new Intent();
	i.setComponent(new ComponentName("me.abitno.vplayer.t", "me.abitno.vplayer.VideoActivity"));
	i.setAction("me.abitno.vplayer.action.VIEW");
	i.setData(Uri.parse(url));
	i.putExtra("displayName", title);
	startActivity(i);
}

 以上就是对Android Vitamio FAQ音频播放的组件详细介绍,希望能帮助Android开发音频播放的朋友。

你可能感兴趣的:(Android 开发音频组件(Vitamio FAQ)详细介绍)