思路梳理:
H5获取本地视频的时长duration,原理就是通过input file导入文件,通过window.createObjectURL创建文件的本地url,赋值给video src,然后获取时长。
这里面有一个问题:就是只有当这个视频被播放后,js才可以获取到video资源实例,才能拿到duration。
所以就有了下面的一些操作。
html部分:
<video ref="curVideo" autoplay="autoplay" preload="metadata" webkit-playsinline="true" playsinline="true"
x-webkit-airplay="allow" x5-video-player-type="h5" x5-video-player-fullscreen="true"
x5-video-orientation="portraint" style="object-fit:fill" controls="controls" width="300"
height="300" loop="loop" >
您的浏览器不支持视频播放。
</video>
<input ref="videoRef" type="file" accept="video/*" @change="determineLengthOfVideo" preload="metadata" >
js部分:
determineLengthOfVideo() {
let _this = this;
Toast.loading({
duration: 0, // 持续展示 toast
forbidClick: true, // 禁用背景点击
message: '正在读取...'
});
// let fileTemp = file.file;
let fileTemp = this.$refs['videoRef'].files[0];
console.log('determineLengthOfVideo fileTemp', fileTemp);
let getUrl = null;
if (window.createObjectURL != undefined) { // basic
getUrl = window.createObjectURL(fileTemp);
} else if (window.URL != undefined) { // mozilla(firefox)
getUrl = window.URL.createObjectURL(fileTemp);
} else if (window.webkitURL != undefined) { // webkit or chrome
getUrl = window.webkitURL.createObjectURL(fileTemp);
}
//给 ref:curVideo 动态赋值
let curVideoDom = _this.$refs['curVideo'];
curVideoDom.src = getUrl;
curVideoDom.play();
// 轮询视频时长,得到时长后清除定时器
let hasDuration = setInterval(() => {
let curVideoDuration = _this.$refs['curVideo'].duration;
if (curVideoDuration) {
console.log('curVideoDuration', curVideoDuration);
Toast.clear();
_this.formData.curVideoDuration = curVideoDuration;
clearInterval(hasDuration);
if (curVideoDuration > 15) {
Notify({
message: '视频时长不可超过15秒',
duration: 5000
});
} else {
let temp = {
content: '',
file: fileTemp
}
//执行上传
_this.onAfterRead(temp, {
name: 'videoUpload'
});
}
}
}, 10)
}
兼容ios
为什么 IOS 下微信和钉钉可以自动播放带声音的视频?
确实发现在微信经常能看到自动播放的H5,但是作者自己写的设置了 autoplay、playsInline 的视频播放样例,在微信上依旧无法自动播放,而在钉钉上却可以自动播放
系统-浏览器 | 带声音 | 不带声音 |
IOS 钉钉 | 支持 | 支持 |
IOS Safari | 禁止 | 自动播放 |
IOS 微信 | 禁止 | 禁止 |
通过查询资料,IOS WebAPP 开发都是基于 IOS 提供的浏览器内核进行开发的
,所以在 WebAPP 的 webview 中可以修改自动播放的表现,钉钉明显是支持自动播放,微信则是禁止自动播放,但是提供了内置事件来支持自动播放:
自动播放方式1:
微信下通过 WeixinJSBridgeReady 事件进行自动播放:
//兼容微信内置浏览器 视频自动播放,用于本地视频预览
audioAutoPlay(id) {
var audio = document.getElementById(id);
audio.play();
audio.pause();
var myPlay = function() {
document.removeEventListener("WeixinJSBridgeReady", myPlay);
document.removeEventListener("YixinJSBridgeReady", myPlay);
audio.play();
audio.pause();
// document.removeEventListener("touchstart", play, false);
};
//weixin 监听到,执行play
document.addEventListener("WeixinJSBridgeReady", myPlay, false);
//yixin
document.addEventListener('YixinJSBridgeReady', myPlay, false);
// document.addEventListener("touchstart", play, false);
},
自动播放方式2:(究极办法)
<video id="netVideo"
v-show="formData.videoUrl !== ''"
:src="localVideoUrl"
controls="controls"
width="100%"
height="300px"
loop="loop"
autoplay="autoplay"
webkit-playsinline=""
playsinline=""
x-webkit-airplay="allow"
x5-video-player-type=""
x5-video-player-fullscreen="true"
x5-video-orientation="portraint"
style="background-color: #000000;">
您的浏览器不支持视频播放。
</video>
<script>
import WX from 'weixin-js-sdk';
methods: {
setWxJsSDK() {
this.$axios.post(//请求后端,获取签名)
.then(res => {
if (res.data.status === 0) {
let data = res.data.data;
WX.config({
debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: APPID, // 必填,公众号的唯一标识
timestamp: data.timestamp, // 必填,生成签名的时间戳
nonceStr: data.noncestr, // 必填,生成签名的随机串
signature: data.signature, // 必填,签名
jsApiList: [] // 必填,需要使用的JS接口列表
});
WX.ready(function() {
document.getElementById('netVideo').play();
})
}
})
.catch(err => {
console.log(err);
});
}
}
</script>