mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-03-13 12:40:17 +00:00
FS-7513: do layers in order and reset when attaching
This commit is contained in:
parent
fcf32fd53d
commit
1aa66ef30a
@ -976,7 +976,7 @@ SWITCH_DECLARE(char *) switch_util_quote_shell_arg_pool(const char *string, swit
|
||||
|
||||
#define SWITCH_READ_ACCEPTABLE(status) (status == SWITCH_STATUS_SUCCESS || status == SWITCH_STATUS_BREAK || status == SWITCH_STATUS_INUSE)
|
||||
|
||||
static inline uint32_t switch_parse_bandwidth_string(const char *bwv)
|
||||
static inline int32_t switch_parse_bandwidth_string(const char *bwv)
|
||||
{
|
||||
int32_t bw = 0;
|
||||
|
||||
|
@ -355,6 +355,7 @@ typedef struct mcu_layer_s {
|
||||
mcu_layer_geometry_t geometry;
|
||||
int member_id;
|
||||
int idx;
|
||||
int tagged;
|
||||
switch_image_t *img;
|
||||
switch_image_t *cur_img;
|
||||
} mcu_layer_t;
|
||||
@ -931,9 +932,12 @@ static void set_bgcolor(bgcolor_yuv_t *bgcolor, char *bgcolor_str)
|
||||
|
||||
static void reset_layer(mcu_canvas_t *canvas, mcu_layer_t *layer)
|
||||
{
|
||||
|
||||
int x = 0, y = 0;
|
||||
int screen_w = 0, screen_h = 0;
|
||||
|
||||
layer->tagged = 0;
|
||||
|
||||
screen_w = canvas->img->d_w * layer->geometry.scale / SCALE_FACTOR;
|
||||
screen_h = canvas->img->d_h * layer->geometry.scale / SCALE_FACTOR;
|
||||
|
||||
@ -1085,6 +1089,7 @@ static switch_status_t attach_video_layer(conference_member_t *member, int idx)
|
||||
switch_mutex_lock(member->conference->canvas->mutex);
|
||||
|
||||
layer = &member->conference->canvas->layers[idx];
|
||||
layer->tagged = 0;
|
||||
|
||||
if (layer->member_id && layer->member_id == member->id) {
|
||||
member->video_layer_id = idx;
|
||||
@ -1095,6 +1100,8 @@ static switch_status_t attach_video_layer(conference_member_t *member, int idx)
|
||||
detach_video_layer(member);
|
||||
}
|
||||
|
||||
reset_layer(member->conference->canvas, layer);
|
||||
|
||||
channel = switch_core_session_get_channel(member->session);
|
||||
res_id = switch_channel_get_variable_dup(channel, "video_reservation_id", SWITCH_FALSE, -1);
|
||||
|
||||
@ -1150,6 +1157,7 @@ static void init_canvas_layers(conference_obj_t *conference, video_layout_t *vla
|
||||
for (i = 0; i < MCU_MAX_LAYERS; i++) {
|
||||
mcu_layer_t *layer = &conference->canvas->layers[i];
|
||||
layer->member_id = 0;
|
||||
layer->tagged = 0;
|
||||
}
|
||||
|
||||
conference->canvas->layers_used = 0;
|
||||
@ -1444,7 +1452,7 @@ static void *SWITCH_THREAD_FUNC conference_video_muxing_thread_run(switch_thread
|
||||
if (layer) {
|
||||
switch_img_free(&layer->cur_img);
|
||||
layer->cur_img = img;
|
||||
scale_and_patch(conference, layer);
|
||||
layer->tagged = 1;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1457,6 +1465,17 @@ static void *SWITCH_THREAD_FUNC conference_video_muxing_thread_run(switch_thread
|
||||
|
||||
if (remaining) goto top;
|
||||
|
||||
|
||||
for (i = 0; i < conference->canvas->total_layers; i++) {
|
||||
mcu_layer_t *layer = &conference->canvas->layers[i];
|
||||
|
||||
if (layer->member_id > -1 && layer->cur_img && layer->tagged) {
|
||||
scale_and_patch(conference, layer);
|
||||
layer->tagged = 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (used) {
|
||||
switch_time_t now = switch_micro_time_now();
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user