return SWITCH_STATUS_FALSE;
}
- if (member->video_flow == SWITCH_MEDIA_FLOW_SENDONLY) {
+ if (member->video_flow == SWITCH_MEDIA_FLOW_SENDONLY && !member->avatar_png_img) {
return SWITCH_STATUS_FALSE;
}
}
}
- if (!layer && conference->canvas->layers_used < conference->canvas->total_layers && imember->video_flow != SWITCH_MEDIA_FLOW_SENDONLY) {
+ if (!layer && conference->canvas->layers_used < conference->canvas->total_layers && (imember->avatar_png_img || imember->video_flow != SWITCH_MEDIA_FLOW_SENDONLY)) {
/* find an empty layer */
for (i = 0; i < conference->canvas->total_layers; i++) {
mcu_layer_t *xlayer = &conference->canvas->layers[i];
continue;
}
- if (imember->video_flow == SWITCH_MEDIA_FLOW_SENDONLY) {
+ if (imember->video_flow == SWITCH_MEDIA_FLOW_SENDONLY && !imember->avatar_png_img) {
continue;
}
- if (!switch_channel_test_flag(imember->channel, CF_VIDEO)) {
+ if (!switch_channel_test_flag(imember->channel, CF_VIDEO) && !imember->avatar_png_img) {
continue;
}
channel = switch_core_session_get_channel(member->session);
member->video_flow = switch_core_session_media_flow(member->session, SWITCH_MEDIA_TYPE_VIDEO);
- if (switch_channel_test_flag(channel, CF_VIDEO)) {
+ if (switch_channel_test_flag(channel, CF_VIDEO) && member->video_flow != SWITCH_MEDIA_FLOW_SENDONLY) {
switch_set_flag_locked(member, MFLAG_ACK_VIDEO);
} else {
if (conference->no_video_avatar) {
return;
}
- if (member && member->video_flow == SWITCH_MEDIA_FLOW_SENDONLY) {
+ if (member && member->video_flow == SWITCH_MEDIA_FLOW_SENDONLY && !member->avatar_png_img) {
return;
}
if (((conference->video_floor_holder && !member && !switch_test_flag(conference, CFLAG_VID_FLOOR_LOCK)) ||
- (member && member->channel && switch_channel_test_flag(member->channel, CF_VIDEO)))) {
+ (member && member->channel && (switch_channel_test_flag(member->channel, CF_VIDEO) || member->avatar_png_img)))) {
conference_set_video_floor_holder(conference, member, SWITCH_FALSE);
}
break;
}
- if (switch_channel_test_flag(channel, CF_VIDEO) && !switch_test_flag(member, MFLAG_ACK_VIDEO)) {
+ if ((switch_channel_test_flag(channel, CF_VIDEO) || member->avatar_png_img) && !switch_test_flag(member, MFLAG_ACK_VIDEO)) {
switch_set_flag_locked(member, MFLAG_ACK_VIDEO);
switch_core_session_video_reinit(member->session);
conference_set_video_floor_holder(member->conference, member, SWITCH_FALSE);
if (member == NULL)
return SWITCH_STATUS_GENERR;
- if (!switch_channel_test_flag(member->channel, CF_VIDEO)) {
+ if (!switch_channel_test_flag(member->channel, CF_VIDEO) && !member->avatar_png_img) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Channel %s does not have video capability!\n", switch_channel_get_name(member->channel));
return SWITCH_STATUS_FALSE;
}