npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@realsee/vr-signals

v1.0.7

Published

vr 信号器

Downloads

101

Readme

@realsee/vr-signals

接入使用

使用 npm 包

  1. 使用 npm 安装
npm install @realsee/vr-signals
  1. 协商确认远端支持的方法和事件,写一个类型声明文件
// vr-signals-types.ts

/**
 * 声明支持的方法列表,方便 IDE 做代码提示
 */
export type ActionMap = {
  'tag.changeData': (arg: { id: string; title: string; description: string }) => void
  'monitor.open': (arg: { id: string }) => void
  'monitor.close': (arg: { id: string }) => void
}

/**
 * 声明支持的事件列表,方便 IDE 做代码提示
 */
export type EventMap = {
  'tag.click': (data: {
    id: string
    data: {
      /** 标签 id */
      id: string
      /** 标签标题 */
      title: string
      /** 标签描述 */
      description: string
      /** 标签类型 */
      type: string
      /** 扩展字段 */
      extraData: string
    }
  }) => void
  'monitor.open': (data: {
    id: string
    data: {
      /** 监控 id */
      id: string
      /** 监控名称 */
      name: string
      /** 监控视频地址 */
      videoSrc: string
      /** 监控类型 */
      type: string
      /** 扩展字段 */
      extraData: string
    }
  }) => void
  'monitor.close': (data: {
    id: string
    data: {
      /** 监控 id */
      id: string
      /** 监控名称 */
      name: string
      /** 监控视频地址 */
      videoSrc: string
      /** 监控类型 */
      type: string
      /** 扩展字段 */
      extraData: string
    }
  }) => void
  'overlay.visible': (data: { visible: boolean }) => void
}
  1. 客户端 引入使用(接收 VR 的事件与向 VR 发送请求指令)
// 引入 RealseeVRSignalsClient 类
import { RealseeVRSignalsClient } from '@realsee/vr-signals'
// 引入 ActionMap 和 EventMap 类型声明
import type { ActionMap, EventMap } from './vr-signals-types'

// 创建 RealseeVRSignalsClient 实例
const vrSignalsClient = new RealseeVRSignalsClient<ActionMap, EventMap>({
  // 请将下面的 vrLink 替换为您的 VR 链接
  vrLink: 'xxxx',
  // 传入 iframe 元素
  element: document.getElementById('iframe'),
  // 传入日志级别,可选值为 DEBUG、INFO、WARN、ERROR、NONE,不传则默认无日志,日志会在控制台直接输出
  logLevel: 'DEBUG',
  // 传入握手重试次数,默认 10 次,如果设置为 0,则不重试。每次握手间隔 1000ms
  shakehandRetryTimes: 10,
})

// 声明一个标签点击事件回调
const onTagClick: EventMap['tag.click'] = (data) => {
  console.log('tag.click', data)
}

// 在 vrSignalsClient 初始化完成后执行
vrSignalsClient.onReady(async () => {
  // 注册标签点击事件
  vrSignalsClient.on('tag.click', onTagClick)

  // 取消注册标签点击事件
  vrSignalsClient.off('tag.click', onTagClick)

  // 注册标签点击事件,只执行一次
  vrSignalsClient.once('tag.click', onTagClick)

  // 发送一个修改标签数据的请求
  const result = await vrSignalsClient.send('tag.changeData', {
    id: '10896811',
    title: '新标题',
    description: '新描述',
  })

  console.log('tag.changeData', result)
})
  1. 服务端 引入使用(向 Client 发送事件并接收 Client 的请求指令)
// 引入 RealseeVRSignalsRemote 类
import { RealseeVRSignalsRemote } from '@realsee/vr-signals'
// 引入 ActionMap 和 EventMap 类型声明
import type { ActionMap, EventMap } from './vr-signals-types'

// 处理 actionMap 的函数映射

const actionMap: ActionMap = {
  'tag.changeData': (arg) => {
    console.log('tag.changeData', arg)
  },
  'monitor.open': (arg) => {
    console.log('monitor.open', arg)
  },
  'monitor.close': (arg) => {
    console.log('monitor.close', arg)
  },
}

// 创建 RealseeVRSignalsRemote 实例
const vrSignalsRemote = new RealseeVRSignalsRemote<ActionMap, EventMap>({
  // 传入日志级别,可选值为 DEBUG、INFO、WARN、ERROR、NONE,不传则默认无日志,日志会在控制台直接输出
  logLevel: 'DEBUG',
  // 传入 actionMap
  actionMap,
})

// 下面的代码是模拟接收到 VR 信号的事件,实际使用时请根据实际情况调用
vrSignalsRemote.sendEevent('tag.click', {
  id: '10896811',
  data: {
    id: '10896811',
    title: '标题',
    description: '描述',
    type: '类型',
    extraData: '扩展字段',
  },
})

API

RealseeVRSignalsClient

构造函数

new RealseeVRSignalsClient(options: {
  vrLink: string, // VR 链接
  element: HTMLElement, // iframe 元素
  logLevel?: 'DEBUG' | 'INFO' | 'WARN' | 'ERROR' | 'NONE', // 日志级别
})

实例方法

onReady

当 VR 信号准备就绪时触发

onReady(callback: () => void)
on

监听 VR 信号事件

on(eventName: string, callback: (data: any) => void)
off

取消监听 VR 信号事件

off(eventName: string, callback: (data: any) => void)
once

监听 VR 信号事件,只执行一次

once(eventName: string, callback: (data: any) => void)
send

调用 VR 信号方法

send(methodName: string, data: any)

实例属性

logLevel

日志级别

logLevel = 'DEBUG' | 'INFO' | 'WARN' | 'ERROR' | 'NONE'

RealseeVRSignalsRemote

构造函数

new RealseeVRSignalsRemote(options: {
  logLevel?: 'DEBUG' | 'INFO' | 'WARN' | 'ERROR' | 'NONE', // 日志级别
  actionMap: ActionMap, // 方法映射
})

实例方法

sendEevent

发送 VR 信号事件

sendEevent(eventName: string, data: any)

实例属性

logLevel

日志级别

logLevel = 'DEBUG' | 'INFO' | 'WARN' | 'ERROR' | 'NONE'

从 0.x 迁移

API 变更

  • 移除 RealseeVRSignals 类,改为 RealseeVRSignalsClientRealseeVRSignalsRemote 两个类,分别用于客户端和服务端
  • 移除 SDK 里的 方法和事件的类型声明,改为由用户自行声明
  • 原有的 onEventoffEventonceEvent 方法改为 onoffonce 方法

代码变更

  • 从 0.x 迁移时,需要将原有的 RealseeVRSignals 类的实例改为 RealseeVRSignalsClientRealseeVRSignalsRemote 类的实例
  • 将原有的 onEventoffEventonceEvent 方法改为 onoffonce 方法
  • 原有的 send 方法保持不变,不需要变更
  • 原有的 logLevel 属性保持不变,不需要变更

License

See the LICENSE file for license rights and limitations.