@npv3/kplayer

KPlayer,是对 “翼智家行业版” Hybrid(混合)客户端所提供的原生功能的封装。

Usage no npm install needed!

<script type="module">
  import npv3Kplayer from 'https://cdn.skypack.dev/@npv3/kplayer';
</script>

README

使用说明

KPlayer,是对 “翼智家行业版” Hybrid(混合)客户端所提供的原生功能的封装。

Hybrid客户端使用QT框架开发,使用QtWebkit/QtWebEngine提供嵌入的浏览器环境。同时,使用QtWebChannel与浏览器环境内的网页进行通讯。

Hybrid客户端提供的功能文档见《WEB客户端接口》,KPlayer中的方法都源自于该文档,并进行了简单的封装。

安装 KPlayer

npm i @npv3/kplayer -S

创建 KPlayer

import KPlayer from '@npv3/kplayer'

// 判断网页环境是否支持 KPlayer
if(KPlayer.inQt()) {
  console.log('当前环境支持 KPlayer')
} else {
  console.log('您当前的环境不支持 KPlayer, 请使用正确的客户端打开页面,或使用浏览器支持的播放方案')
}

const player = new KPlayer({
  // 播放器依附的DOM元素
  playerEl: document.querySelect('#player'),
  // 播放器类型,live 或者 playback
  type: 'live',
  // 接收客户端消息的回调方法
  onWebChannelRecvMessage: (func, param, webChannel) => {}
})
// 等待player webChannel初始化完成
await player.webChannelInitialize()
// 播放直播地址
// player.webChannel.playPlayer(...)
// 发送消息(通用方式)
player.webChannel.sendMessage(func, param)

使用示例

// 通过QTWebChannel发送消息(通用方试)
// 如果KPlayer所封装的方法不全,可以直接使用该方法与客户端通讯,参考《WEB客户端接口》文档。
player.webChannel.sendMessage(func, param)

// 2.1, 2.8 更新播放器窗口的位置
const posRect = {
  x1: left,      // 可视区域左上角x坐标
  y1: top,       // 可视区域左上角y坐标
  x2: width,     // 可视区域宽度
  y2: height,    // 可视区域高度
  x3: realLeft,  // 真实区域左上角x坐标
  y3: realTop,   // 真实区域左上角y坐标
  x4: realWidth, // 真实区域宽度
  y4: realHeight // 真实区域高度
}
player.webChannel.setPlayerPos(posRect)

// 2.2, 2.9 直播窗口显示(或隐藏)
const show = 1 // 0
player.webChannel.setPlayerShowStatus(show)

// 2.3 直播窗口多画面分屏
const screenNum = 1
player.webChannel.setPlayerScreenNum(screenNum)

// 2.4 直播窗口全屏(或退出全屏)
const isFullScreen = 1 // 0
player.webChannel.setPlayerFullScreen(isFullScreen)

// 2.5, 2.10 播放视频直播(或回看)
// 视频直播
const params = {
  deviceId: '33010600001327270679',
  deviceName: 'test',
  control: 1, // 是否支持云台控制
  playUri: 'rtsp://183.131.55.25:30010/pssWork_2/l_194116'
}

// 视频回看
const params = {
  deviceId: '33010600001327270679',
  deviceName: 'test',
  playStartTime: '2020-10-28 16:01:49',
  playEndTime: '2020-10-28 16:11:59',
  playUri: 'rtsp://183.131.0.1/pssWork_2/l_194116'
}
player.webChannel.playPlayer(params)

// 2.6, 2.11 关闭播放器
player.webChannel.stopPlayer()

// 2.7 直播轮巡视频播放
const params = {
  "deviceInfo": [{
    "deviceId": "61fd72b02f9311eb314f25d6ae6bbe8d",
    "deviceName": "临安指南山",
    "control": 1,//是否支持云台控制
    "playUri": "rtsp://183.131.55.25:30010/pssWork_2/l_194116",
    "orgName": "杭州市西湖区", //组织架构关系
    "collect": 1 //1 收藏, 0未收藏
  }]
}
player.webChannel.playCycle(params)

// 2.12 弹出电子地图
const params = {
  emapUrl: 'http://kvideo.51iwifi.com/map/#/home'
}
player.webChannel.showEmapPage(params)