]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
FS-10121: [mod_conference] Add role-id and layout transitions to conference
authorAnthony Minessale <anthm@freeswitch.org>
Mon, 13 Mar 2017 17:31:03 +0000 (12:31 -0500)
committerAnthony Minessale <anthm@freeswitch.org>
Mon, 13 Mar 2017 17:31:27 +0000 (12:31 -0500)
src/mod/applications/mod_conference/conference_video.c
src/mod/applications/mod_conference/mod_conference.h

index b2b0edc1ee502a95dfe2f03ab1b40bd5b981c6d2..28e3991b118bd2b20a93a33038695a210629beac 100644 (file)
@@ -1415,6 +1415,9 @@ void conference_video_init_canvas_layers(conference_obj_t *conference, mcu_canva
 
        canvas->vlayout = vlayout;
 
+       canvas->res_count = 0;
+       canvas->role_count = 0;
+
        for (i = 0; i < vlayout->layers; i++) {
                mcu_layer_t *layer = &canvas->layers[i];
 
@@ -1454,8 +1457,15 @@ void conference_video_init_canvas_layers(conference_obj_t *conference, mcu_canva
                
                /* if we ever decided to reload layers config on demand the pointer assignment below  will lead to segs but we
                   only load them once forever per conference so these pointers are valid for the life of the conference */
-               layer->geometry.res_id = vlayout->images[i].res_id;
-               layer->geometry.role_id = vlayout->images[i].role_id;
+
+               if ((layer->geometry.res_id = vlayout->images[i].res_id)) {
+                       canvas->res_count++;
+               }
+
+               if ((layer->geometry.role_id = vlayout->images[i].role_id)) {
+                       canvas->role_count++;
+               }
+
                layer->geometry.audio_position = vlayout->images[i].audio_position;
        }
 
@@ -3056,25 +3066,29 @@ void *SWITCH_THREAD_FUNC conference_video_muxing_thread_run(switch_thread_t *thr
                        layer = NULL;
 
                        switch_mutex_lock(canvas->mutex);
+
                        
-                       if (canvas->layout_floor_id > -1 && imember->id == conference->video_floor_holder &&
-                               imember->video_layer_id != canvas->layout_floor_id) {
-                               conference_video_attach_video_layer(imember, canvas, canvas->layout_floor_id);
+                       if (zstr(imember->video_role_id) || !canvas->role_count) {
+                               if (canvas->layout_floor_id > -1 && imember->id == conference->video_floor_holder &&
+                                       imember->video_layer_id != canvas->layout_floor_id) {
+                                       conference_video_attach_video_layer(imember, canvas, canvas->layout_floor_id);
+                                       layer = &canvas->layers[imember->video_layer_id];
+                               }
                        }
                        
                        //printf("MEMBER %d layer_id %d canvas: %d/%d\n", imember->id, imember->video_layer_id,
                        //         canvas->layers_used, canvas->total_layers);
 
-                       if (imember->video_role_id) {
+                       if (!zstr(imember->video_role_id) && canvas->role_count) {
                                if (imember->video_layer_id > -1) {
                                        layer = &canvas->layers[imember->video_layer_id];
                                }
 
-                               if (!layer || (!layer->geometry.role_id || strcmp(layer->geometry.role_id, imember->video_role_id))) {
+                               if (!layer || (zstr(layer->geometry.role_id) || strcmp(layer->geometry.role_id, imember->video_role_id))) {
                                        for (i = 0; i < canvas->total_layers; i++) {
                                                mcu_layer_t *xlayer = &canvas->layers[i];
                                                
-                                               if (imember->video_role_id && xlayer->geometry.role_id && !strcmp(xlayer->geometry.role_id, imember->video_role_id)) {
+                                               if (!zstr(imember->video_role_id) && !zstr(xlayer->geometry.role_id) && !strcmp(xlayer->geometry.role_id, imember->video_role_id)) {
                                                        conference_video_attach_video_layer(imember, canvas, i);
                                                        layer = xlayer;
                                                }
@@ -3082,8 +3096,7 @@ void *SWITCH_THREAD_FUNC conference_video_muxing_thread_run(switch_thread_t *thr
                                }
                        }
 
-
-                       if (!layer && imember->video_layer_id > -1) {
+                       if (imember->video_layer_id > -1) {
                                layer = &canvas->layers[imember->video_layer_id];
                                
                                if (layer->member_id != (int)imember->id) {
index b13c7c0d58540230c6cb0fd2430e155a7f798ec8..5f6af27566a7fd7936319a8b5472f1b9f2df9890 100644 (file)
@@ -521,6 +521,8 @@ typedef struct mcu_canvas_s {
        int height;
        switch_image_t *img;
        mcu_layer_t layers[MCU_MAX_LAYERS];
+       int res_count;
+       int role_count;
        int total_layers;
        int layers_used;
        int layout_floor_id;