summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com>2022-05-25 16:05:36 +0200
committerManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com>2022-05-25 16:05:36 +0200
commita118732f7c10da03196ebd9207007686163114f4 (patch)
tree2849324c46094a6c1f9ecb4bc2e9874260073940 /src
parent8028fc3cfc1612e89cedeba72118507672a618b2 (diff)
Improve rectf() and push_clip() under cairo and GUI scaling.
Diffstat (limited to 'src')
-rw-r--r--src/drivers/Cairo/Fl_Cairo_Graphics_Driver.cxx12
1 files changed, 10 insertions, 2 deletions
diff --git a/src/drivers/Cairo/Fl_Cairo_Graphics_Driver.cxx b/src/drivers/Cairo/Fl_Cairo_Graphics_Driver.cxx
index 9c5d8292c..5a099024d 100644
--- a/src/drivers/Cairo/Fl_Cairo_Graphics_Driver.cxx
+++ b/src/drivers/Cairo/Fl_Cairo_Graphics_Driver.cxx
@@ -104,7 +104,10 @@ void Fl_Cairo_Graphics_Driver::set_cairo(cairo_t *cr, float s) {
void Fl_Cairo_Graphics_Driver::rectf(int x, int y, int w, int h) {
- cairo_rectangle(cairo_, x-0.5, y-0.5, w, h);
+ cairo_matrix_t mat;
+ cairo_get_matrix(cairo_, &mat);
+ double s = 1 / mat.xx;
+ cairo_rectangle(cairo_, x - 0.5, y - 0.5, w + s, h + s);
cairo_fill(cairo_);
check_status();
surface_needs_commit();
@@ -499,7 +502,12 @@ void Fl_Cairo_Graphics_Driver::push_clip(int x, int y, int w, int h) {
c->prev = clip_;
clip_ = c;
cairo_save(cairo_);
- cairo_rectangle(cairo_, clip_->x-0.5 , clip_->y-0.5 , clip_->w , clip_->h);
+ cairo_matrix_t mat;
+ cairo_get_matrix(cairo_, &mat);
+ double s = 1 / mat.xx;
+ double ss = (2 * s < 1 ? s : 1/2.);
+ cairo_rectangle(cairo_, clip_->x - 0.5 - ss, clip_->y - 0.5 - ss ,
+ clip_->w + s + 2 * ss, clip_->h + s + 2 * ss);
cairo_clip(cairo_);
check_status();
}