频道信息

本文档主要讲述 频道模块(channel) 提供的频道信息获取相关的 API 文档,详细内容见下文:

一、频道信息

1.1 获取频道基础信息

根据语言类型获取频道基础信息(含英文配置),如:频道名称、频道介绍、主持人名称。

Api 方法: getChannelBasicInfo(type?: LanguageType): ChannelBasicInfo

参数说明:

  • type:语言类型,LanguageType 类型,选传,默认 'zh_CN'

返回值说明: 频道基础信息,ChannelBasicInfo 类型,详细类型说明如下

属性名说明类型

title

频道标题

string

publisher

频道主持人

string

description

频道描述

string

示例:

// 获取频道的基础信息
const cnBasicInfo = watchCore.channel.getChannelBasicInfo();
console.log('频道名称', cnBasicInfo.title);
console.log('频道介绍', cnBasicInfo.description);
console.log('主持人名称', cnBasicInfo.publisher);

// 获取频道的英文基础信息
const enBasicInfo = watchCore.channel.getChannelBasicInfo('en');
console.log('英文频道名称', enBasicInfo.title);

1.2 获取频道场景

用于判断频道类型,如是否为三分屏的频道,是否为研讨会的频道

Api 方法: getChannelScene(): ChannelScene

返回值说明: ChannelScene 类型

示例:

import { ChannelScene } from '@polyv/live-watch-sdk';
const scene = watchCore.channel.getChannelScene();
const isAloneChannel = scene === ChannelScene.Alone; // 普通直播频道
const isPptChannel = scene === ChannelScene.Ppt; // 三分屏频道
const isSeminarChannel = scene === ChannelScene.Seminar; // 研讨会频道

1.3 获取当前频道的观看页地址

用于获取当前观看页的地址。

Api 方法: getChannelWatchUrl(): string

示例:

const watchUrl = watchCore.channel.getChannelWatchUrl();
console.log('当前观看页的打开地址', watchUrl);

1.4 生成观看页地址

Api 方法: generateWatchUrl(channelId: string): string

参数说明:

  • channelId:频道号,string 类型,必传

示例:

const watchUrl = watchCore.channel.generateWatchUrl('频道号');
location.href = watchUrl;

1.5 获取讲师信息

用于获取当前讲师/主播的信息。

Api 方法: getTeacherInfo(): TeacherInfoType

返回值说明: TeacherInfoType 类型

示例:

const teacherInfo = watchCore.channel.getTeacherInfo();
console.log('讲师昵称', teacherInfo.nick);
console.log('讲师头像', teacherInfo.pic);
console.log('讲师头衔', teacherInfo.actor);

1.6 获取渠道 id

通过后台设置的渠道进入观看页后,在创建观看页 SDK 实例时传入 promoteId 渠道号配置,可通过该方法获取当前观众的渠道 id,用作其他处理。

Api 方法: getPromoteId(): undefined | string

返回值说明: undefined | string 类型

示例:

import { createWatchCore } from '@polyv/live-watch-sdk';
const watchCore = createWatchCore({
  channelId: '频道号',
  promoteId: '渠道号',
});

// 需要重新获取渠道号时
const promoteId = watchCore.channel.getPromoteId();

1.7 获取频道协议配置

可以获取在不同语言下的协议配置,主要用于授权类业务

Api 方法: getChannelAgreementConfig(): Promise<ChannelAgreementConfig>

返回值说明: Promise<ChannelAgreementConfig> 类型

示例:

const agreementConfig = await watchCore.channel.getChannelAgreementConfig();
console.log('当前语言的协议配置', agreementConfig["zh_CN"]);

二、直播状态

2.1 频道直播状态

Enum 枚举: LiveStatus

常量枚举成员说明

'live'

LiveStatus.Live

直播中

'waiting'

LiveStatus.Waiting

等待中

'end'

LiveStatus.End

已结束,无直播

'playback'

LiveStatus.Playback

回放中

'stop'

LiveStatus.Stop

直播暂停中

'unStart'

LiveStatus.UnStart

未开始

2.2 直播状态改变事件

说明: 当主播开始/结束直播后,频道的直播状态都会改变,通过该事件监听直播状态改变

Event 事件: ChannelEvents.LiveStatusChange

回调参数: Object 对象,详细类型说明如下

属性名说明类型

liveStatus

新的直播状态

LiveStatus

示例:

watchCore.channel.eventEmitter.on(ChannelEvents.LiveStatusChange, (data) => {
  console.log('频道状态改变,新状态:', data.liveStatus);
});

2.3 获取频道直播状态

用于获取频道当前的直播状态,通过 ChannelEvents.LiveStatusChange 事件监听直播状态更改事件。

Api 方法: getLiveStatus(): LiveStatus

返回值说明: LiveStatus 类型

示例:

import { LiveStatus } from '@polyv/live-watch-sdk';

watchCore.channel.eventEmitter.on(ChannelEvents.LiveStatusChange, () => {
  const liveStatus = watchCore.channel.getLiveStatus();
  console.log('是否正在直播', liveStatus === LiveStatus.Live);
});

2.4 场次号改变事件

说明: 主播开次新的一次直播后,都会生成一个新的直播场次号,可以通过频道模块的该事件监听直播场次号改变。

Event 事件: ChannelEvents.SessionIdChange

回调参数: Object 对象,详细类型说明如下

属性名说明类型

sessionId

新的场次号

string

示例:

watchCore.channel.eventEmitter.on(ChannelEvents.LiveStatusChange, (data) => {
  console.log('频道状态改变,新状态:', data.liveStatus);
});

2.5 获取频道直播场次号

通过 getCurrentSessionId 方法获取当前频道的最新场次号。

Api 方法: getCurrentSessionId(): string

返回值说明: 最新场次号

示例:

const currentSessionId = watchCore.channel.getCurrentSessionId();
console.log('频道最新场次号', currentSessionId);

2.6 关闭直播状态轮训

需要和 watchCore.channel.startLiveStatusPolling 方法配合使用

Api 方法: removeLiveStatusPolling(pollingId: string): void

参数说明:

  • pollingId:轮训 id,string 类型,必传

示例:

const watchCore = getWatchCore();
const pollingId = watchCore.channel.startLiveStatusPolling();
watchCore.channel.removeLiveStatusPolling(pollingId);

2.7 开始直播状态轮训

会根据后端配置,在条件允许的情况下进行直播状态轮询

Api 方法: startLiveStatusPolling(pollingId?: string): string

参数说明:

  • pollingId:轮训 id,string 类型,选传,默认 ...

返回值说明: 轮询标识位,可用作移除轮询的参数

示例:

const watchCore = getWatchCore();
const pollingId = watchCore.channel.startLiveStatusPolling();
console.info('轮询标识位:', pollingId);

三、推流信息

3.1 获取推流信息

用于获取当前频道的最新推流信息,如流的尺寸、推流类型等。

Api 方法: getPushInfo(): Promise<StreamPushInfo>

返回值说明: Promise<StreamPushInfo> 类型,详细类型说明如下

属性名说明类型

isNewGuide

是否导播台推流

YN

resolutionWidth

分辨率宽度

number

resolutionHeight

分辨率高度

number

streamType

推流类型

StreamType

示例:

const pushInfo = await watchCore.channel.getPushInfo();
console.log('流宽度', pushInfo.resolutionWidth);
console.log('流高度', pushInfo.resolutionHeight);
console.log('推流类型', pushInfo.streamType);

四、页面浏览次数

4.1 获取观看页浏览次数

如果不需要轮询通机制来更新浏览次数,可调用 getPageViewCount 方法来重新获取观众进入页面时的浏览次数。

Api 方法: getPageViewCount(): number

示例:

const pageViewCount = await watchCore.channel.getPageViewCount();
console.log('页面浏览次数', pageViewCount);

4.2 开启观看页浏览次数请求轮询

用于开启观看页浏览次数接口请求的轮询,在触发回调后更新页面的浏览次数。

从 v1.2.0 开始在方法调用后立即回调一次

Api 方法: startPageViewPolling(callback?: Function): void

参数说明:

  • callback:回调函数,获取每次轮询的浏览次数,Function 类型,选传

示例:

watchCore.channel.startPageViewPolling((pageViewCount: number) => {
  console.log('页面浏览次数更新:', pageViewCount);
});

4.3 获取最新的观看页浏览次数

Api 方法: getLatestPageView(): Promise<number>

返回值说明: Promise<number> 类型

4.4 停止观看页浏览次数请求轮询

当页面销毁或相关组件销毁时,调用 stopPageViewPolling 停止轮询器。

Api 方法: stopPageViewPolling(): void

示例:

// vue 代码
export default {
  // 组件销毁前停止定时器
  beforeDestroy() {
    watchCore.channel.stopPageViewPolling();
  }
};

4.5 获取浏览次数设置信息

用于获取管理后台设置的页面浏览次数信息。

Api 方法: getPageViewSetting(): PageViewSetting

返回值说明: 页面浏览次数设置,PageViewSetting 类型,详细类型说明如下

属性名说明类型

pvShowEnabled

页面浏览次数开关

boolean

pageViewCount

页面浏览次数

number

mobilePvShowLocation

移动端页面浏览次数位置

PageViewShowLocation

示例:

const setting = watchCore.channel.getPageViewSetting();
console.log('页面浏览次数开关', setting.pvShowEnabled);
console.log('页面浏览次数', setting.pageViewCount);
console.log('移动端浏览次数位置', setting.mobilePvShowLocation);

五、直播开始时间

5.1 获取直播倒计时设置

用于获取后台设置的频道开始时间等设置信息。

Api 方法: getCountdownSetting(): ChannelCountdownSetting

返回值说明: 倒计时设置,ChannelCountdownSetting 类型,详细类型说明如下

属性名说明类型

liveStartTime

直播开始时间,单位:时间戳

undefined | number

countdownEnabled

倒计时开关

boolean

playbackShowCountdownEnabled

回放时是否显示下一场倒计时

boolean

示例:

const setting = watchCore.channel.getCountdownSetting();
console.log('开始时间:', setting.liveStartTime);
console.log('回放下是否显示倒计时:', setting.playbackShowCountdownEnabled);

六、观看时长

6.1 获取观看时长设置

Api 方法: getWatchDurationSetting(): Object

返回值说明: Object 类型,详细类型说明如下

属性名说明类型

watchDurationEnabled

-

boolean

6.2 结束观看时长统计轮询

Api 方法: stopWatchDurationStatsPolling(): void

6.3 开始观看时长统计轮询

Api 方法: startWatchDurationStatsPolling(): void

Last updated