From 9584b892c7f61ecf1574cbe90838f76e228a8f72 Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Sat, 29 Apr 2023 09:14:15 +0300 Subject: [PATCH 33/33] gtk4: Implement selection rectangle drawing See osdn #47814 Signed-off-by: Marko Lindqvist --- client/gui-gtk-3.22/canvas.c | 10 ++++++++++ client/gui-gtk-4.0/canvas.c | 10 ++++++++++ client/gui-gtk-4.0/mapview.c | 25 ++++++++----------------- client/include/canvas_g.h | 6 +++--- 4 files changed, 31 insertions(+), 20 deletions(-) diff --git a/client/gui-gtk-3.22/canvas.c b/client/gui-gtk-3.22/canvas.c index 36f0e4e24d..b4190267b3 100644 --- a/client/gui-gtk-3.22/canvas.c +++ b/client/gui-gtk-3.22/canvas.c @@ -250,6 +250,11 @@ void canvas_put_line(struct canvas *pcanvas, struct color *pcolor, case LINE_GOTO: cairo_set_line_width(cr, 2.); break; + case LINE_SELECT_RECT: + cairo_set_line_width(cr, 2.); + cairo_set_dash(cr, dashes, 2, 0); + cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); + break; } gdk_cairo_set_source_rgba(cr, &pcolor->color); @@ -298,6 +303,11 @@ void canvas_put_curved_line(struct canvas *pcanvas, struct color *pcolor, case LINE_GOTO: cairo_set_line_width(cr, 2.); break; + case LINE_SELECT_RECT: + cairo_set_line_width(cr, 2.); + cairo_set_dash(cr, dashes, 2, 0); + cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); + break; } gdk_cairo_set_source_rgba(cr, &pcolor->color); diff --git a/client/gui-gtk-4.0/canvas.c b/client/gui-gtk-4.0/canvas.c index 7f8941f845..6467873cbf 100644 --- a/client/gui-gtk-4.0/canvas.c +++ b/client/gui-gtk-4.0/canvas.c @@ -250,6 +250,11 @@ void canvas_put_line(struct canvas *pcanvas, struct color *pcolor, case LINE_GOTO: cairo_set_line_width(cr, 2.); break; + case LINE_SELECT_RECT: + cairo_set_line_width(cr, 2.); + cairo_set_dash(cr, dashes, 2, 0); + cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); + break; } gdk_cairo_set_source_rgba(cr, &pcolor->color); @@ -302,6 +307,11 @@ void canvas_put_curved_line(struct canvas *pcanvas, case LINE_GOTO: cairo_set_line_width(cr, 2.); break; + case LINE_SELECT_RECT: + cairo_set_line_width(cr, 2.); + cairo_set_dash(cr, dashes, 2, 0); + cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); + break; } gdk_cairo_set_source_rgba(cr, &pcolor->color); diff --git a/client/gui-gtk-4.0/mapview.c b/client/gui-gtk-4.0/mapview.c index 870ad11a25..1e03ab2c10 100644 --- a/client/gui-gtk-4.0/mapview.c +++ b/client/gui-gtk-4.0/mapview.c @@ -723,12 +723,7 @@ void scrollbar_jump_callback(GtkAdjustment *adj, gpointer hscrollbar) **************************************************************************/ void draw_selection_rectangle(int canvas_x, int canvas_y, int w, int h) { -#if 0 - double dashes[2] = {4.0, 4.0}; struct color *pcolor; - cairo_t *cr; - GdkDrawingContext *ctx; - GdkSurface *wndw; if (w == 0 || h == 0) { return; @@ -739,18 +734,14 @@ void draw_selection_rectangle(int canvas_x, int canvas_y, int w, int h) return; } - wndw = gtk_native_get_surface(gtk_widget_get_native(map_canvas)); - ctx = gdk_window_begin_draw_frame(wndw, NULL, - gdk_window_get_clip_region(wndw)); - cr = gdk_drawing_context_get_cairo_context(ctx); - gdk_cairo_set_source_rgba(cr, &pcolor->color); - cairo_set_line_width(cr, 2.0); - cairo_set_dash(cr, dashes, 2, 0); - cairo_set_operator(cr, CAIRO_OPERATOR_DIFFERENCE); - cairo_rectangle(cr, canvas_x, canvas_y, w, h); - cairo_stroke(cr); - gdk_window_end_draw_frame(wndw, ctx); -#endif + canvas_put_line(mapview.store, pcolor, LINE_SELECT_RECT, + canvas_x, canvas_y, w, 0); + canvas_put_line(mapview.store, pcolor, LINE_SELECT_RECT, + canvas_x, canvas_y, 0, h); + canvas_put_line(mapview.store, pcolor, LINE_SELECT_RECT, + canvas_x, canvas_y + h, w, 0); + canvas_put_line(mapview.store, pcolor, LINE_SELECT_RECT, + canvas_x + w, canvas_y, 0, h); } /**********************************************************************//** diff --git a/client/include/canvas_g.h b/client/include/canvas_g.h index 144fef9514..3ecb5477e4 100644 --- a/client/include/canvas_g.h +++ b/client/include/canvas_g.h @@ -20,10 +20,10 @@ struct color; struct sprite; -struct canvas; /* opaque type, real type is gui-dep */ +struct canvas; /* Opaque type, real type is gui-dep */ enum line_type { - LINE_NORMAL, LINE_BORDER, LINE_TILE_FRAME, LINE_GOTO + LINE_NORMAL, LINE_BORDER, LINE_TILE_FRAME, LINE_GOTO, LINE_SELECT_RECT }; /* Creator and destructor */ @@ -81,4 +81,4 @@ GUI_FUNC_PROTO(void, canvas_put_text, struct canvas *pcanvas, int canvas_x, int canvas_y, enum client_font font, struct color *pcolor, const char *text) -#endif /* FC__CANVAS_G_H */ +#endif /* FC__CANVAS_G_H */ -- 2.39.2