打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
Vitamio中文API文档(5)—— MediaPlayer

类概述

public class MediaPlayer

MediaPlayer可控制播放音乐/视频和网络流。可以从VideoView找到使用这个类的方法。

这个类与android.media.MediaPlayer的作用大部分相同。请参阅 开发者指南音频和视频 使用MediaPlayer。



常量

public static final int MEDIA_ERROR_UNKNOWN

播放错误,未知错误。

常量值:0


public static final int MEDIA_ERROR_NOT_VALID_FOR_PROGRESSIVE_PLAYBACK

播放错误(一般视频播放比较慢或视频本身有问题会引发)。

常量值:200


public static final int MEDIA_INFO_VIDEO_TRACK_LAGGING

     视频过于复杂,无法解码:不能快速解码帧。此时可能只能正常播放音频。参见MediaPlayer.OnInfoListener。

常量值:700


public static final int MEDIA_INFO_BUFFERING_START

MediaPlayer暂停播放等待缓冲更多数据。

常量值:701


public static final int MEDIA_INFO_BUFFERING_END

MediaPlayer在缓冲完后继续播放。

常量值:702


public static final int MEDIA_INFO_NOT_SEEKABLE

媒体不支持Seek,例如直播流。

常量值:801


public static final int MEDIA_INFO_DOWNLOAD_RATE_CHANGED

av_read_frame()的速度(KB/s)。

常量值:901


public static final int VIDEOQUALITY_LOW

视频质量——流畅。

常量值:-16


public static final int VIDEOQUALITY_MEDIUM

视频质量——普通。

常量值:0


public static final int VIDEOQUALITY_HIGH

视频质量——高质。

常量值:16


public static final int SUBTITLE_INTERNAL

字幕显示来自内置字幕。

常量值:0


public static final int SUBTITLE_EXTERNAL

字幕显示来自外置字幕。

常量值:1


public static final String[] SUB_TYPES

Vitamio支持的外置字幕类型。

常量值:{ ".srt", ".ssa", ".smi", ".txt", ".sub", ".ass" }

 

公共方法

public static final boolean isLibraryLoaded ()

     动态链接库(so)是否已经成功加载完成。


public void setDisplay (SurfaceHolder sh)

设置用于显示媒体视频的SurfaceHolder。这个调用是可选的。只显示音频而不显示视频时不调用这个方法(例如后台播放)。

sh


public void setDataSource (Context context, Uri uri)

设置多媒体数据源,例如context Uri。(支持raw资源访问,例如:android.resource://com.your.package/R.raw.your_resource_id)

context

uri

IllegalArgumentException



public native void setDataSource (String path)

设置数据源(文件路径或 http/rtsp/mms URL )。


public native void setDataSource (FileDescriptor fd)

      设置数据源(FileDescriptor)。调用者在调用后要自行关闭FileDescriptor,最安全的做法是一返回就马上关闭。


public native void prepare ()

预处理播放器为播放做准备,方法是同步执行。

     设置完数据源和显示的 Surface 后,你需要调用prepare() 或prepareAsync() 。对于文件,你可以直到媒体播放器准备播放时再调用prepare 


public native void prepareAsync ()

预处理播放器为播放做准备,方法是异步执行。

     设置完数据源和显示的 Surface 后,你需要调用prepare() 或prepareAsync() 。对于流,你应该调用prepareAsync() ,立即返回,而不是阻塞,直到足够的数据被缓冲。


public void start ()

开始或继续播放。如果此前已暂停播放,那么就从暂停的地方播放。如果已经停止播放或还未开始播放,播放将从头开始。


public void stop ()

 pause()相同 


public void pause ()

暂停播放。调用 start() 恢复。


public void setWakeMode (Context context, int mode)

设置 MediaPlayer 的底层电源管理。可以在 MediaPlayer 没有通过 SurfaceHolder 设置 setDisplay 播放时使用,从而使用高级别的 setScreenOnWhilePlaying 特性。

本方法在 MediaPlayer 访问低级别电源管理控制设备电源时使用。参数是一个 android.os.PowerManager 唤醒组合标识。使用这个方法需要 WAKE_LOCK 权限。默认情况下不使用以保持设备唤醒播放。


public void setScreenOnWhilePlaying (boolean screenOn)

控制是否使用附加 SurfaceHolder 保持屏幕高亮持续播放视频。本方法可能优于使用setWakeMode ,因为它不需要应用程序访问底层唤醒锁的权限。


public native int getVideoWidth ()

获取视频宽度。

返回视频的宽度,没有视频或宽度尚未确定时返回0。可以通过注册OnVideoSizeChangedListener当宽度有效时获得一个通知。


public native int getVideoHeight ()

获取视频高度。

返回视频的高度,没有视频或高度尚未确定时返回0。可以通过注册OnVideoSizeChangedListener当高度有效时获得一个通知。


public native boolean isPlaying ()

检测 MediaPlayer是否正在播放。


public native void seekTo (long msec)

设置到指定时间位置播放。

msec 从开始位置到 msec 的偏移量(以毫秒为单位)


public native long getCurrentPosition ()

获取当前播放位置。


public native Bitmap getCurrentFrame ()

获取当前视频帧。(可用于截图)


public native long getDuration ()

获取多媒体播放持续时间。


public void release ()

释放与 MediaPlayer相关的资源。当你使用完MediaPlayer完后调用此方法是一个好的编程习惯。


public void reset ()

复位 (reset)MediaPlayer至未初始化状态。调用此方法后,你需要再次设置数据源,并通过prepare()来初始化。


public native void setVolume (float leftVolume, float rightVolume))

设置音量。(范围 0.0~1.0之间)


public void setOnPreparedListener (OnPreparedListener listener))

注册一个回调函数,在视频预处理完成后调用。

 

public void setOnCompletionListener (OnCompletionListener l)

注册一个回调函数,视频播放完成后调用。


public void setOnErrorListener (OnErrorListener l)

注册一个回调函数,在异步操作调用过程中发生错误时调用。例如视频打开失败。


public void setOnBufferingUpdateListener (OnBufferingUpdateListener l)

注册一个回调函数,在网络视频流缓冲变化时调用。


public void setOnSeekCompleteListener (OnSeekCompleteListener l)

注册一个回调函数,在 seek 操作完成后调用。


public void setOnVideoSizeChangedListener (OnVideoSizeChangedListener listener)

注册一个回调函数,在视频大小已知或更新后调用。


public void setOnSubtitleUpdateListener (OnSubtitleUpdateListener l)

注册一个回调函数,在字幕需要显示时调用。


public void setOnInfoListener (OnInfoListener l)

      注册一个回调函数,在有警告或错误信息时调用。例如:开始缓冲、缓冲结束、下载速度变化。


public void releaseDisplay ()

在播放音频的时候调用这个有效果。


public native float getVideoAspectRatio ()

获取视频宽高比例。

返回视频的宽高比。没有视频或者宽高不正确返回0。参见VideoView.setVideoLayout。


public native void setVideoQuality (int quality)

设置视频质量。如果播放延迟比较严重,你可以尝试使用 VIDEOQUALITY_LOW (流畅),默认 VIDEOQUALITY_LOW (流畅)。


public native void setDeinterlace (boolean deinterlace)

设置视频反交错。


public native void setBufferSize (int bufSize)

设置视频缓冲大小。默认 1024KB


public native boolean isBuffering ()

检测是否缓冲完毕。


public native int getBufferProgress ()

参见 OnBufferingUpdateListener。


public native void setMetaEncoding (String encoding)

设置元数据编码。例如: UTF-8


public native String getMetaEncoding ()

获取元数据编码。


public HashMap<String, Integer> getAudioTrackMap (String encoding)

获取视频中嵌入的音轨。例如: English


public native int getAudioTrack ()

设置播放音轨编号。

 

public native void setAudioTrack (int audioIndex)

设置音轨编号,必须使用 getAudioTrackMap 的返回值。


public void setInitialAudioTrack (int audioIndex)

设置初始化音轨。


public void setInitialSubTrack (int subIndex)

设置初始化字幕。


public native void setSubShown (boolean shown)

设置是否显示字幕。

shown true 表示显示字幕


public native void setSubEncoding (String encoding)

设置字幕编码。

encoding 字幕编码。如果为 null 将自动检测。


public native int getSubLocation ()

获取字幕位置类型。0为内嵌字幕,1为外挂字幕。


public native void setSubPath (String subPath)

设置外挂字幕路径。必须是本地文件路径。


public native String getSubPath ()

获取外挂字幕路径。


public native void setSubTrack (int trackId)

设置字幕编号。必须是 getSubTrackMap 的返回值。


public native int getSubTrack ()

获取字幕编号。


public HashMap<String, Integer> getSubTrackMap (String encoding)

获取视频内嵌字幕集合。

encoding 格式化字符串编码。如果为 null 将自动检测。

返回字幕名称和字幕编号组成的Map。


受保护方法

protected void finalize()

调用了native_finalize。



MediaPlayer 内部接口

官方网址: http://vov.io/vitamio/

整理:农民伯伯


public interface OnBufferingUpdateListener

void onBufferingUpdate (MediaPlayer mp, int percent)

更新流媒体缓存状态。

参数

mp

percent



public interface OnErrorListener

boolean onError (MediaPlayer mp, int what, int extra)

错误信息。

参数

mp

what

extra

返回值

如果处理了错误返回true,否则返回false。返回false或没有设置OnErrorListener将引发OnCompletionListener被调用。



public interface OnInfoListener

boolean onInfo (MediaPlayer mp, int what, int extra)

信息或警告。

参数

mp

what

extra

返回值

如果处理了错误返回true,否则返回false。返回false或没有设置OnInfoListener将丢弃信息或警告。



public interface OnSubtitleUpdateListener

public void onSubtitleUpdate (String text)

需要显示文字字幕。


public void onSubtitleUpdate (byte[] pixels, int width, int height)

需要显示图片字幕。

参数

pixels

width

height

 

 

~~~~~~~~~~~~~~ 


本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
AVI视频压缩软件《WisMencoder》使用方法
C++编码规范之格式
iOS 音频前处理
Flash AS3.0 资料之声音(一)
DrawDib函数
视频技术中如何处理花屏卡顿问题?附Python代码举例
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服