diff options
| author | Matthias Melcher <fltk@matthiasm.com> | 2016-02-10 19:49:35 +0000 |
|---|---|---|
| committer | Matthias Melcher <fltk@matthiasm.com> | 2016-02-10 19:49:35 +0000 |
| commit | e83bc2527fd412bc235f1f8743659e31b12bdc31 (patch) | |
| tree | 8c807e8b0c7af5f8ec1c67da1eec8e17bf4ad963 /src/Fl_Screen_Driver.cxx | |
| parent | 478d6336200d18630abd0d77c512e28fb2b931d0 (diff) | |
Basic Screen Driver Structure. LIMBO!
Creating the basic structure for a screen driver system.
OS X works X11 and WinAPI are in limbo and will be fixed in the next hour or so.
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.3-porting@11148 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
Diffstat (limited to 'src/Fl_Screen_Driver.cxx')
| -rw-r--r-- | src/Fl_Screen_Driver.cxx | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/src/Fl_Screen_Driver.cxx b/src/Fl_Screen_Driver.cxx new file mode 100644 index 000000000..46e9e5d2c --- /dev/null +++ b/src/Fl_Screen_Driver.cxx @@ -0,0 +1,124 @@ +// +// "$Id$" +// +// All screen related calls in a driver style class. +// +// Copyright 1998-2016 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// http://www.fltk.org/COPYING.php +// +// Please report all bugs and problems on the following page: +// +// http://www.fltk.org/str.php +// + + +#include "config_lib.h" +#include <FL/Fl_Screen_Driver.H> +#include <FL/Fl.H> + + +Fl_Screen_Driver::Fl_Screen_Driver() : +num_screens(-1) +{ +} + + +void Fl_Screen_Driver::screen_xywh(int &X, int &Y, int &W, int &H) +{ + int x, y; + Fl::get_mouse(x, y); + screen_xywh(X, Y, W, H, x, y); +} + + +void Fl_Screen_Driver::screen_xywh(int &X, int &Y, int &W, int &H, int mx, int my) +{ + screen_xywh(X, Y, W, H, screen_num(mx, my)); +} + + +void Fl_Screen_Driver::screen_work_area(int &X, int &Y, int &W, int &H) +{ + int x, y; + Fl::get_mouse(x, y); + screen_work_area(X, Y, W, H, x, y); +} + + +void Fl_Screen_Driver::screen_work_area(int &X, int &Y, int &W, int &H, int mx, int my) +{ + screen_work_area(X, Y, W, H, screen_num(mx, my)); +} + + +int Fl_Screen_Driver::screen_count() +{ + if (num_screens < 0) + init(); + return num_screens ? num_screens : 1; +} + + +void Fl_Screen_Driver::screen_xywh(int &X, int &Y, int &W, int &H, int mx, int my, int mw, int mh) +{ + screen_xywh(X, Y, W, H, screen_num(mx, my, mw, mh)); +} + + +int Fl_Screen_Driver::screen_num(int x, int y) +{ + int screen = 0; + if (num_screens < 0) init(); + + for (int i = 0; i < num_screens; i ++) { + int sx, sy, sw, sh; + Fl::screen_xywh(sx, sy, sw, sh, i); + if ((x >= sx) && (x < (sx+sw)) && (y >= sy) && (y < (sy+sh))) { + screen = i; + break; + } + } + return screen; +} + + +// Return the number of pixels common to the two rectangular areas +static inline float fl_intersection(int x1, int y1, int w1, int h1, + int x2, int y2, int w2, int h2) +{ + if(x1+w1 < x2 || x2+w2 < x1 || y1+h1 < y2 || y2+h2 < y1) + return 0.; + int int_left = x1 > x2 ? x1 : x2; + int int_right = x1+w1 > x2+w2 ? x2+w2 : x1+w1; + int int_top = y1 > y2 ? y1 : y2; + int int_bottom = y1+h1 > y2+h2 ? y2+h2 : y1+h1; + return (float)(int_right - int_left) * (int_bottom - int_top); +} + + +int Fl_Screen_Driver::screen_num(int x, int y, int w, int h) +{ + int best_screen = 0; + float best_intersection = 0.; + for (int i = 0; i < num_screens; i++) { + int sx = 0, sy = 0, sw = 0, sh = 0; + screen_xywh(sx, sy, sw, sh, i); + float sintersection = fl_intersection(x, y, w, h, sx, sy, sw, sh); + if (sintersection > best_intersection) { + best_screen = i; + best_intersection = sintersection; + } + } + return best_screen; +} + + + +// +// End of "$Id$". +// |
