Support arbitrary screen layouts

The Quartz port now supports arbitrary multiple monitor layouts instead
of only monitors are were laid out horizontally.  This builds on the
reworked coordinate translation done in a previous commit.
This commit is contained in:
Kristian Rietveld 2009-10-26 08:42:15 +01:00
parent 8846012c6d
commit 959a9437e6

View File

@ -112,8 +112,8 @@ static void
gdk_screen_quartz_calculate_layout (GdkScreenQuartz *screen) gdk_screen_quartz_calculate_layout (GdkScreenQuartz *screen)
{ {
NSArray *array; NSArray *array;
NSRect largest_rect;
int i; int i;
int max_x, max_y;
GDK_QUARTZ_ALLOC_POOL; GDK_QUARTZ_ALLOC_POOL;
@ -121,43 +121,33 @@ gdk_screen_quartz_calculate_layout (GdkScreenQuartz *screen)
array = [NSScreen screens]; array = [NSScreen screens];
/* FIXME: For now we only support screen layouts where the screens are laid
* out horizontally. Mac OS X also supports laying out the screens vertically
* and the screens having "non-standard" offsets from eachother. In the
* future we need a much more sophiscated algorithm to translate these
* layouts to GDK coordinate space and GDK screen layout.
*/
screen->width = 0; screen->width = 0;
screen->height = 0; screen->height = 0;
screen->min_x = 0; screen->min_x = 0;
screen->min_y = 0; screen->min_y = 0;
max_x = max_y = 0;
/* We determine the minimum and maximum x and y coordinates
* covered by the monitors. From this we can deduce the width
* and height of the root screen.
*/
for (i = 0; i < [array count]; i++) for (i = 0; i < [array count]; i++)
{ {
NSRect rect = [[array objectAtIndex:i] frame]; NSRect rect = [[array objectAtIndex:i] frame];
screen->width += rect.size.width;
screen->height = MAX (screen->height, rect.size.height);
screen->min_x = MIN (screen->min_x, rect.origin.x); screen->min_x = MIN (screen->min_x, rect.origin.x);
max_x = MAX (max_x, rect.origin.x + rect.size.width);
screen->min_y = MIN (screen->min_y, rect.origin.y); screen->min_y = MIN (screen->min_y, rect.origin.y);
max_y = MAX (max_y, rect.origin.y + rect.size.height);
} }
screen->width = max_x - screen->min_x;
screen->height = max_y - screen->min_y;
screen->n_screens = [array count]; screen->n_screens = [array count];
screen->screen_rects = g_new0 (GdkRectangle, screen->n_screens); screen->screen_rects = g_new0 (GdkRectangle, screen->n_screens);
/* Find the monitor with the largest height. All monitors should be
* offset to this one in the GDK screen space instead of offset to
* the screen with the menu bar.
*/
largest_rect = [[array objectAtIndex:0] frame];
for (i = 1; i < [array count]; i++)
{
NSRect rect = [[array objectAtIndex:i] frame];
if (rect.size.height > largest_rect.size.height)
largest_rect = [[array objectAtIndex:i] frame];
}
for (i = 0; i < screen->n_screens; i++) for (i = 0; i < screen->n_screens; i++)
{ {
NSScreen *nsscreen; NSScreen *nsscreen;
@ -167,13 +157,10 @@ gdk_screen_quartz_calculate_layout (GdkScreenQuartz *screen)
rect = [nsscreen frame]; rect = [nsscreen frame];
screen->screen_rects[i].x = rect.origin.x - screen->min_x; screen->screen_rects[i].x = rect.origin.x - screen->min_x;
screen->screen_rects[i].y
= screen->height - (rect.origin.y + rect.size.height) + screen->min_y;
screen->screen_rects[i].width = rect.size.width; screen->screen_rects[i].width = rect.size.width;
screen->screen_rects[i].height = rect.size.height; screen->screen_rects[i].height = rect.size.height;
if (largest_rect.size.height - rect.size.height == 0)
screen->screen_rects[i].y = 0;
else
screen->screen_rects[i].y = largest_rect.size.height - rect.size.height + largest_rect.origin.y;
} }
GDK_QUARTZ_RELEASE_POOL; GDK_QUARTZ_RELEASE_POOL;