freeswitch会议floor获取方式分析

1、设置conference->video_floor_holder成员的函数

  • conference_set_video_floor_holder(conference_obj_t *conference, conference_member_t *member, switch_bool_t force)
  • 前提是检查到该member有video视频功能。
  • 关键是函数内设置conference对象的成员这一句:conference->video_floor_holder = member;
  • 若传入的member参数为NULL,则会遍历会议中成员链表将第一个(链表是头插法故链表第一个往往是最后一个进入会议中的成员)非原video_floor_holder的成员设为新的video_floor_holder。
  • 若传入的第三参数force为true,则会设置floor锁定标志switch_set_flag(conference, CFLAG_VID_FLOOR_LOCK),若是其他地方要更改video_floor_holder则必须是在检查非锁定状态下才可以更改。
  • 函数中默认会打印DEBUG1类型的日志通知旧的和新的video_floor_holder更新。可换成INFO或者NOTIFY类型日志,更容易看到。
  • 函数末尾还会生成用户自定义事件CUSTOM::conference::maintenance下发新旧video_floor_holder更新的通知,可用事件订阅的方式获取。

2、设置conference->floor_holder成员的函数

  • conference_set_floor_holder(conference_obj_t *conference, conference_member_t *member)
  • 适用于任何有无视频功能的member。
  • 首先会检查该member是否支持video视频,若是,则也会调用conference_set_video_floor_holder函数去设置video_floor_holder。
  • 若传入的member参数为NULL,则将floor_holder也设为NULL。
  • 其他打印日志和下发事件通知功能同上。

3、通过api去修改floor拥有者

  • 控制台api命令:
    conference 3000 floor member-id
    conference 3000 vid-floor member-id [force]若是加了force则锁定该video_floor
    conference 3000 clear-vid-floor
  • 模块内函数调用逻辑:
    conf_api_sub_floor =》conference_set_floor_holder
    conf_api_sub_vid_floor =》conference_set_video_floor_holder
    conf_api_sub_clear_vid_floor =》switch_clear_flag(conference, CFLAG_VID_FLOOR_LOCK),即解除video_floor锁定

4、通过dtmf键控去修改floor拥有者

  • 可在配置文件conference.conf.xml中设置某个按键对应vid-floor-force,然后再模块源码中有一个映射表,将vid-floor-force动作对应到一个函数conference_loop_fn_vid_floor_force,该函数内部实际调用上面的conf_api_sub_vid_floor函数。

5、根据声音能量member->score_iir切换floor_holder

  • score_iir在代码开头使用宏定义设置SCORE_IIR_SPEAKING_MAX 300SCORE_IIR_SPEAKING_MIN 100,意思是一个已经获取floor的用户只有在score_iir值小于100时才会失去floor控制权,否则会先保持而不是说有其他member的值比它的大就切换。而其他用户想要获取floor,则至少要自身score_iir值大于300。这两个条件同时满足才会因为声音能量去切换floor_holder。
  • 证明,在conference_thread_run函数中对每一个收到的语音包检查(imember->score_iir > SCORE_IIR_SPEAKING_MAX && (floor_holder->score_iir < SCORE_IIR_SPEAKING_MIN)若满足条件,则会切换floor_holder。当然,若是没有旧的floor_hoder则第一个检查的member就是。
  • 关于score_iir声音能量值的修改是在函数conference_loop_input中会对每个接收的语音数据包进行分析,然后统计出声音能量值,再更新这一个member对应的score_iir成员值
    member->score_iir = (int) (((1.0 - SCORE_DECAY) * (float) member->score) + (SCORE_DECAY * (float) member->score_iir));。其中的member->score = energy / samples;而energy是对接收到的语音数据包的data的每个short两字节数据取绝对值然后统计求和,而samples是一个对应于这条channel的采样值。
  • 具体切换,也是调用conference_set_floor_holder函数。

针对项目问题解决方案:

  • 已在conference_set_video_floor_holder函数中旧的和新的video_floor_holder更新时打印INFO类型日志。可看到切换时打印的用户账号名(%s)和用户声音能量值(%d)。代码在2555行左右:
    丢弃旧的"===================================Dropping video floor %s, score_iir=%d\n"
    增加新的"===================================Adding video floor %s, score_iir=%d\n"
  • 若是video_floor_holder一直不切换,也就是视频会议一直只显示一个人的视频,那就让其他用户使用按键’#’去强制获取video_floor_holder,然后就会触发调用上面这个函数打印出以上日志。然后就可以看到一直占据video_floor_holder的用户是谁,以及他的声音能量score_iir是多少,若是该能量值一直是高于100的,那么就符合逻辑,因为只有在该能量值低于100并且同时其他会议成员的能量值高于300时才会引发切换。
  • 方案一:若是因为score_iir值一直高于100,那就只能想办法从客户端那边将话机不讲话时的score_iir控制在100以下。
  • 方案二:或者也可以通过观察打印出的日志,看看话机不讲话时score_iir的值在什么水平范围,假设一直在150左右不高于160,那么也可以在服务器的会议模块代码mod_conference.c中设置将该能量低阈值从100设置为160。具体设置很简单,只需要将代码第91行的宏定义修改为:
    #define SCORE_IIR_SPEAKING_MIN 160
    然后在mod_conference.c所在文件目录位置,执行make install 命令,重新编译安装mod_conference.c文件,并在服务器中重新加载会议模块或者重启服务器。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容

  • 一、分析一个模块的源码步骤 1、首先应该看SWITCH_MODULE_LOAD_FUNCTION(mod_conf...
    XDgbh阅读 1,556评论 0 0
  • 四子歌(藏头诗) 林忠顺 梅傲妆冬点点红, 兰幽若谷戏春虫。 竹洁入夏青而直, 菊艳经秋淡也浓。
    林忠顺阅读 703评论 3 3
  • 梦伊始的地方 海深天蓝 高于心中所想 或低于心中期望 是谦卑 是向阳 若是如梦般精彩 莫忘初心伊始 洒脱自在而又从...
    简然_b2c7阅读 299评论 1 3