1
0
mirror of git://projects.qi-hardware.com/eda-tools.git synced 2024-11-29 19:59:43 +02:00

eeshow/: add color overriding; basic infrastructure for viewing deltas

This commit is contained in:
Werner Almesberger 2016-08-07 14:06:50 -03:00
parent ba62fc4fc4
commit f40f012a1e
3 changed files with 90 additions and 47 deletions

View File

@ -97,7 +97,7 @@ static void set_color(struct cro_ctx *cc, int color)
if (color < 0)
return;
c = color_rgb[color];
cairo_set_source_rgb(cc-> cr,
cairo_set_source_rgb(cc->cr,
(c >> 16) / 255.0, ((c >> 8) & 255) / 255.0, (c & 255) / 255.0);
}
@ -480,10 +480,9 @@ void cro_canvas_end(struct cro_ctx *cc, int *w, int *h, int *xmin, int *ymin)
}
void cro_canvas_draw(struct cro_ctx *cc, cairo_t *cr, int xo, int yo,
float scale)
void cro_canvas_prepare(cairo_t *cr)
{
set_color(cc, COLOR_WHITE);
cairo_set_source_rgb(cr, 1, 1, 1);
cairo_paint(cr);
cairo_select_font_face(cr, "Helvetica", CAIRO_FONT_SLANT_NORMAL,
@ -491,8 +490,14 @@ void cro_canvas_draw(struct cro_ctx *cc, cairo_t *cr, int xo, int yo,
cairo_set_line_width(cr, 2);
cairo_set_line_cap(cr, CAIRO_LINE_CAP_ROUND);
}
void cro_canvas_draw(struct cro_ctx *cc, cairo_t *cr, int xo, int yo,
float scale)
{
cc->cr = cr;
cc->scale = scale;
cc->xo = xo;
cc->yo = yo;

View File

@ -37,7 +37,8 @@ uint32_t *cro_img_end(struct cro_ctx *cc, int *w, int *h, int *stride);
void cro_img_write(struct cro_ctx *cc, const char *name);
void cro_canvas_end(struct cro_ctx *cc, int *w, int *h, int *xmin, int *ymin);
void cro_canvas_draw(struct cro_ctx *cc, cairo_t *cr, int x, int y,
float scale);
void cro_canvas_prepare(cairo_t *cr);
void cro_canvas_draw(struct cro_ctx *cc, cairo_t *cr,
int x, int y, float scale);
#endif /* !CRO_H */

View File

@ -28,10 +28,12 @@
#include <gtk/gtk.h>
#include "util.h"
#include "style.h"
#include "cro.h"
#include "gfx.h"
#include "git-hist.h"
#include "sch.h"
#include "delta.h"
#include "gui-aoi.h"
#include "gui-over.h"
#include "gui.h"
@ -40,7 +42,7 @@
struct gui_ctx;
struct gui_sheet {
const const struct sheet *sch;
const struct sheet *sch;
struct cro_ctx *gfx_ctx;
int w, h;
@ -81,6 +83,10 @@ struct gui_ctx {
struct overlay *hist_overlays;
struct aoi *aois; /* areas of interest; in canvas coord */
struct gui_sheet delta_a;
struct gui_sheet delta_b;
struct gui_sheet delta_ab;
struct gui_sheet *curr_sheet;
/* current sheet */
struct gui_hist *curr_hist;
@ -97,6 +103,34 @@ static void redraw(const struct gui_ctx *ctx)
}
static struct gui_sheet *find_corresponding_sheet(struct gui_sheet *pick_from,
struct gui_sheet *ref_in, const struct gui_sheet *ref)
{
struct gui_sheet *sheet, *plan_b;
const char *title = ref->sch->title;
/* plan A: try to find sheet with same name */
if (title)
for (sheet = pick_from; sheet; sheet = sheet->next)
if (sheet->sch->title &&
!strcmp(title, sheet->sch->title))
return sheet;
/* plan B: use sheet in same position in sheet sequence */
plan_b = ref_in;
for (sheet = pick_from; sheet; sheet = sheet->next) {
if (plan_b == ref)
return sheet;
plan_b = plan_b->next;
}
/* plan C: just go to the top */
return pick_from;
}
/* ----- Rendering --------------------------------------------------------- */
@ -113,14 +147,22 @@ static gboolean on_draw_event(GtkWidget *widget, cairo_t *cr,
const struct gui_ctx *ctx = user_data;
const struct gui_sheet *sheet = ctx->curr_sheet;
GtkAllocation alloc;
float f = 1.0 / (1 << ctx->zoom);
int x, y;
gtk_widget_get_allocation(ctx->da, &alloc);
x = -(sheet->xmin + ctx->x) * f + alloc.width / 2;
y = -(sheet->ymin + ctx->y) * f + alloc.height / 2;
cro_canvas_draw(sheet->gfx_ctx, cr, x, y, f);
cro_canvas_prepare(cr);
if (!ctx->last_hist) {
cro_canvas_draw(sheet->gfx_ctx, cr, x, y, f);
} else {
/* @@@ fix geometry later */
cro_canvas_draw(ctx->delta_ab.gfx_ctx, cr, x, y, f);
cro_canvas_draw(ctx->delta_a.gfx_ctx, cr, x, y, f);
cro_canvas_draw(ctx->delta_b.gfx_ctx, cr, x, y, f);
}
overlay_draw_all(ctx->sheet_overlays, cr,
SHEET_OVERLAYS_X, SHEET_OVERLAYS_Y);
@ -145,6 +187,34 @@ static void render_sheet(struct gui_sheet *sheet)
}
static void render_delta(struct gui_ctx *ctx)
{
struct sheet *sch_a, *sch_b, *sch_ab;
const struct gui_sheet *a = ctx->curr_sheet;
const struct gui_sheet *b = find_corresponding_sheet(
ctx->last_hist->sheets, ctx->curr_hist->sheets, ctx->curr_sheet);
sch_a = alloc_type(struct sheet);
sch_b = alloc_type(struct sheet);
sch_ab = alloc_type(struct sheet);
delta(a->sch, b->sch, sch_a, sch_b, sch_ab);
ctx->delta_a.sch = sch_a,
ctx->delta_b.sch = sch_b,
ctx->delta_ab.sch = sch_ab,
render_sheet(&ctx->delta_a);
render_sheet(&ctx->delta_b);
render_sheet(&ctx->delta_ab);
cro_color_override(ctx->delta_ab.gfx_ctx, COLOR_LIGHT_GREY);
cro_color_override(ctx->delta_a.gfx_ctx, COLOR_RED);
cro_color_override(ctx->delta_b.gfx_ctx, COLOR_GREEN2);
// @@@ clean up when leaving sheet
}
/* ----- Tools ------------------------------------------------------------- */
@ -277,34 +347,6 @@ static void hide_history(struct gui_ctx *ctx)
}
static struct gui_sheet *find_corresponding_sheet(struct gui_ctx *ctx,
struct gui_sheet *sheets)
{
struct gui_sheet *sheet, *plan_b;
const char *title = ctx->curr_sheet->sch->title;
/* plan A: try to find sheet with same name */
if (title)
for (sheet = sheets; sheet; sheet = sheet->next)
if (sheet->sch->title &&
!strcmp(title, sheet->sch->title))
return sheet;
/* plan B: use sheet in same position in sheet sequence */
plan_b = ctx->curr_hist->sheets;
for (sheet = sheets; sheet; sheet = sheet->next) {
if (plan_b == ctx->curr_sheet)
return sheet;
plan_b = plan_b->next;
}
/* plan C: just go to the top */
return sheets;
}
static bool hover_history(void *user, bool on)
{
struct gui_hist *h = user;
@ -330,22 +372,15 @@ static void do_sheet_overlays(struct gui_ctx *ctx);
static void go_to_history(struct gui_hist *h)
{
struct gui_ctx *ctx = h->ctx;
struct gui_sheet *sheet;
if (h == ctx->curr_hist) {
ctx->last_hist = NULL;
do_sheet_overlays(ctx);
} else {
/*
* Look up sheet BEFORE changing history (we need various
* items from ctx for this).
*
* Set sheet AFTER changing history.
*/
sheet = find_corresponding_sheet(ctx, h->sheets);
ctx->last_hist = ctx->curr_hist;
ctx->curr_hist = h;
go_to_sheet(ctx, sheet);
go_to_sheet(ctx, find_corresponding_sheet(h->sheets,
ctx->last_hist->sheets, ctx->curr_sheet));
}
}
@ -437,7 +472,7 @@ static void do_sheet_overlays(struct gui_ctx *ctx)
}
if (ctx->last_hist) {
ctx->last_hist->sheet_over = overlay_add(&ctx->sheet_overlays,
&ctx->aois, show_history_details, show_history_cb,
&ctx->aois, show_history_details, click_history,
ctx->last_hist);
overlay_style(ctx->curr_hist->sheet_over,
&overlay_style_diff_new);
@ -460,6 +495,8 @@ static void go_to_sheet(struct gui_ctx *ctx, struct gui_sheet *sheet)
mark_aois(ctx, sheet);
}
ctx->curr_sheet = sheet;
if (ctx->last_hist)
render_delta(ctx);
do_sheet_overlays(ctx);
zoom_to_extents(ctx);
}