video.md 3.5 KB
Newer Older
D
DCloud_LXH 已提交
1 2 3 4
## video

<!-- UTSCOMJSON.video.description -->

D
DCloud_LXH 已提交
5 6
<!-- UTSCOMJSON.video.compatibility -->

7
<!-- UTSCOMJSON.video.attribute -->
D
DCloud_LXH 已提交
8 9 10 11 12

<!-- UTSCOMJSON.video.event -->

<!-- UTSCOMJSON.video.component_type -->

DCloud-yyl's avatar
DCloud-yyl 已提交
13 14

### 视频格式  
W
wanganxp 已提交
15 16 17
web端支持的视频格式,不同浏览器有差异,可查询caniuse。

app端支持的视频格式如下:
D
DCloud_LXH 已提交
18 19 20
- [x] mp4
- [x] m4v
- [x] mov
lizhongyi_'s avatar
lizhongyi_ 已提交
21
- [x] webm (安卓端支持,iOS端不支持)
D
DCloud_LXH 已提交
22 23
- [x] 3gp
- [x] flv
lizhongyi_'s avatar
lizhongyi_ 已提交
24
- [x] m3u8 (本地m3u8文件安卓端需3.99+,iOS端需4.11+)
D
DCloud_LXH 已提交
25

DCloud-yyl's avatar
DCloud-yyl 已提交
26 27 28 29 30 31 32 33 34
### src路径支持说明  
- 本地路径/static方式  
	由于uni-app/uni-app x编译时,只把/static目录下的静态资源copy到app中,所以src均需指向/static目录下。  
	其他目录的视频文件由于不会被打包进去,所以无法访问。  
	app平台文件路径会存在大小写敏感问题,为了有更好的兼容性,建议统一按大小写敏感原则处理 [详情](../api/file-system-spec.md#casesensitive)  

- 支持网络路径  
	网络媒体 http、https协议  
	流媒体 rtmp/hls/rtsp 协议  
D
DCloud_LXH 已提交
35

DCloud-yyl's avatar
DCloud-yyl 已提交
36
### app平台组件实现  
D
DCloud_LXH 已提交
37 38 39 40
App-Android平台video组件使用ijkplayer库实现:[https://github.com/bilibili/ijkplayer](https://github.com/bilibili/ijkplayer)

弹幕功能使用DanmakuFlameMaster库实现:[https://github.com/bilibili/DanmakuFlameMaster](https://github.com/bilibili/DanmakuFlameMaster)

W
wanganxp 已提交
41
ijkplayer库底层又使用了ffmpeg,这些库的功能较多,官方的video组件并非完全封装。有需要的开发者可以使用uts直接操作这些库。插件市场已经有一批uts库直接调用该库,[见插件市场](https://ext.dcloud.net.cn/search?q=ffmpeg&orderBy=Relevance&uni-appx=1)
D
DCloud_LXH 已提交
42 43 44

video组件的源码[详见](https://gitcode.net/dcloud/uni-component/-/tree/master/uni_modules/uni-video)。下载该uni_modules到工程下,修改源码打包,可覆盖内置的video组件。

W
wanganxp 已提交
45
另外ijkplayer作为一个开源库,比腾讯视频等商业sdk仍有差距。如无法在开源库上满足需求,可在插件市场寻找腾讯视频等商业sdk插件:[见插件市场](https://ext.dcloud.net.cn/search?q=%E8%85%BE%E8%AE%AF%E8%A7%86%E9%A2%91&orderBy=Relevance&cat1=5&cat2=51)[阿里云视频](https://ext.dcloud.net.cn/search?q=%E9%98%BF%E9%87%8C%E4%BA%91%E8%A7%86%E9%A2%91&orderBy=Relevance&cat1=5&cat2=51)
D
DCloud_LXH 已提交
46 47

<!-- UTSCOMJSON.video.children -->
48 49

- 4.25版本起,App-Android平台支持子组件。
D
DCloud_LXH 已提交
50 51 52 53 54 55 56

### 上下文对象API

video的操作api为[uni.createVideoContext()](../api/create-video-context.md)

给video组件设一个id属性,将id的值传入uni.createVideoContext(),即可得到video组件的上下文对象,进一步可使用`.play()``.stop()`等方法。

57 58
<!-- UTSCOMJSON.video.example -->

D
DCloud_LXH 已提交
59 60
<!-- UTSCOMJSON.video.reference -->

DCloud-yyl's avatar
DCloud-yyl 已提交
61 62
### Bug & Tips@tips  
- app平台暂不支持横屏全屏后放置子组件
D
DCloud_LXH 已提交
63
- 标准运行基座默认不包含intel x86 cpu的兼容so库,所以video组件在标准基座运行时无法在x86 cpu的设备上运行(常见于模拟器)。如需支持x86 cpu,请在manifest里配置`abiFilters`,打包或自定义基座后生效 [详见](https://uniapp.dcloud.net.cn/uni-app-x/manifest.html#android)
W
wanganxp 已提交
64 65
- App默认拦截触摸事件,目前会导致父组件无法响应触摸事件
- video 默认宽度为300px,高度为225px。(App平台从 uni-app x 4.0起支持该默认宽高)
W
wanganxp 已提交
66 67 68 69 70

#### 本地文件播放
本地视频文件,有2种方式:
- static目录下(项目下或uni_modules下都支持static目录)
- 使用绝对路径。相对路径转绝对路径[详见](https://doc.dcloud.net.cn/uni-app-x/uts/utsandroid.html#convert2absfullpath)