}
+static void reset_video_bitrate_counters(conference_member_t *member)
+{
+ member->managed_kps = 0;
+ member->blackouts = 0;
+ member->good_img = 0;
+ member->blanks = 0;
+}
+
static switch_status_t attach_video_layer(conference_member_t *member, int idx)
{
mcu_layer_t *layer = NULL;
switch_img_fill(member->conference->canvas->img, layer->x_pos, layer->y_pos, layer->screen_w, layer->screen_h,
&member->conference->canvas->letterbox_bgcolor);
- member->managed_kps = 0;
- member->blackouts = 0;
+ reset_video_bitrate_counters(member);
end:
}
-
static void *SWITCH_THREAD_FUNC conference_video_muxing_thread_run(switch_thread_t *thread, void *obj)
{
conference_obj_t *conference = (conference_obj_t *) obj;
if (img) {
imember->good_img++;
if ((imember->good_img % (int)(conference->video_fps.fps * 10)) == 0) {
- imember->blackouts = 0;
+ reset_video_bitrate_counters(imember);
}
} else {
imember->blanks++;
imember->good_img = 0;
-
+
if (imember->blanks == conference->video_fps.fps || (imember->blanks % (int)(conference->video_fps.fps * 10)) == 0) {
- imember->blackouts++;
imember->managed_kps = 0;
switch_core_session_request_video_refresh(imember->session);
}
- if (imember->blanks == conference->video_fps.fps * 2) {
+ if (imember->blanks == conference->video_fps.fps * 5) {
imember->blackouts++;
check_avatar(imember, SWITCH_TRUE);
if (layer && imember->avatar_png_img) {
layer->is_avatar = 1;
}
+ imember->managed_kps = 0;
}
}
}
if (flushed && imember->blanks) {
switch_img_free(&imember->avatar_png_img);
- imember->managed_kps = 0;
-
+ reset_video_bitrate_counters(imember);
+
if (layer) {
layer->is_avatar = 0;
}
int kps;
if (!layer || !switch_test_flag(imember, MFLAG_CAN_BE_SEEN) || imember->avatar_png_img) {
- kps = switch_calc_bitrate(320, 240, 1, imember->conference->video_fps.fps);
+ kps = switch_calc_bitrate(320, 240, 2, imember->conference->video_fps.fps);
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "%s auto-setting bitrate to %dkps because user's image is not visible\n",
switch_channel_get_name(imember->channel), kps);
} else {
kps = switch_calc_bitrate(layer->screen_w, layer->screen_h, 2, imember->conference->video_fps.fps);
- if (imember->blackouts > 2) {
- kps /= 2;
- switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1,
- "%s auto-setting half-bitrate based on loss to %dkps to accomodate %dx%d resolution\n",
- switch_channel_get_name(imember->channel), kps, layer->screen_w, layer->screen_h);
- } else {
- switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "%s auto-setting bitrate to %dkps to accomodate %dx%d resolution\n",
- switch_channel_get_name(imember->channel), kps, layer->screen_w, layer->screen_h);
- }
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG1, "%s auto-setting bitrate to %dkps to accomodate %dx%d resolution\n",
+ switch_channel_get_name(imember->channel), kps, layer->screen_w, layer->screen_h);
}
msg.message_id = SWITCH_MESSAGE_INDICATE_BITRATE_REQ;
return SWITCH_STATUS_GENERR;
switch_clear_flag_locked(member, MFLAG_CAN_BE_SEEN);
- member->managed_kps = 0;
- member->blackouts = 0;
-
+ reset_video_bitrate_counters(member);
+
//if (member->channel) {
//switch_channel_set_flag(member->channel, CF_VIDEO_PAUSE_READ);
//switch_core_session_request_video_refresh(member->session);
}
switch_set_flag_locked(member, MFLAG_CAN_BE_SEEN);
- member->managed_kps = 0;
- member->blackouts = 0;
+ reset_video_bitrate_counters(member);
if (member->channel) {
//switch_channel_clear_flag(member->channel, CF_VIDEO_PAUSE_READ);