Implement a platform-independent version of Fl_Graphics_Driver::copy_offscreen() usable when drawing to PostScript.
git-svn-id: file:///fltk/svn/fltk/branches/branch-1.4@12147 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
parent
6645a6b225
commit
1fc01c7cbb
@ -140,6 +140,8 @@ public:
|
||||
virtual void open_display() {}
|
||||
// optional method to close display access
|
||||
virtual void close_display() {}
|
||||
// compute dimensions of an Fl_Offscreen
|
||||
virtual void offscreen_size(Fl_Offscreen off, int &width, int &height) {}
|
||||
};
|
||||
|
||||
|
||||
|
@ -19,6 +19,7 @@
|
||||
#include <FL/Fl.H>
|
||||
#include "config_lib.h"
|
||||
#include <FL/Fl_Graphics_Driver.H>
|
||||
#include <FL/Fl_Screen_Driver.H>
|
||||
#include <FL/Fl_Image.H>
|
||||
#include <FL/fl_draw.H>
|
||||
|
||||
@ -74,7 +75,22 @@ int Fl_Graphics_Driver::draw_scaled(Fl_Image *img, int X, int Y, int W, int H) {
|
||||
/** see fl_copy_offscreen() */
|
||||
void Fl_Graphics_Driver::copy_offscreen(int x, int y, int w, int h, Fl_Offscreen pixmap, int srcx, int srcy)
|
||||
{
|
||||
// nothing to do, reimplement in driver if needed
|
||||
// This platform-independent version is used when the current graphics driver is PostScript.
|
||||
// It requires that pixmap has been created by fl_create_offscreen().
|
||||
int px_width = w, px_height = h;
|
||||
Fl::screen_driver()->offscreen_size(pixmap, px_width, px_height);
|
||||
int px = srcx, py = srcy, pw = w, ph = h;
|
||||
if (px < 0) {px = 0; pw += srcx; x -= srcx;}
|
||||
if (py < 0) {py = 0; ph += srcy; y -= srcy;}
|
||||
if (px + pw > px_width) {pw = px_width - px;}
|
||||
if (py + ph > px_height) {ph = px_height - py;}
|
||||
fl_begin_offscreen(pixmap);
|
||||
uchar *img = fl_read_image(NULL, px, py, pw, ph, 0);
|
||||
fl_end_offscreen();
|
||||
if (img) {
|
||||
fl_draw_image(img, x, y, pw, ph, 3, 0);
|
||||
delete[] img;
|
||||
}
|
||||
}
|
||||
|
||||
/** see fl_set_spot() */
|
||||
|
@ -94,6 +94,8 @@ public:
|
||||
virtual void enable_im();
|
||||
virtual void disable_im();
|
||||
virtual void open_display();
|
||||
// --- compute dimensions of an Fl_Offscreen
|
||||
virtual void offscreen_size(Fl_Offscreen o, int &width, int &height);
|
||||
};
|
||||
|
||||
|
||||
|
@ -400,6 +400,12 @@ int Fl_Cocoa_Screen_Driver::input_widget_handle_key(int key, unsigned mods, unsi
|
||||
return -1;
|
||||
}
|
||||
|
||||
void Fl_Cocoa_Screen_Driver::offscreen_size(Fl_Offscreen off, int &width, int &height)
|
||||
{
|
||||
width = CGBitmapContextGetWidth(off);
|
||||
height = CGBitmapContextGetHeight(off);
|
||||
}
|
||||
|
||||
//
|
||||
// End of "$Id$".
|
||||
//
|
||||
|
@ -77,6 +77,7 @@ public:
|
||||
virtual void enable_im();
|
||||
virtual void disable_im();
|
||||
virtual void open_display();
|
||||
virtual void offscreen_size(Fl_Offscreen off, int &width, int &height);
|
||||
};
|
||||
|
||||
|
||||
|
@ -638,6 +638,15 @@ float Fl_WinAPI_Screen_Driver::desktop_scaling_factor() {
|
||||
return scaling;
|
||||
}
|
||||
|
||||
void Fl_WinAPI_Screen_Driver::offscreen_size(Fl_Offscreen off, int &width, int &height)
|
||||
{
|
||||
BITMAP bitmap;
|
||||
if ( GetObject(off, sizeof(BITMAP), &bitmap) ) {
|
||||
width = bitmap.bmWidth;
|
||||
height = bitmap.bmHeight;
|
||||
}
|
||||
}
|
||||
|
||||
//
|
||||
// End of "$Id$".
|
||||
//
|
||||
|
@ -87,6 +87,8 @@ public:
|
||||
virtual void disable_im();
|
||||
virtual void open_display();
|
||||
virtual void close_display();
|
||||
// --- compute dimensions of an Fl_Offscreen
|
||||
virtual void offscreen_size(Fl_Offscreen o, int &width, int &height);
|
||||
};
|
||||
|
||||
|
||||
|
@ -1143,6 +1143,17 @@ Fl_RGB_Image *Fl_X11_Screen_Driver::read_win_rectangle(uchar *p, int X, int Y, i
|
||||
return rgb;
|
||||
}
|
||||
|
||||
|
||||
void Fl_X11_Screen_Driver::offscreen_size(Fl_Offscreen off, int &width, int &height)
|
||||
{
|
||||
int px, py;
|
||||
unsigned w, h, b, d;
|
||||
Window root;
|
||||
XGetGeometry(fl_display, off, &root, &px, &py, &w, &h, &b, &d);
|
||||
width = (int)w;
|
||||
height = (int)h;
|
||||
}
|
||||
|
||||
//
|
||||
// End of "$Id$".
|
||||
//
|
||||
|
Loading…
Reference in New Issue
Block a user