danmu-client弹幕客户端

联合创作 · 2023-09-29 19:28

danmu-client 是一个独立的弹幕客户端,其服务端项目见danmu-server,其基于项目DDPlayer所完善。

功能特色

  • 以WebSocket作为通讯协议,用Canvas作为弹幕的画布。
  • 可在桌面任何位置显示弹幕,可与其他程序共同工作。
  • 窗口置于最前,完全透明可穿透,用户可用键鼠等与其他程序正常交互。
  • 提供紧急清空弹幕池、停止接收弹幕等功能。

直接启动程序

目前仅有Windows x86版本可用。

  1. 打开Release下载已经编译好的程序包并解压到某目录。
  2. 双击目录下的danmu,启动成功。

源代码部署说明

  1. 下载并安装Nodejsiojs,同时需要安装Visual Studio以便编译C++组件。
  2. 命令行切换到工程目录下,执行npm install,等待自动下载和编译组件。(如果不想通过npm下载nw,可以在package.json里去掉nw再将其手动拷贝到工程目录下)。
  3. 执行nw,启动成功。

调试工具打开说明

对于已编译的程序,你可以打开命令提示符输入danmu --remote-debugging-port=9222`;

对于源代码部署,可输入npm run debug。然后打开http://127.0.0.1:9222/即可开始调试。

发布说明(Windows x86 + x64)

  1. 下载nw-penetrate的编译版本,分别解压到cache\node_modules\系统版本(win32或win64)\nw-penetrate\build\Release目录下。
  2. 下载rid,将其放到环境变量定义之处,或直接拷贝到项目根目录下。
  3. 执行grunt。
  4. 用各种PE信息修改工具修改文件属性即可(如Visual Studio)。

配置说明

根目录config.js下有配置,以下是说明

socket: {
    url: "弹幕服务器开启的IP与端口(如使用反代,需要确认反代支持WebSocket连接)",
    password: "弹幕服务器连接密码",
    room: "选择连接弹幕服务器的某间房间",
    heartbeat: 心跳包发送间隔
},
display: {
    comment: {
        animationStyle: "默认弹幕样式(支持scroll、reversescroll、staticdown、staticup)",
        fontStyle: "默认字体样式",
        fontColor: "默认颜色",
        lifeTime: 每条弹幕的基本存活时间,
        height: 每条弹幕占据高度
    }, 
    image: 图片弹幕开关
}, 
image: {
    regex: 图片判断正则,勿动
    whitelist: [
        "图片弹幕允许加载的网络图片白名单。", 
        "不支持通配符,必须一条一条手动添加。", 
        "请确认图片可以正常被打开。"
    ]
}

图片弹幕

打开图片弹幕开关后,弹幕内含相关内容的将被解析为图片。图片必须可以正常打开,调用代码如:[IMG WIDTH=24]danmu-24.png[/IMG]。格式:[IMG WIDTH=图片宽度]图片地址(支持HTTP)[/IMG]

为了保证安全与稳定,图片弹幕有防火墙机制。只有在弹幕程序目录及子目录下存在的图片才可被加载。引用网络图片,必须手动修改config.js添加白名单规则。如果被过滤,则程序不会有任何提示,该弹幕也不会被显示。

浏览 12
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

编辑 分享
举报