目前HTML5技术已渐渐成为主流,主流的浏览器都已支持HTML5。越来越多的应用使用了HTML5的元素,如canvas、video等,另外网页存储功能更增加了用户的网络体验,使得越来越多的开发者在使用这样的标准,所以我们也需要学习如何使用自动化技术来测试它们。
WebDriver支持在指定的浏览器上测试HTML5,另外,我们还可以使用JavaScript来测试这些功能,这样就可以在任何浏览器上测试HTML5了。
大多数浏览器使用控件(如Flash)来播放视频,但是,不同的浏览器需要使用不同的插件。HTML5定义了一个新的元素<video>,指定了一个标准的方式来嵌入电影片段,IE9+、Firefox、Opera、Chrome都支持该元素。
代码如下图:
JavaScript函数有个内置的对象叫做arguments。Arguments对象包含了函数调用的参数组,[0]表示取对象的第一个值。
currentSrc熟悉返回当前音频/视频的URL。如果未设置音频/视频,则返回空字符串。Load()、play()、pause()等控制着视频的加载、播放、暂停。
视频采集和管理是多模态大数据应用场景必不可少的环节,在基于Vue2前端框架实现的Web界面如何进行视频的展示和播放是开发人员会遇到的一个主要技术问题。本文提供基于Vue2+video.js实现视频的预览的方案。
采集的视频数据在前端视频管理模块列表中展示,然后用弹窗查看视频详情并预览播放。最开始使用 vue-mini-player 组件,可轻松实现视频在编辑界面的弹窗中播放,但是遇到两个问题:1)弹窗中播放着视频,关闭窗口后,视频流不会停止。2)关闭窗口,重新打开新的视频编辑窗口后,依旧是继续播放之前的视频。其原因应该是关闭旧的窗口后,视频播放的控件没有销毁,导致新打开的控件其实还是旧控件的实例。查了很多关于vue-mini-player的文档和使用样例,没有找到如何销毁vue-mini-player控件。
视频列表
单条视频数据编辑界面
video.js 是一个通用的可嵌入网页的视频播放器JS库,在Vue2中引用video.js可以创建播放组件对象,关闭视频时能进行操作。基于Vue2使用video.js方法如下。
npm install video.js@6.13.0
import videoJs from 'video.js'
import 'video.js/dist/video-js.css'
Vue.prototype.videoJs = videoJs //注册
创建<video>组件,可放在弹窗中任何需要的地方。重点是给出id值,设置属性时需要用到。
<template>
<el-dialog :title="title" :visible.sync="open" width="900px" append-to-body>
<video id="casvideoplayer" ref="videoPlayerRef" class="video-js">
<source :src="playUrl" type="video/mp4">
</video>
...
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm">确 定</el-button>
<el-button @click="cancel">取 消</el-button>
</div>
</el-dialog>
</template>
export default {
data() {
return {
// 使用video.js播放视频配置
videoJsPlayer: null,
playUrl:"", //视频文件链接
videoPlayerOption: {
controls: true, //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
// url: "", //要嵌入的视频资源url(不起作用?)
poster: '', //封面
autoplay: false, //自动播放属性, true/false/"muted"(静音播放)
muted: false, //静音播放
preload: 'none', //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
fluid: false, //是否自适应布局,播放器将会有流体体积。换句话说,它将缩放以适应容器。
width: "850px", //视频播放器的显示宽度(以像素为单位)(fluid=false时起作用)
height: "600px", //视频播放器的显示高度(以像素为单位)(fluid=false时起作用)
},
};
methods: {
// 视频列表的“修改”按钮,点击后显示修改弹窗
handleUpdate(row) {
// 从后台获取视频信息
getVedio(row.id).then(response => {
this.form = response.data; //修改弹窗其他字段信息赋值
this.title = "修改视频管理";
this.open = true; // 显示修改弹窗
// video.js组件播放视频
this.videoPlayerOption.poster = response.data.avator;
this.playUrl = response.data.contentsOrg;
this.showVideoWindow(); //设置视频播放控件
});
},
//(重点是这里)
// 使用video.js组件播放视频
showVideoWindow(){
// 如果视频播放控件已经存在,切换视频url,重新播放;如果控件不存在,创建
if(this.videoJsPlayer){
this.videoJsPlayer.src([
{
src: this.playUrl,
type: "video/mp4"
}
]);
// 如何图片不为空,设置视频封面
if(this.videoPlayerOption.poster != null && this.videoPlayerOption.poster != ""){
this.videoJsPlayer.poster(this.videoPlayerOption.poster);
}
this.videoJsPlayer.load(this.playUrl);
// this.videoJsPlayer.play(); //自动播放(打开后,切换视频后需自动播放)
}else{
// 最开始创建一次视频播放组件
this.$nextTick(() => {
this.videoJsPlayer = this.videoJs(
"casvideoplayer", //播放器控件id
this.videoPlayerOption //播放器设置项(这里设置的poster属性不生效,需要在后面单独设置)
);
this.videoJsPlayer.poster(this.videoPlayerOption.poster); //貌似不生效?
})
}
},
// 编辑弹窗页面的“取消”按钮
cancel() {
// 重置视频控件数据(video.js组件)
if(this.videoJsPlayer){
this.videoJsPlayer.reset();
}
this.reset();
},
}
以上代码实现了在Vue2弹窗中播放视频组件的功能,注意关闭弹窗时要使用“取消”按钮。如果通过点击弹窗右上角X关闭弹窗,视频还可以在后台继续播放,但是打开一个新的视频修改弹窗后,播放的视频会终止,并切换到新视频播放界面。即使这样,目前的功能已经不影响用户正常使用。
video.js还有一个强大功能,看到喜欢的画面点击右键可以保存视频帧,另外支持画中画、设备投放等功能。
video.js右键功能
后续优化改进工作包括:1)把video.js视频播放功能做成Vue组件,方便在不同的Vue代码文件中调用。2)捕获窗口关闭的事件(如点击X关闭,或者鼠标失焦点后关闭),关闭视频流。
video.js
Vue
【参考材料】
video.js官方网站:https://videojs.com/
其他编码材料:
https://blog.csdn.net/qq_60533482/article/details/128015308
https://blog.csdn.net/Uookic/article/details/116131535
https://www.cnblogs.com/DL-CODER/p/16833222.html
Qt中,可以使用QWebEngineView来嵌入Web内容。然而,QWebEngineView不直接支持播放MP4视频。要在Qt中播放MP4视频,你可以考虑以下几种方法:
1. 使用HTML5的video标签:创建一个HTML页面,通过video标签将MP4视频嵌入其中,然后使用QWebEngineView加载该HTML页面。
```cpp
QUrl url("path_to_your_html_page.html");
webEngineView->load(url);
```
2. 使用JavaScript和HTML5的Video对象:通过执行JavaScript代码,在QWebEngineView中动态创建Video对象,并设置其属性和事件监听器。
```cpp
QString javascriptCode = "\
var video = document.createElement('video'); \
video.src = 'path_to_your_video.mp4'; \
document.body.appendChild(video); \
";
webEngineView->page()->runJavaScript(javascriptCode);
```
3. 使用第三方的JavaScript库:例如Video.js、jPlayer等,这些库提供了更多的功能和样式定制选项。你可以在HTML页面中引入这些库并使用其API进行视频播放控制。
无论哪种方法,确保你已经将必要的MP4文件路径正确设置,并根据需要调整其他参数(如宽度、高度、自动播放等)。
*请认真填写需求信息,我们会在24小时内与您取得联系。