雅荷心语博客
雅荷心语
心之所向便是光
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 关注本站
    • 微信
    • 微博
    • 腾讯微博
    • Twitter
    • Facebook
    • RSS订阅
Hi, 请登录     我要注册     找回密码

如何将无头浏览器的操作录制为视频

2023-11-29 分类:前端之旅 阅读(877) 评论(0)

之前一直使用 puppeteer 来进行一些业务操作, 但是近期因为需要将无头浏览器内部的操作录制为视频, 发现使用 puppeteer 来做有些 复杂, 要结合 ffmpeg 还要操作数据流之类的,

询问 chatGPT 发现有个更好用的自动化测试框架叫 playwright 有类似的能力,就浅浅尝试一下。

项目地址 : https://github.com/microsoft/playwright

首先我们安装一下: npm install playwright

随便写个 demo 试试

1
2
3
4
5
6
7
8
9
10
11
12
import {chromium} from "playwright";
 
(async () => {
const browser = await chromium.launch({
headless: false, // 非无头模式,方便观察录制效果
args: ['--start-fullscreen'], // 全屏模式
});
const context = await browser.newContext();
const page = await context.newPage();
await page.goto('https://www.baidu.com/');
// 进行其他操作...
})();

若是遇到异常:

node:internal/process/promises:279
triggerUncaughtException(err, true /* fromPromise */);
^

可能是依赖没安装全, 重新安装一下: npx playwright install

最终配置如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
import { chromium }  from "playwright";
import { exec } from "child_process";
(async () => {
const width = 1280;
const height = 720;
let browser = await chromium.launch({
executablePath: "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome", // 自动查找浏览器的可执行文件路径
headless: false, // 非无头模式,方便观察录制效果
args: ['--start-fullscreen'], // 全屏模式
});
const context = await browser.newContext({
viewport: { width, height }, // 设置浏览器的初始大小
recordVideo: {
dir: 'recordings/', // 视频保存目录
frameRate: 60, // 视频帧率
size: { width, height }, // 视频分辨率
outputSize: { width, height }, // 输出视频大小
videoSize: { width: 1920, height:1080 }, // 视频大小
format: 'mp4' // 指定视频格式为 MP4
}
});
const page = await context.newPage();
await page.goto('https://vr.he29.com/tour/index?id=65432d6218a3326&h=1');
setTimeout(async (_)=> {
const video = await page.video(); // 获取录制的视频对象
const videoPath = await video.path(); // 获取录制的视频文件路径
console.log('录制的视频文件路径:', videoPath);
const outMp4 = videoPath.replace('.webm', '.mp4');
const run = `/Applications/ffmpeg -i ${videoPath} ${outMp4}`;
console.log(`run`, run)
exec(run);
await browser.close();
}, 5000)
})();

 

可以正常录制到 webm 格式的视频, 后面使用 ffmpeg 转为 mp4 就可以了

不过目前录制的视频清晰度有些低,目前还没有找到好的办法

分享到:更多 ()

相关推荐

  • AI 编辑器 cursor 如何禁止自动更新
  • AI 编辑器 cursor 工具栏改成和 vscode 一样的左侧 竖向展示
  • nodejs 脚本打包为可执行文件
  • 初学 python 笔记
  • nodejs 同时运行多个脚本
  • 让你的照片动起来
  • vue工程项目动态加载umd.js实践
  • 使用 shell 检测目标服务器是否异常
关于我

小天明 北京·朝阳 前端搬砖工程师

碎碎念):(来自公众号)

热门文章

  • 踩坑记录——iphone上safari开启隐身模式时localStorage变为只读-雅荷心语博客踩坑记录——iphone上safari开启隐身模式时localStorage变为只读2017-02-21评论(4)
  • 程序员是怎样一群人-雅荷心语博客程序员是怎样一群人2015-12-08评论(3)
  • 百度你个大毒瘤 - 吐糟博客这几天打不开事情-雅荷心语博客百度你个大毒瘤 – 吐糟博客这几天打不开事情2015-12-28评论(2)
  • PHP 非对称加密 openssl 加密及解密方法-雅荷心语博客PHP 非对称加密 openssl 加密及解密方法2016-05-17评论(2)
  • PHPStorm10 下载安装破解汉化-雅荷心语博客PHPStorm10 下载安装破解汉化2015-12-15评论(2)
2025年7月
一 二 三 四 五 六 日
« 六    
 123456
78910111213
14151617181920
21222324252627
28293031  

最新评论

  • 前端小武 8年前 (2017-04-06)说:
    我看到了layer
  • 丁艳平 8年前 (2017-03-03)说:
  • Dawn 9年前 (2016-09-16)说:
    call_user_func_array最后的例子是错哦,你用bc方法去调用类里 另外一个方法就知道问题所在了。情况1.调用非静态方法 第一个参数应该传[类的实例,调用方法] (既然有类实例了直接-&
  • Dawn 9年前 (2016-06-21)说:
    tp框架设置了全局捕获异常的,这也没什么。坑的是 他捕获了异常。然后全部返回404。。。不知道的 还以为自己网站被删除了
  • Dawn 9年前 (2016-05-17)说:
    构造函数里的判断 用异常机制可能更好一些

其他类型

  • 芊云全景
  • 配音兔AI配音神器

博客类型

  • 芊云全景
  • 配音兔AI配音神器

左邻右舍

  • 易水寒
  • 楼教主
  • 芊云全景
  • 贤心
  • 配音兔AI配音神器

雅荷心语博客 -心之所向便是光

联系我们关于我们

© 2025 雅荷心语博客   网站地图