Commit 8e74db9c authored by Christoffer Ackelman's avatar Christoffer Ackelman

GTK: Minor optimization of subwindow drawing.

parent 7df9937e
...@@ -1216,12 +1216,14 @@ int GlowDrawGtk::begin(DrawWind *w) { ...@@ -1216,12 +1216,14 @@ int GlowDrawGtk::begin(DrawWind *w) {
return 0; return 0;
} }
void GlowDrawGtk::end() { void GlowDrawGtk::end(bool flush) {
int width, height; if (flush) {
gdk_drawable_get_size(w->buffer, &width, &height); int width, height;
gdk_drawable_get_size(w->buffer, &width, &height);
gdk_draw_drawable(w->window, get_gc(this, glow_eDrawType_Line, 0), w->buffer, gdk_draw_drawable(w->window, get_gc(this, glow_eDrawType_Line, 0), w->buffer,
0, 0, 0, 0, width, height); 0, 0, 0, 0, width, height);
}
this->w = NULL; this->w = NULL;
} }
......
...@@ -114,7 +114,7 @@ public: ...@@ -114,7 +114,7 @@ public:
void clear(); void clear();
int begin(DrawWind* wind); int begin(DrawWind* wind);
void end(); void end(bool flush = true);
void get_window_size(DrawWind* w, int* width, int* height); void get_window_size(DrawWind* w, int* width, int* height);
void set_window_size(DrawWind* w, int width, int height); void set_window_size(DrawWind* w, int width, int height);
......
...@@ -877,7 +877,7 @@ int GlowDrawQt::begin(DrawWind *w) { ...@@ -877,7 +877,7 @@ int GlowDrawQt::begin(DrawWind *w) {
return 0; return 0;
} }
void GlowDrawQt::end() { void GlowDrawQt::end(bool flush) {
this->w = NULL; this->w = NULL;
} }
......
...@@ -110,7 +110,7 @@ public: ...@@ -110,7 +110,7 @@ public:
void clear(); void clear();
int begin(DrawWind *w); int begin(DrawWind *w);
void end(); void end(bool flush = true);
void get_window_size(DrawWind* w, int* width, int* height); void get_window_size(DrawWind* w, int* width, int* height);
void set_window_size(DrawWind* w, int width, int height); void set_window_size(DrawWind* w, int width, int height);
......
...@@ -81,7 +81,7 @@ public: ...@@ -81,7 +81,7 @@ public:
virtual void set_window_size(DrawWind* w, int width, int height) = 0; virtual void set_window_size(DrawWind* w, int width, int height) = 0;
virtual int begin(DrawWind* wind) = 0; virtual int begin(DrawWind* wind) = 0;
virtual void end() = 0; virtual void end(bool flush = true) = 0;
virtual void rect(int x, int y, int width, int height, glow_eDrawType gc_type, virtual void rect(int x, int y, int width, int height, glow_eDrawType gc_type,
int fill, int idx, int highlight = 0) = 0; int fill, int idx, int highlight = 0) = 0;
......
...@@ -168,11 +168,10 @@ void GrowCtx::set_mode(grow_eMode grow_mode) ...@@ -168,11 +168,10 @@ void GrowCtx::set_mode(grow_eMode grow_mode)
int GrowCtx::subw_event_handler(glow_eEvent event, int x, int y, int w, int h) int GrowCtx::subw_event_handler(glow_eEvent event, int x, int y, int w, int h)
{ {
int i; int i;
double fx, fy;
int sts; int sts;
fx = double(x + mw->offset_x) / mw->zoom_factor_x; double fx = double(x + mw->offset_x) / mw->zoom_factor_x;
fy = double(y + mw->offset_y) / mw->zoom_factor_y; double fy = double(y + mw->offset_y) / mw->zoom_factor_y;
if (has_subwindows == -1) { if (has_subwindows == -1) {
// Initialize // Initialize
...@@ -258,14 +257,10 @@ int GrowCtx::event_handler(glow_eEvent event, int x, int y, int w, int h) ...@@ -258,14 +257,10 @@ int GrowCtx::event_handler(glow_eEvent event, int x, int y, int w, int h)
{ {
int sts = 0; int sts = 0;
int i; int i;
GlowCtx* ctx;
int node_move_event = 0; int node_move_event = 0;
double fx, fy;
ctx = this; double fx = double(x + mw->offset_x) / mw->zoom_factor_x;
double fy = double(y + mw->offset_y) / mw->zoom_factor_y;
fx = double(x + ctx->mw->offset_x) / ctx->mw->zoom_factor_x;
fy = double(y + ctx->mw->offset_y) / ctx->mw->zoom_factor_y;
callback_object_type = glow_eObjectType_NoObject; callback_object_type = glow_eObjectType_NoObject;
callback_object = 0; callback_object = 0;
...@@ -1555,13 +1550,13 @@ int GrowCtx::event_handler(glow_eEvent event, int x, int y, int w, int h) ...@@ -1555,13 +1550,13 @@ int GrowCtx::event_handler(glow_eEvent event, int x, int y, int w, int h)
} else if (select_rect_active && edit_mode != grow_eMode_Scale) { } else if (select_rect_active && edit_mode != grow_eMode_Scale) {
glow_eSelectPolicy policy; glow_eSelectPolicy policy;
if (ctx->select_policy == glow_eSelectPolicy_Both) { if (select_policy == glow_eSelectPolicy_Both) {
if (x < select_rect_start_x) if (x < select_rect_start_x)
policy = glow_eSelectPolicy_Partial; policy = glow_eSelectPolicy_Partial;
else else
policy = glow_eSelectPolicy_Surround; policy = glow_eSelectPolicy_Surround;
} else } else
policy = ctx->select_policy; policy = select_policy;
select_rect_active = 0; select_rect_active = 0;
select_rect_last_x = x; select_rect_last_x = x;
...@@ -1745,12 +1740,11 @@ int GrowCtx::event_handler(glow_eEvent event, int x, int y, int w, int h) ...@@ -1745,12 +1740,11 @@ int GrowCtx::event_handler(glow_eEvent event, int x, int y, int w, int h)
cursor_present = 0; cursor_present = 0;
if (node_movement_active || con_create_active || select_rect_active if (node_movement_active || con_create_active || select_rect_active
|| node_movement_paste_active) { || node_movement_paste_active) {
if (x < 0 || x > ctx->mw->window_width || y < 0 || y > mw->window_height) { if (x < 0 || x > mw->window_width || y < 0 || y > mw->window_height) {
/* Start auto scrolling */ /* Start auto scrolling */
auto_scrolling(this); auto_scrolling(this);
} }
} else if (x < 0 || x > ctx->mw->window_width || y < 0 } else if (x < 0 || x > mw->window_width || y < 0 || y > mw->window_height)
|| y > mw->window_height)
a.set_hot(0); a.set_hot(0);
tiptext->remove(); tiptext->remove();
break; break;
......
...@@ -323,7 +323,11 @@ void GrowWindow::draw(DrawWind* w, GlowTransform* t, int highlight, int hot, ...@@ -323,7 +323,11 @@ void GrowWindow::draw(DrawWind* w, GlowTransform* t, int highlight, int hot,
ctx->gdraw->rect( ctx->gdraw->rect(
ll_x, ll_y, ur_x - ll_x, ur_y - ll_y, fill_drawtype, 1, 0); ll_x, ll_y, ur_x - ll_x, ur_y - ll_y, fill_drawtype, 1, 0);
ctx->gdraw->end(false);
ctx->gdraw->begin(window_ctx->mw);
window_ctx->draw(window_ctx->mw, ll_x, ll_y, ur_x, ur_y); window_ctx->draw(window_ctx->mw, ll_x, ll_y, ur_x, ur_y);
ctx->gdraw->end(false);
ctx->gdraw->begin(w);
ctx->gdraw->pop_customcolors(); ctx->gdraw->pop_customcolors();
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment