linux/windows wps node.js插件对PPT状态监听并且通知其他应用

需求背景

公司要求对Window系统,和国产操作系统(UOS)的wps 软件在 PPT开始播放 结束播放,和播放中翻页 上一页 下一页 等状态进行监听,并通知到我们桌面应用。

技术方案

  • 开发WPS插件,使用node.JS 插件开发,同时支持了window / linux
  • 对WPS 消息进行监听
  • 通知到其他应用程序

实现过程

  • 开发WPS插件

这里不做过多讲解,请查看我前面的文章,wps linux node.js 加载项开发,和离线部署方案,说得比较清楚了!

这里详细说下WPS事件的监听通知到其他应用程序

按照我前面的文章(wps linux node.js 加载项开发,和离线部署方案)在创建好的目录下面,有个JS文件夹里面的ribbon.js文件函数:OnAddinLoad是启动入口,如下图所示:
OnAddinLoad函数里面我调用了自己实现的InitWebSocketRegisterCommand

  • InitWebSocket 函数代码完整实现
js 复制代码
var planWebsocket = null;
var planIP = "127.0.0.1"; // IP地址
var planPort = "9800";    // 端口号


/*
 * 摘要提示:Lv
 * 初始化websocket   
 */
function InitWebSocket() {
        if ('WebSocket' in window) {
            planWebsocket = new WebSocket('ws://'+ planIP +':' + planPort + '/PPTController'); // 通信地址
            planWebsocket.onopen = function (event) {
                console.log('建立连接');
                let sendData = {
                    "command": "getplans", "data": [{"planid": 0}]
                }
                planWebsocket.send(JSON.stringify(sendData)); // 发送获取数据的接口
            }
 
            planWebsocket.onmessage = function (event) {
                // console.log('收到消息:' + event.data)
                let data = JSON.parse(event.data);
                if (data.command == "getplans") {
                    var planData = data.data;//返回的数据
                    console.log(planData);
                } else if (data.command == "getscenes") {
                    // 其他命令
                }
            }
 
            planWebsocket.onclose = function (event) {
                console.log('连接关闭');
            }
 
            planWebsocket.onerror = function () {
                alert('websocket通信发生错误!');
            }
        } else {
            alert('该浏览器不支持websocket!');
        }
    }
  • RegisterCommand 函数代码完整实现
js 复制代码
/*
 * 摘要提示:Lv
 * 注册PPT播放状态的事件 
 */
function RegisterCommand()
{
    wps.ApiEvent.AddApiEventListener('SlideShowBegin', Application_SlideShowBegin);
    wps.ApiEvent.AddApiEventListener('SlideShowEnd', SlideShowEndCommand);
    wps.ApiEvent.AddApiEventListener('SlideShowNextSlide',SlideShowNextSlideCommand);
    wps.ApiEvent.AddApiEventListener('SlideShowOnPrevious',SlideShowOnPreviousCommand);
}

function Application_SlideShowBegin(Wn) {
    alert("开始播放");
    
    //调用SendMsg发送消息,示例:
    SendMsg("SlideShowBegin","开始播放");
}

function SlideShowEndCommand(Wn)
{
    alert("结束播放");
}

function SlideShowNextSlideCommand(Wn)
{
    alert("准备播放下一页");
}

function SlideShowOnPreviousCommand(Wn)
{
    alert("上一页");
}


function SendMsg(type,msg)
{
    let sendData = {
        "command": type, "data": msg
    }
    planWebsocket.send(JSON.stringify(sendData));
}

如上代码描述:

我在我wps 启动node.js 插件时,首先我实例化了一个WebSocket服务,且注册了ppt相关的事件回调。在回调函数内,我使用WebSocket 通信告诉其他应用程序,其他程序接收到消息后执行自身的业务。

相关推荐
小小小米粒1 小时前
NAT 模式, 仅主机模式 Host-Only ,桥接模式 Bridge
linux·服务器·网络
桌面运维家2 小时前
IDV3技术:优化Windows虚拟桌面音频体验
windows·音视频
解道Jdon5 小时前
VSCode 2026年2月更新:技能市场、CLI、钩子支持
ide·windows·git·svn·eclipse·github·visual studio
沙漏无语5 小时前
(二)TIDB搭建正式集群
linux·数据库·tidb
思麟呀5 小时前
计算机网络初步认识
linux·计算机网络
love530love5 小时前
Windows 11 源码编译 vLLM 0.16 完全指南(RTX 3090 / CUDA 12.8 / PyTorch 2.7.1)
人工智能·pytorch·windows·python·深度学习·vllm·vs 2022
浩子智控5 小时前
zynq嵌入式开发(2)—基本开发测试实例
linux·嵌入式硬件·硬件架构
闻道且行之5 小时前
Nginx 安装、做成服务及 HTTPS 配置全流程
linux·运维·nginx·https
爱上妖精的尾巴6 小时前
8-18 WPS JS宏 正则表达式-边界匹配
开发语言·javascript·正则表达式·wps·jsa
昵称只能一个月修改一次。。。6 小时前
Linux系统编程:网络编程
linux·服务器·网络