biliLive – B站直播录播一站式处理工具
biliLive-tools 是一款专为 B 站录播设计的多功能工具,它集弹幕转换、视频压制和上传至 B 站于一体,同时兼容录播姬与 blrec 的 webhook 功能。如果您是录播爱好者,正在寻找能够将 xml 格式弹幕转换、压制弹幕并上传的工具,或者您是视频剪辑师,需要一个下载 B 站视频的利器,又或者您已经厌倦了 B 站繁琐的多片段上传流程,那么 bililive-tools 将是您的不二之选。我们开发这款工具的初衷是为了解决录播工具的分散性问题,以往处理一场包含弹幕的完整录播往往需要多个软件的协同工作,而且部分工具仅提供命令行界面(CLI),这无疑增加了使用的复杂度。现在,有了 bililive-tools,一切变得简单便捷。
截图
特色
- 支持录播姬与blrec的webhook自动化处理
- 支持 Danmufactory GUI 弹幕xml转换
- 支持根据弹幕切片
- 支持b站分P投稿
- 支持视频与弹幕压制
- 支持 ffmpeg 转码及转封装
- 支持B站视频下载
- 支持斗鱼录播及其弹幕下载
下载
不提供 MacOS 安装包,需要的可以自行编译,编译时需要替换用到的二进制文件。
由于我不在Linux开发,测试覆盖不光,如果存在问题可以提issue。
CLI的使用参考文档
下载地址:https://github.com/renmu123/biliLive-tools/releases
备用:https://www.alipan.com/s/iRyhxjdqGeL
功能
断播续传
这个功能主要用于解决:由于网络或者设置分段原因导致录播片段被切割成多个。
开启后,会将主播的一场直播上传到同一个视频中
一场直播的定义:同一个主播,本次文件创建时间与上一个文件结束写入时间如果相差n分钟(使用配置),那么会被定义为一场直播,不会使用webhook中比如录播姬的session定义。
开启录制后,或反复切换开关,可能会有奇怪的错误。
如果出现bug,将设置中的日志等级调整为debug
后复现然后进行反馈。
xml弹幕转换
xml弹幕转换底层使用DanmakuFactory,B站弹幕确认可以使用,其余类型请自行测试。
部分功能如自适应分辨率
切片功能
用于局部渲染带有弹幕的视频,支持lossless-cut项目导入
支持哪些快捷键:
ctrl+s
保存到llc项目ctrl+shift+s
另存为llc项目ctrl+enter
导出ctrl+z
撤销ctrl+shift+z
重做I
在当前时间开始当前片段O
在当前时间结束当前片段up
上一个片段down
下一个片段del
删除片段space
播放/暂停ctrl+left
后退1秒ctrl+right
前进1秒ctrl+k
切换视图
通知功能
使用通知功能时,请妥善保存所有信息,请勿分享给他人,本软件不会发送任何信息到任何服务器
邮箱
使用smtp服务来发送邮件,每个邮件服务商的参数各不相同,使用请自行参照各服务商的教程。
server酱
serer酱支持免费推送信息到手机微信,免费账户有限制。
tg bot
使用tg bot发送信息时默认使用系统代理。
tg bot 的搭建请自行寻找教程
ntfy
自定义Webhook
如果想接入webhook相关功能,你可以自行构造参数并调用接口,采用post
方法,端口为/webhook/custom
,接收后立刻返回http code=200。
参数: event
: FileClosed
|FileOpening
(如果你想使用断播续传功能,请在上一个FileClosed
事件后在设置的时间间隔内发送FileOpening
事件)
filePath
: 视频文件的绝对路径 coverPath
: 视频封面的绝对路径,如果为空,会读取与视频文件名相同的后缀为jpg
的文件,支持为空
danmuPath
: 视频弹幕xml
文件,如果为空,会读取与视频文件名相同的xml
文件,支持为空
roomId
: 数字类型,房间号,用于断播续传
time
: 用于标题格式化的时间,示例:"2021-05-14T17:52:54.946"
title
: 标题,用于格式化视频标题
username
:主播名称,用于格式化视频标题
以下参数用于弹幕分析功能,非必要 有些弹幕中存在元数据(参考blrec)的会被自动解析,比如弹幕姬或blrec或douyu-cli(0.6.1及以上)生成的弹幕 platform
:平台,如果是b站推荐为bilibili
,斗鱼推荐为douyu
,其实填啥都可以
live_start_time
:直播开始时间,示例:"2021-05-14T17:52:54.946" live_title
:直播标题
示例:
curl --location 'http://127.0.0.1:18010/webhook/custom' \
--header 'Content-Type: application/json' \
--data '{
"event":"FileClosed",
"filePath":"D:\\aa.mp4",
"coverPath":"D:\\aa.jpg",
"danmuPath":"D:\\aa.xml",
"roomId":93589,
"time":"2021-05-14T17:52:54.946",
"title":"我是猪",
"username":"djw"
}'
CLI的使用
你可以使用二进制文件或者使用 npm i bililive-cli -g
进行安装。
具体文档参考页面
常见问题
Webhook标题模板引擎如何使用
1.5.0起 Webhook 标题支持ejs模板引擎,具体语法参考文档,如果标题超过80字,会被自动截断,会优先执行模板引擎,之后会对{{}}
占位符进行替换,如果有语法错误,会被跳过,优先保证上传。
// 以下为支持注入的参数
{
title: string; // 直播间标题
user: string; // 主播名称
time: Date; // 直播开始时间
roomId: number | string; // 房间号
}
示例:<%= user %>-<%= time.getFullYear() %><%= String(time.getMonth() + 1).padStart(2, "0") %>直播录像
渲染结果:djw-202408直播录像
压制预设如何设置
如果你是一个小白,先根据自己的硬件选择对应的编码,推荐使用crf或cq等质量模式的默认参数,压制后查看视频大小,压制时间,画质,接下来调整参数,以满足你的需求,没有最好的参数,只有最合适的参数,不同视频,不同场景可能合适的参数都不一致。
进阶请自行搜索ffmpeg相关的教程
nvnec或其他硬件转码无法正常使用
请尝试更新显卡驱动,如果更新到最新后还无法使用,请尝试手动更换ffmpeg可执行文件为6.0,或使用1.0.0以下版本
blrec的webhook事件如何设置
依赖于“视频文件创建”,“视频文件完成”两个webhhook,建议直接勾选全部事件。
blrec开启转换为mp4后无法使用
请关闭该功能,使用本软件的“转封装为mp4”功能
有时上传和下载任务点击暂停无效
上传任务分为三个阶段,只有第二个阶段是支持暂停的:
- 获取上传基础信息
- 文件切片上传
- 文件合并,调用提交接口
下载任务分为三个阶段,只有第二个阶段是支持暂停的:
- 获取下载文件基础信息
- 文件切片下载
- 文件合并
投稿后自动评论未生效
该功能会每隔十分钟会查询一次投稿中心的前20个稿件,如果为本软件投稿且开启了自动评论的已审核非续传稿件,会进行自动评论,如果一个稿件24小时内状态不为审核通过,那么这个稿件将被移出队列。
如果你的稿件不为以上情况却未进行投稿,请提issue
怎么评估压制的速度
进入队列,查看任务最后一栏的速率,可以根据速率调整压制参数
如何查看原始ffmpeg命令输出
压制之后查看log
最大任务数
- 目前支持ffmepg任务和斗鱼视频下载最大任务数,可以在“设置-任务-ffmpeg最大任务数”中进行设置,默认为不限制
- 手动暂停的任务不会被自动启动
- 高能进度条任务会自动进行,因为速度会很快
使用zip包后安装包无法使用
zip包并非传统意义上的绿色包,数据和安装包文件的不会存放在同一个文件夹中,如果你尝试使用安装包后使用压缩包,可能会导致二进制文件的路径错误从而无法使用,请尝试在设置中手动修改二进制文件路径。
如果你想将数据放在同一个文件夹内,请在可执行文件所在文件夹创建一个portable文件,无拓展名如.txt,更改后重启应用,如有需要可以新建文件前在设置中备份设置。
更改webhook部分配置不生效
请不要在直播开始后修改相应的配置,比如标题,断播续传等配置,本场直播可能并不会生效
共有 0 条评论