📄 gvxmeas.c
字号:
/* Copyright (C) 2000, Ghostgum Software Pty Ltd. All rights reserved.
This file is part of GSview.
This program is distributed with NO WARRANTY OF ANY KIND. No author
or distributor accepts any responsibility for the consequences of using it,
or for whether it serves any particular purpose or works at all, unless he
or she says so in writing. Refer to the GSview Free Public Licence
(the "Licence") for full details.
Every copy of GSview must include a copy of the Licence, normally in a
plain ASCII text file named LICENCE. The Licence grants you the right
to copy, modify and redistribute GSview, but only under certain conditions
described in the Licence. Among other things, the Licence requires that
the copyright notice and this notice be preserved on all copies.
*/
/* gvxmeas.cpp */
#include "gvx.h"
#include <math.h>
#include "en/gvclang.h"
float measure_lastx;
float measure_lasty;
static const char measure_fmt[] = "%.5g";
static const char *ctmfmt = "%.5g" ;
extern float fthreshold;
void measure_transform_point(float x, float y, float *px, float *py);
#define degrees(x) (x * 180.0 / 3.14159265358979)
typedef struct tagCTMTEXT {
char xx[32];
char xy[32];
char yx[32];
char yy[32];
char tx[32];
char ty[32];
} CTMTEXT;
typedef struct tagCTMDLG {
GtkWidget *window;
GtkWidget *unit_pt;
GtkWidget *unit_mm;
GtkWidget *unit_inch;
GtkWidget *unit_custom;
GtkWidget *ctmxx;
GtkWidget *ctmxy;
GtkWidget *ctmyx;
GtkWidget *ctmyy;
GtkWidget *ctmtx;
GtkWidget *ctmty;
GtkWidget *tx;
GtkWidget *ty;
GtkWidget *translate;
GtkWidget *angle;
GtkWidget *rotate;
GtkWidget *sx;
GtkWidget *sy;
GtkWidget *scale;
GtkWidget *initmatrix;
GtkWidget *invertmatrix;
GtkWidget *button_ok;
GtkWidget *button_cancel;
GtkWidget *button_help;
MEASURE measure;
MATRIX ctm;
} CTMDLG;
void measure_dialog_unitx(void);
void calc_ctm(GtkWidget *w, gpointer data);
gint measure_delete(GtkWidget *widget, GdkEvent *event, gpointer data);
void show_calc_dialog(void);
void update_ctm_text(CTMTEXT *t, MATRIX *ctm);
void update_dialog_ctm(CTMDLG *dlg, MATRIX *ctm);
void dialog_put_float(GtkWidget *entry, float fx);
BOOL dialog_get_float_error(CTMDLG *dlg, GtkWidget *entry, float *fres,
BOOL error);
BOOL dialog_get_float(CTMDLG *dlg, GtkWidget *entry, float *fres);
BOOL dialog_get_ctm(CTMDLG *dlg, MATRIX *ctm, BOOL error);
void calc_enable_custom(CTMDLG *dlg, BOOL enable);
void calc_units(CTMDLG *dlg, int unit);
void calc_pts(GtkWidget *w, gpointer data);
void calc_mm(GtkWidget *w, gpointer data);
void calc_inch(GtkWidget *w, gpointer data);
void calc_custom(GtkWidget *w, gpointer data);
void calc_ro(GtkWidget *w, gpointer data);
void calc_tr(GtkWidget *w, gpointer data);
void calc_sc(GtkWidget *w, gpointer data);
void calc_ini(GtkWidget *w, gpointer data);
void calc_inv(GtkWidget *w, gpointer data);
GtkWidget *measure; /* main dialog */
GtkWidget *measure_unit; /* labels */
GtkWidget *measure_startx;
GtkWidget *measure_starty;
GtkWidget *measure_finishx;
GtkWidget *measure_finishy;
GtkWidget *measure_deltax;
GtkWidget *measure_deltay;
GtkWidget *measure_radius;
GtkWidget *measure_angle;
void
measure_update_last(void)
{
char buf[64];
float thisx, thisy;
if (measure == NULL)
return;
measure_transform_point(measure_lastx, measure_lasty, &thisx, &thisy);
if (fabs(thisx) < fthreshold)
thisx = 0.0;
if (fabs(thisy) < fthreshold)
thisy = 0.0;
sprintf(buf, measure_fmt, thisx);
gtk_label_set_text(GTK_LABEL(measure_startx), buf);
sprintf(buf, measure_fmt, thisx);
gtk_label_set_text(GTK_LABEL(measure_starty), buf);
}
void
measure_setpoint(float x, float y)
{
measure_lastx = x;
measure_lasty = y;
measure_update_last();
measure_paint(x, y);
}
/* This is called from motion_notify_event */
void
measure_paint(float x, float y)
{
float lastx, lasty;
float thisx, thisy;
float deltax, deltay;
float radius, angle;
char buf[64];
if (measure == NULL)
return;
measure_transform_point(x, y, &thisx, &thisy);
if (fabs(thisx) < fthreshold)
thisx = 0.0;
if (fabs(thisy) < fthreshold)
thisy = 0.0;
measure_transform_point(measure_lastx, measure_lasty, &lastx, &lasty);
if (fabs(lastx) < fthreshold)
lastx = 0.0;
if (fabs(lasty) < fthreshold)
lasty = 0.0;
deltax = thisx - lastx;
deltay = thisy - lasty;
if (fabs(deltax) < fthreshold)
deltax = 0.0;
if (fabs(deltay) < fthreshold)
deltay = 0.0;
radius = sqrt(deltax*deltax + deltay*deltay);
if ((deltax == 0.0) && (deltay == 0.0))
angle = 0.0;
else
angle = degrees( atan2(deltay, deltax) );
sprintf(buf, measure_fmt, thisx);
gtk_label_set_text(GTK_LABEL(measure_finishx), buf);
sprintf(buf, measure_fmt, thisy);
gtk_label_set_text(GTK_LABEL(measure_finishy), buf);
sprintf(buf, measure_fmt, deltax);
gtk_label_set_text(GTK_LABEL(measure_deltax), buf);
sprintf(buf, measure_fmt, deltay);
gtk_label_set_text(GTK_LABEL(measure_deltay), buf);
sprintf(buf, measure_fmt, radius);
gtk_label_set_text(GTK_LABEL(measure_radius), buf);
sprintf(buf, "%.2f", angle);
gtk_label_set_text(GTK_LABEL(measure_angle), buf);
}
void
measure_dialog_unitx(void)
{
if (measure_unit)
gtk_label_set_text(GTK_LABEL(measure_unit),
get_string(IDS_UNITNAME + option.measure.unit - IDM_UNITPT));
}
void calc_ctm(GtkWidget *w, gpointer data)
{
show_calc_dialog();
measure_dialog_unitx();
measure_update_last();
}
gint measure_delete(GtkWidget *widget, GdkEvent *event, gpointer data)
{
measure_close();
return TRUE;
}
void measure_close(void)
{
if (measure) {
if (debug & DEBUG_GENERAL)
gs_addmess("measure_close:\n");
gtk_widget_destroy(measure);
measure = NULL;
measure_startx = NULL;
measure_starty = NULL;
measure_finishx = NULL;
measure_finishy = NULL;
measure_deltax = NULL;
measure_deltay = NULL;
measure_radius = NULL;
measure_angle = NULL;
}
}
void
measure_show(void)
{
/* create measure dialog */
GtkWidget *table;
GtkWidget *con;
GtkWidget *label;
GtkWidget *button_change;
int y = 0;
if (measure != NULL) {
if (debug & DEBUG_GENERAL)
gs_addmess("measure_show: showing dialog\n");
gtk_widget_show(measure);
return;
}
measure_lastx = 0.0;
measure_lasty = 0.0;
measure=gtk_window_new(GTK_WINDOW_DIALOG);
gtk_container_set_border_width(GTK_CONTAINER(measure), 10);
gtk_window_set_title(GTK_WINDOW(measure), get_string(IDS_AAMEASURE));
table = gtk_table_new(4, 6, FALSE);
gtk_container_add(GTK_CONTAINER(measure), table);
/* row 0 */
label = gtk_label_new(get_string(IDS_AAUNITC));
gtk_widget_show(label);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), label);
gtk_table_attach_defaults(GTK_TABLE(table), con, 0, 1, y, y+1);
measure_unit = gtk_label_new("");
measure_dialog_unitx();
gtk_widget_show(measure_unit);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_unit);
gtk_table_attach_defaults(GTK_TABLE(table), con, 1, 2, y, y+1);
button_change = gtk_button_new_with_label(get_string(IDS_AACHANGE));
gtk_widget_show(button_change);
gtk_table_attach_defaults(GTK_TABLE(table), button_change, 2, 4, y, y+1);
y++;
/* row 1, blank line and set minimum spacing */
label = gtk_label_new(" ");
gtk_widget_show(label);
gtk_table_attach_defaults(GTK_TABLE(table), label, 0, 1, y, y+1);
label = gtk_label_new(" ");
gtk_widget_show(label);
gtk_table_attach_defaults(GTK_TABLE(table), label, 1, 2, y, y+1);
label = gtk_label_new(" ");
gtk_widget_show(label);
gtk_table_attach_defaults(GTK_TABLE(table), label, 2, 3, y, y+1);
y++;
/* row 2, start x y */
label = gtk_label_new(get_string(IDS_AASTARTC));
gtk_widget_show(label);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), label);
gtk_table_attach_defaults(GTK_TABLE(table), con, 0, 1, y, y+1);
measure_startx = gtk_label_new("x");
gtk_widget_show(measure_startx);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_startx);
gtk_table_attach_defaults(GTK_TABLE(table), con, 1, 2, y, y+1);
measure_starty = gtk_label_new("y");
gtk_widget_show(measure_starty);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_starty);
gtk_table_attach_defaults(GTK_TABLE(table), con, 2, 3, y, y+1);
y++;
/* row 3, finish x y */
label = gtk_label_new(get_string(IDS_AAFINISHC));
gtk_widget_show(label);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), label);
gtk_table_attach_defaults(GTK_TABLE(table), con, 0, 1, y, y+1);
measure_finishx = gtk_label_new("x");
gtk_widget_show(measure_finishx);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_finishx);
gtk_table_attach_defaults(GTK_TABLE(table), con, 1, 2, y, y+1);
measure_finishy = gtk_label_new("y");
gtk_widget_show(measure_finishy);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_finishy);
gtk_table_attach_defaults(GTK_TABLE(table), con, 2, 3, y, y+1);
y++;
/* row 4, delta x y */
label = gtk_label_new(get_string(IDS_AADELTAC));
gtk_widget_show(label);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), label);
gtk_table_attach_defaults(GTK_TABLE(table), con, 0, 1, y, y+1);
measure_deltax = gtk_label_new("x");
gtk_widget_show(measure_deltax);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_deltax);
gtk_table_attach_defaults(GTK_TABLE(table), con, 1, 2, y, y+1);
measure_deltay = gtk_label_new("y");
gtk_widget_show(measure_deltay);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_deltay);
gtk_table_attach_defaults(GTK_TABLE(table), con, 2, 3, y, y+1);
y++;
/* row 5, len radius angle */
label = gtk_label_new(get_string(IDS_AALENGTHC));
gtk_widget_show(label);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), label);
gtk_table_attach_defaults(GTK_TABLE(table), con, 0, 1, y, y+1);
measure_radius = gtk_label_new("r");
gtk_widget_show(measure_radius);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_radius);
gtk_table_attach_defaults(GTK_TABLE(table), con, 1, 2, y, y+1);
measure_angle = gtk_label_new("th");
gtk_widget_show(measure_angle);
con = gtk_alignment_new(1, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), measure_angle);
gtk_table_attach_defaults(GTK_TABLE(table), con, 2, 3, y, y+1);
label = gtk_label_new("\260");
gtk_widget_show(label);
con = gtk_alignment_new(0, 0, 0, 0);
gtk_widget_show(con);
gtk_container_add(GTK_CONTAINER(con), label);
gtk_table_attach_defaults(GTK_TABLE(table), con, 3, 4, y, y+1);
gtk_widget_show(GTK_WIDGET(table));
gtk_signal_connect(GTK_OBJECT(measure), "delete-event",
GTK_SIGNAL_FUNC(measure_delete), NULL);
gtk_signal_connect(GTK_OBJECT(button_change), "clicked",
GTK_SIGNAL_FUNC(calc_ctm), NULL);
measure_setpoint(0.0, 0.0);
gtk_widget_show(GTK_WIDGET(measure));
if (debug & DEBUG_GENERAL)
gs_addmessf("measure_show: created dialog\n");
}
void update_ctm_text(CTMTEXT *t, MATRIX *ctm)
{
/* round small values to zero */
if (fabs(ctm->xx) < fthreshold)
ctm->xx = 0.0;
if (fabs(ctm->xy) < fthreshold)
ctm->xy = 0.0;
if (fabs(ctm->yx) < fthreshold)
ctm->yx = 0.0;
if (fabs(ctm->yy) < fthreshold)
ctm->yy = 0.0;
if (fabs(ctm->tx) < fthreshold)
ctm->tx = 0.0;
if (fabs(ctm->ty) < fthreshold)
ctm->ty = 0.0;
sprintf(t->xx, ctmfmt, ctm->xx);
sprintf(t->xy, ctmfmt, ctm->xy);
sprintf(t->yx, ctmfmt, ctm->yx);
sprintf(t->yy, ctmfmt, ctm->yy);
sprintf(t->tx, ctmfmt, ctm->tx);
sprintf(t->ty, ctmfmt, ctm->ty);
}
void update_dialog_ctm(CTMDLG *dlg, MATRIX *ctm)
{
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -