FreeSWITCH 1.10.10 简单图形化界面15 - JsSIP媒体控制(LookLook)

FreeSWITCH 1.10.10 简单图形化界面15 - JsSIP媒体控制


FreeSWITCH界面安装参考:https://blog.csdn.net/jia198810/article/details/137820796

0、 界面预览

http://myfs.f3322.net:8020/

用户名:admin,密码:admin

FreeSWITCH界面安装参考:https://blog.csdn.net/jia198810/article/details/137820796

1、本地媒体流

通过JsSIP建立通话后,获取JsSIP.RTCSession类,通过mute()方法可控制是否关闭和开启本地音频或者视频媒体。

可参考JsSIP使用手册https://jssip.net/documentation/api/session/#method_mute

如下:

获取session
javascript 复制代码
  //通过JsSIP.UA的newRTCSession事件获取呼叫session,并通过mute开启关闭本地音频和视频
  this.ua.on('newRTCSession', (e) => {
      this.currentSession = e.session;
      //其他代码
      .....
   })
本地音频
javascript 复制代码
//关闭本地音频
//通过options控制是关闭音频还是视频
this.muteLocalAudio = () =>{
    //开启音频,则audio:false
	this.currentSession.mute(options={audio:true,video:false})
}
本地视频
javascript 复制代码
//关闭本地视频
//通过options控制是关闭音频还是视频
this.muteLocalVideo = () =>{
    //开启视频,则video:false
	this.currentSession.mute(options={audio:true,video:true})
}

2、远端媒体流

通过JsSIP建立通话后,获取JsSIP.RTCSession类的confirmed事件获取远端媒体MediaStream对象,然后通过媒体轨道MediaStreamTrack关闭和开启远端媒体。

可参考web开发手册https://developer.mozilla.org/en-US/docs/Web/API/MediaStreamTrack/enabled

如下:

获取媒体流
javascript 复制代码
 //获取JsSIP.RTCSession类的confirmed事件获取远端媒体
this.audioReceiver = null;
this.videoReceiver = null;
this.currentSession.on("confirmed", (e) => {
    

     // 分别获取音频和视频
    receivers.forEach((receiver) => {
        if (receiver.track.kind === "audio") {
            audioReceiver = receiver;
        } else if (receiver.track.kind === "video") {
            videoReceiver = receiver;
        }
     }); 
   // 播放音频及视频
   ......
});
远端音频

通过MediaStreamTrack的enabled属性控制媒体轨道

javascript 复制代码
//关闭远端音频
this.closeRemoteAudio = () =>{
    //开启音频,则enabled = true
    this.audioReceiver.getAudioTracks()[0].enabled = false
}
远端视频
javascript 复制代码
//关闭远端视频,黑屏
this.closeRemoteVideo = () =>{
    //开启视频,则enabled = true
    this.videoReceiver.getVideoTracks()[0].enabled = false
}
相关推荐
贾宝玉的玉宝贾18 小时前
FreeSWITCH 简单图形化界面59 - 拨号应用speak,使用纯CPU的kokoro-tts播放文字
voip·freeswitch·tts·ippbx·pbx·sip通信·kokoro
RTC老炮20 小时前
webrtc弱网-BBRv2算法原理
网络·算法·webrtc
RTC老炮20 小时前
webrtc弱网-BBRv1算法原理
网络·算法·webrtc
帐篷Li2 天前
自媒体从500到1000粉进阶指南:突破瓶颈期的实操方法论
媒体
爱学习的程序媛3 天前
Windows系统下安装与配置FreeSWITCH完整指南
windows·实时互动·webrtc·实时音视频·信息与通信·媒体
火山上的企鹅3 天前
QGC二次开发本地媒体浏览实战(二)FFmpeg最小系统实战
qt·ffmpeg·媒体·qgc
xiejiashu3 天前
EasyRTC成功发布!原生WebRTC/嵌入式WebRTC,Windows/Linux/Android/ARM全支持
webrtc·嵌入式webrtc·easyrtc·webrtc原生库·arm-webrtc
火山上的企鹅3 天前
QGC二次开发本地媒体浏览实战(一)Qt5+DirectShow 在 Android正常_Windows为什么出问题
android·qt·媒体·qgc
LJ97951114 天前
GEO时代的技术突围:Infoseek媒体发布如何改写内容分发规则
媒体
开开心心就好4 天前
免费自媒体多功能工具箱,图片音视频处理
人工智能·pdf·ocr·excel·音视频·语音识别·媒体