智能综窗业务和设计介绍

本贴最后更新于 509 天前,其中的信息可能已经沧海桑田

智能综窗系统

业务介绍

该系统对接的金赋机器硬件。主要用于市民之家中给群众自行办理政务相关事项使用。其中包含的功能主要有:

  1. 市民之家简介。
  2. 视频客服坐席。
  3. 办件进度查询。
  4. 单事项专题办理。
  5. 用户登录(小程序登录,人脸登录,身份证登录)三种方式。

为方便群众办理业务,系统采用了上下屏交互设计。下屏主要进行业务相关的办理功能,上屏实时的对当前进行的业务进行各种引导提示。

image.png

image.png

代码设计

简介

该项目使用的 vue3 开发的单页面应用。为能管理上下屏的交互通信,采用了 lsbridge 插件来进行页签间的通信。上下屏的业务通过路由进行管理,再开发阶段可以再浏览器分别开启上屏和下屏的路由地址进行相应的开发调试工作。

代码介绍

上屏代码均管理在 /upper 路由的 upper 目录下,view 目录中的其余内容为下屏业务代码。

image.png

主要介绍下视频坐席模块,因为是金赋提供的服务(vue2 开发的插件)。没法直接已插件形式引入到我们 vue3 的项目中。所以采用的是以 iframe 嵌入的方式加入的。以蔡甸项目举例。部署路径为 :

注:视频通话需要需要使用浏览器调起麦克风和摄像头所以需要使用 https 协议才行。坐席后台管理地址:https://10.41.215.239:7005/office/#/agentSide/agentSideManager

硬件介绍

金赋的机器使用的 win7 32 位(部分为 64 位)系统。开机时硬件服务会自动启动在 5005 端口,具体接口地址为 http://127.0.0.1:5005/Device 不同硬件带上对应参数传参。

上下双屏可理解为 window 的两个屏幕。目前设置的上屏作为主屏使用(因部分本地服务如人脸摄像头,高拍仪会直接再主屏中开启窗口。接口也提供了相应的修改大小和位置的属性,如有需要可自行尝试配置)。

目前业务使用到硬件有 身份证对卡器,双目摄像头,拾音器,高拍仪,文件打印机,小票打印机。

常见问题解决方案

上下屏通信失败,无法通信

插件 lsbridge.js 中的 send 方法会过滤掉重复参数,只触发一次。解决方法是在 send 中加入一个时间戳属性,确保每次的传参不会重复。

视频坐席连接不上

先看部署地址是不是 https 的。然后是 kamfuvideo 项目中的 videoPath 需要进行配置 iterminal 服务的 https 地址image.png

因为是 vue2 的项目,部分插件都是旧版的。打包需要使用 14 版本及一下的 nodejs 安装依赖和打包。

打包成 exe 应用

最早对接时是使用的金赋的自带的容器,那时候只用部署一个 web 地址就可以了,上下屏通信也是使用的容器内部的服务,但是当时存在时不时通信无法接收到的 bug,以及容器本事运行的 chrome 浏览器版本很久才 75 版,无法升级,旧版浏览器无法打开 pdf 文件等其他浏览器兼容问题。后续版本迭代中已舍弃该方法。(介绍这个是情况是想说明为何会使用 electron 来打包以及自己加入上下屏通信,若后续金赋方面修复了相关 bug,人员在进行版本迭代时可自行抉择是否对接第三方的服务)

使用 electron 打包的 exe 文件,根据硬件不同的 win 版本,选择其对应的版本打包参数。为了避免重复打包,再生成的应用文件中加入了 nodejs 读取配置文件地址的操作,可在打包后的根目录下加入 config.json 文件

{
	url: https://10.140.41.251:89/iterminal/home ,
	url1: https://10.140.41.251:89/iterminal/upper
}

配置后 exe 在打开时会按设定的屏幕位置自动开启配置中的两个浏览器页签应用。

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...