diff options
author | Chris Michael <cp.michael@samsung.com> | 2013-07-31 10:52:06 +0100 |
---|---|---|
committer | Deon Thomas <PrinceAMD.Elive@gmail.com> | 2013-08-01 11:47:43 -0400 |
commit | 39587299c2e8e6176c2983813eba412332aef846 (patch) | |
tree | efc17031dca3d2e09c49a3ba338547989b1a5ad1 | |
parent | 75d1a637dcd35b62488f46066558c862c0a7ce98 (diff) | |
download | enlightenment-39587299c2e8e6176c2983813eba412332aef846.tar.gz |
Backport: b0e3605 :: Implement rudamentary monitor snapping after move.
After a monitor has been moved, snap it to the closest monitor.
NB: This should fix cases where a monitor could not be positioned next
to another monitor which had a resolution of 1368. Previously, the
second monitor could only move to 1366 due to a rounding issue when
converting coordinates to virtual. Now, the second monitor (when
finished moving) will Snap to the proper position.
NB: (Currently) In order for the snapping to work, either the
monitors' X axis or Y axis must be equal. Ideally, this should be
fixed to allow for some percentage of position flexibility.
Signed-off-by: Chris Michael <cp.michael@samsung.com>
Signed-off-by: Deon Thomas <PrinceAMD.Elive@gmail.com>
-rw-r--r-- | src/modules/conf_randr/e_smart_randr.c | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/src/modules/conf_randr/e_smart_randr.c b/src/modules/conf_randr/e_smart_randr.c index 4a9297920e..52572830d9 100644 --- a/src/modules/conf_randr/e_smart_randr.c +++ b/src/modules/conf_randr/e_smart_randr.c @@ -656,7 +656,8 @@ static void _e_smart_randr_monitor_cb_moved(void *data, Evas_Object *obj EINA_UNUSED, void *event EINA_UNUSED) { E_Smart_Data *sd; - Evas_Object *randr; + Evas_Object *randr, *mon; + Eina_List *l = NULL; if (!(randr = data)) return; @@ -667,6 +668,22 @@ _e_smart_randr_monitor_cb_moved(void *data, Evas_Object *obj EINA_UNUSED, void * * outputs is at 0,0 */ _e_smart_randr_monitor_position_normalize(sd); + /* move any monitors which are adjacent to this one to their new + * positions due to the resize, specifying this resized monitor as + * the one to skip */ + _e_smart_randr_monitor_position_update(sd, randr, randr); + + EINA_LIST_FOREACH(sd->monitors, l, mon) + { + /* skip the monitor which was currently resized */ + if ((mon == randr)) continue; + + /* move any monitors which are adjacent to this one to their new + * positions due to the resize, specifying this resized monitor as + * the one to skip */ + _e_smart_randr_monitor_position_update(sd, mon, randr); + } + /* tell main dialog that something changed and to enable apply button */ evas_object_smart_callback_call(randr, "randr_changed", NULL); } |