Commit 0b7b696bd0e19818a87c4adbd94bd5bdef4192ca
1 parent
d3931317
Exists in
master
and in
1 other branch
Updating print dialog.
Showing
9 changed files
with
199 additions
and
439 deletions
Show diff stats
... | ... | @@ -0,0 +1,72 @@ |
1 | +/* | |
2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
5 | + * | |
6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
7 | + * | |
8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
10 | + * Free Software Foundation. | |
11 | + * | |
12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
15 | + * obter mais detalhes. | |
16 | + * | |
17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
20 | + * | |
21 | + * Este programa está nomeado como - e possui - linhas de código. | |
22 | + * | |
23 | + * Contatos: | |
24 | + * | |
25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
27 | + * | |
28 | + */ | |
29 | + | |
30 | + #include <v3270.h> | |
31 | + #include <v3270/print.h> | |
32 | + #include <lib3270/log.h> | |
33 | + | |
34 | +/*--[ Widget definition ]----------------------------------------------------------------------------*/ | |
35 | + | |
36 | + LIB3270_EXPORT GtkWidget * v3270_font_selection_new(const gchar *fontname) | |
37 | + { | |
38 | + GtkTreeModel * model = (GtkTreeModel *) gtk_list_store_new(1,G_TYPE_STRING); | |
39 | + GtkWidget * widget = gtk_combo_box_new_with_model(model); | |
40 | + | |
41 | + GtkCellRenderer * renderer = gtk_cell_renderer_text_new(); | |
42 | + gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(widget), renderer, TRUE); | |
43 | + gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(widget), renderer, "text", 0, NULL); | |
44 | + | |
45 | + if(!(fontname && *fontname)) | |
46 | + fontname = v3270_get_default_font_name(); | |
47 | + | |
48 | + gint n_families, i; | |
49 | + PangoFontFamily **families; | |
50 | + pango_context_list_families(gtk_widget_get_pango_context(widget),&families, &n_families); | |
51 | + | |
52 | + for(i=0; i < n_families; i++) | |
53 | + { | |
54 | + if(!pango_font_family_is_monospace(families[i])) | |
55 | + continue; | |
56 | + | |
57 | + const gchar *name = pango_font_family_get_name (families[i]); | |
58 | + GtkTreeIter iter; | |
59 | + | |
60 | + gtk_list_store_append((GtkListStore *) model,&iter); | |
61 | + gtk_list_store_set((GtkListStore *) model, &iter,0, name, -1); | |
62 | + | |
63 | + if(!g_ascii_strcasecmp(name,fontname)) | |
64 | + gtk_combo_box_set_active_iter(GTK_COMBO_BOX(widget),&iter); | |
65 | + | |
66 | + } | |
67 | + | |
68 | + g_free(families); | |
69 | + | |
70 | + return widget; | |
71 | + } | |
72 | + | ... | ... |
src/include/v3270.h
... | ... | @@ -220,6 +220,7 @@ |
220 | 220 | |
221 | 221 | // Misc |
222 | 222 | LIB3270_EXPORT GtkIMContext * v3270_get_im_context(GtkWidget *widget); |
223 | + LIB3270_EXPORT const gchar * v3270_get_default_font_name(); | |
223 | 224 | |
224 | 225 | LIB3270_EXPORT gboolean v3270_get_toggle(GtkWidget *widget, LIB3270_TOGGLE ix); |
225 | 226 | LIB3270_EXPORT gboolean v3270_set_toggle(GtkWidget *widget, LIB3270_TOGGLE ix, gboolean state); | ... | ... |
src/include/v3270/print.h
... | ... | @@ -40,18 +40,20 @@ |
40 | 40 | |
41 | 41 | #define GTK_TYPE_V3270_PRINT_OPERATION (V3270PrintOperation_get_type()) |
42 | 42 | #define GTK_V3270_PRINT_OPERATION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperation)) |
43 | - #define GTK_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperationClass)) | |
43 | + #define GTK_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_V3270_PRINT_OPERATION, V3270PrintOperationClass)) | |
44 | 44 | #define GTK_IS_V3270_PRINT_OPERATION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_V3270_PRINT_OPERATION)) |
45 | - #define GTK_IS_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_V3270_PRINT_OPERATION)) | |
46 | - #define GTK_V3270_PRINT_OPERATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270V3270PrintOperationClass)) | |
45 | + #define GTK_IS_V3270_PRINT_OPERATION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_V3270_PRINT_OPERATION)) | |
46 | + #define GTK_V3270_PRINT_OPERATION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_V3270_PRINT_OPERATION, V3270V3270PrintOperationClass)) | |
47 | 47 | |
48 | - typedef struct _V3270PrintOperation V3270PrintOperation; | |
49 | - typedef struct _V3270PrintPrintOperation V3270PrintOperationClass; | |
48 | + typedef struct _V3270PrintOperation V3270PrintOperation; | |
49 | + typedef struct _V3270PrintOperationClass V3270PrintOperationClass; | |
50 | 50 | |
51 | 51 | /*--[ Prototipes ]-----------------------------------------------------------------------------------*/ |
52 | 52 | |
53 | 53 | LIB3270_EXPORT V3270PrintOperation * v3270_print_operation_new(GtkWidget *widget, LIB3270_PRINT_MODE mode); |
54 | 54 | |
55 | + LIB3270_EXPORT GtkWidget * v3270_font_selection_new(const gchar *fontname); | |
56 | + | |
55 | 57 | G_END_DECLS |
56 | 58 | |
57 | 59 | #endif // V3270_PRINT_OPERATION_H_INCLUDED | ... | ... |
src/testprogram/testprogram.c
... | ... | @@ -103,6 +103,12 @@ static void color_scheme_changed(GtkWidget G_GNUC_UNUSED(*widget), const GdkRGBA |
103 | 103 | |
104 | 104 | } |
105 | 105 | |
106 | +static void print_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *terminal) | |
107 | +{ | |
108 | + debug("%s",__FUNCTION__); | |
109 | + v3270_print_all(terminal); | |
110 | +} | |
111 | + | |
106 | 112 | static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
107 | 113 | |
108 | 114 | /* |
... | ... | @@ -172,6 +178,9 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
172 | 178 | GtkWidget *box = gtk_box_new(GTK_ORIENTATION_VERTICAL,2); |
173 | 179 | GtkWidget *grid = gtk_grid_new(); |
174 | 180 | GtkWidget *color = v3270_color_scheme_new(); |
181 | + GtkWidget *print = gtk_button_new_with_label("Print"); | |
182 | + | |
183 | + g_signal_connect(G_OBJECT(print),"clicked",G_CALLBACK(print_clicked),terminal); | |
175 | 184 | |
176 | 185 | gtk_widget_set_can_focus(color,FALSE); |
177 | 186 | gtk_widget_set_focus_on_click(color,FALSE); |
... | ... | @@ -179,6 +188,7 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { |
179 | 188 | g_signal_connect(G_OBJECT(color),"update-colors",G_CALLBACK(color_scheme_changed),terminal); |
180 | 189 | |
181 | 190 | gtk_grid_attach(GTK_GRID(grid),color,0,0,1,1); |
191 | + gtk_grid_attach(GTK_GRID(grid),print,1,0,1,1); | |
182 | 192 | |
183 | 193 | gtk_box_pack_start(GTK_BOX(box),grid,FALSE,TRUE,0); |
184 | 194 | gtk_box_pack_start(GTK_BOX(box),terminal,TRUE,TRUE,0); | ... | ... |
src/trace/trace.c
... | ... | @@ -357,7 +357,7 @@ static void destroy(GtkWidget *widget) |
357 | 357 | gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(window->scroll),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC); |
358 | 358 | |
359 | 359 | window->view = gtk_text_view_new(); |
360 | - v3270_trace_set_font_from_string(GTK_WIDGET(window),"Monospaced"); | |
360 | + v3270_trace_set_font_from_string(GTK_WIDGET(window),v3270_get_default_font_name()); | |
361 | 361 | |
362 | 362 | window->text = gtk_text_view_get_buffer(GTK_TEXT_VIEW(window->view)); |
363 | 363 | gtk_text_view_set_editable(GTK_TEXT_VIEW(window->view), TRUE); | ... | ... |
src/v3270/font.c
... | ... | @@ -44,6 +44,11 @@ |
44 | 44 | |
45 | 45 | /*--[ Implement ]------------------------------------------------------------------------------------*/ |
46 | 46 | |
47 | +const gchar * v3270_get_default_font_name() | |
48 | +{ | |
49 | + return v3270_default_font; | |
50 | +} | |
51 | + | |
47 | 52 | void v3270_update_font_metrics(v3270 *terminal, cairo_t *cr, int width, int height) |
48 | 53 | { |
49 | 54 | // update font metrics | ... | ... |
src/v3270/print.c
... | ... | @@ -32,499 +32,180 @@ |
32 | 32 | #include "private.h" |
33 | 33 | #include <v3270.h> |
34 | 34 | #include <v3270/colorscheme.h> |
35 | + #include <v3270/print.h> | |
35 | 36 | #include <lib3270/selection.h> |
36 | 37 | #include <lib3270/log.h> |
37 | 38 | #include <lib3270/trace.h> |
38 | 39 | |
39 | - #define AUTO_FONT_SIZE 1 | |
40 | +/*--[ Widget definition ]----------------------------------------------------------------------------*/ | |
40 | 41 | |
41 | -#ifdef AUTO_FONT_SIZE | |
42 | - #define FONT_CONFIG "font-family" | |
43 | - #define DEFAULT_FONT "Courier New" | |
44 | -#else | |
45 | - #define FONT_CONFIG "font" | |
46 | - #define DEFAULT_FONT "Courier New 10" | |
47 | -#endif // AUTO_FONT_SIZE | |
48 | - | |
49 | -/*--[ Structs ]--------------------------------------------------------------------------------------*/ | |
50 | - | |
51 | - typedef struct _print_info | |
52 | - { | |
53 | - GdkRGBA color[V3270_COLOR_COUNT]; | |
54 | - int show_selection : 1; | |
55 | - LIB3270_PRINT_MODE src; | |
56 | - | |
57 | - v3270 * widget; | |
58 | - | |
59 | - int baddr; | |
60 | - int rows; | |
61 | - int cols; ///< @brief Max line width. | |
62 | - int pages; | |
63 | - int lpp; ///< @brief Lines per page. | |
64 | - | |
65 | - v3270FontInfo font; | |
66 | - | |
67 | - double left; | |
68 | - double width; ///< @brief Report width. | |
69 | - double height; ///< @brief Report height (all pages). | |
70 | - | |
71 | - gchar **text; | |
72 | - | |
73 | - } PRINT_INFO; | |
74 | - | |
75 | - | |
76 | -/*--[ Implement ]------------------------------------------------------------------------------------*/ | |
77 | - | |
78 | - static void begin_print(GtkPrintOperation *prt, GtkPrintContext *context, PRINT_INFO *info) | |
42 | + struct _V3270PrintOperationClass | |
79 | 43 | { |
80 | - cairo_font_extents_t extents; | |
81 | - cairo_t * cr = gtk_print_context_get_cairo_context(context); | |
82 | - | |
83 | - // Setup font | |
84 | - if(info->font.family) | |
85 | - { | |
86 | - PangoFontDescription * descr = pango_font_description_from_string(info->font.family); | |
87 | - if(descr) | |
88 | - { | |
89 | - cairo_select_font_face(cr, pango_font_description_get_family(descr), | |
90 | - CAIRO_FONT_SLANT_NORMAL, | |
91 | - pango_font_description_get_weight(descr) == PANGO_WEIGHT_BOLD ? CAIRO_FONT_WEIGHT_BOLD : CAIRO_FONT_WEIGHT_NORMAL); | |
92 | - | |
93 | -#ifdef AUTO_FONT_SIZE | |
94 | - { | |
95 | - double width = gtk_print_context_get_width(context); | |
96 | -#if GTK_CHECK_VERSION(3,0,0) | |
97 | - double cols = (double) info->cols; | |
98 | -#else | |
99 | - double cols = (double) (info->cols+5); | |
100 | -#endif // GTK(3,0,0) | |
101 | - double current = width / cols; | |
102 | - double valid = current; | |
103 | - | |
104 | - do | |
105 | - { | |
106 | - valid = current; | |
107 | - current = valid +1.0; | |
108 | - cairo_set_font_size(cr,current); | |
109 | - cairo_font_extents(cr,&extents); | |
110 | - } | |
111 | - while( (cols * extents.max_x_advance) < width ); | |
112 | - | |
113 | - cairo_set_font_size(cr,valid); | |
114 | - | |
115 | - } | |
116 | -#endif // AUTO_FONT_SIZE | |
117 | - | |
118 | - pango_font_description_free(descr); | |
119 | - } | |
120 | - } | |
121 | - | |
122 | - info->font.scaled = cairo_get_scaled_font(cr); | |
123 | - cairo_scaled_font_reference(info->font.scaled); | |
124 | - cairo_scaled_font_extents(info->font.scaled,&extents); | |
125 | - | |
126 | - info->font.height = extents.height; | |
127 | - info->font.descent = extents.descent; | |
128 | - info->font.width = extents.max_x_advance; | |
129 | - | |
130 | - info->width = ((double) info->cols) * extents.max_x_advance; | |
131 | - info->height = ((double) info->rows) * (extents.height + extents.descent); | |
132 | - | |
133 | - // Center image | |
134 | - info->left = (gtk_print_context_get_width(context)-info->width)/2; | |
135 | - if(info->left < 2) | |
136 | - info->left = 2; | |
137 | - | |
138 | - // Setup page size | |
139 | - info->lpp = (gtk_print_context_get_height(context) / (extents.height + extents.descent)); | |
140 | - info->pages = (info->rows / info->lpp)+1; | |
44 | + GtkPrintOperationClass parent_class; | |
141 | 45 | |
142 | - gtk_print_operation_set_n_pages(prt,info->pages); | |
143 | - } | |
46 | + }; | |
144 | 47 | |
145 | - static void draw_screen(GtkPrintOperation *prt, GtkPrintContext *context, gint pg, PRINT_INFO *info) | |
48 | + struct _V3270PrintOperation | |
146 | 49 | { |
147 | - int row; | |
148 | - int col; | |
149 | - cairo_t * cr = gtk_print_context_get_cairo_context(context); | |
150 | - int baddr = info->baddr; | |
151 | - GdkRectangle rect; | |
50 | + GtkPrintOperation parent; | |
51 | + GdkRGBA color[V3270_COLOR_COUNT]; | |
52 | + LIB3270_PRINT_MODE mode; | |
53 | + v3270 * widget; | |
54 | + H3270 * session; | |
152 | 55 | |
153 | - cairo_set_scaled_font(cr,info->font.scaled); | |
56 | + struct { | |
57 | + gchar * name; | |
58 | + v3270FontInfo info; | |
59 | + } font; | |
154 | 60 | |
155 | - memset(&rect,0,sizeof(rect)); | |
156 | - rect.y = 2; | |
157 | - rect.height = (info->font.height + info->font.descent); | |
158 | - rect.width = info->font.width; | |
61 | + gboolean show_selection; | |
159 | 62 | |
160 | - // Clear page | |
161 | - gdk_cairo_set_source_rgba(cr,info->color+V3270_COLOR_BACKGROUND); | |
162 | - cairo_rectangle(cr, info->left-2, 0, (rect.width*info->cols)+4, (rect.height*info->rows)+4); | |
163 | - cairo_fill(cr); | |
164 | - cairo_stroke(cr); | |
165 | 63 | |
166 | - rect.width++; | |
167 | - rect.height++; | |
64 | + }; | |
168 | 65 | |
169 | - for(row = 0; row < info->rows; row++) | |
170 | - { | |
171 | - rect.x = info->left; | |
172 | - for(col = 0; col < info->cols; col++) | |
173 | - { | |
174 | - unsigned char c; | |
175 | - unsigned short attr; | |
176 | - | |
177 | - if(!lib3270_get_element(info->widget->host,baddr++,&c,&attr) && (info->src == LIB3270_PRINT_ALL || (attr & LIB3270_ATTR_SELECTED))) | |
178 | - { | |
179 | - if(!info->show_selection) | |
180 | - attr &= ~LIB3270_ATTR_SELECTED; | |
181 | - v3270_draw_element(cr,c,attr,info->widget->host,&info->font,&rect,info->color); | |
182 | - } | |
183 | - | |
184 | - rect.x += (rect.width-1); | |
185 | - } | |
186 | - rect.y += (rect.height-1); | |
66 | + G_DEFINE_TYPE(V3270PrintOperation, V3270PrintOperation, GTK_TYPE_PRINT_OPERATION); | |
187 | 67 | |
188 | - } | |
189 | - } | |
190 | - | |
191 | - /* | |
192 | - static void show_print_error(GtkWidget *widget, GError *err) | |
193 | - { | |
194 | - GtkWidget *dialog = gtk_message_dialog_new_with_markup( GTK_WINDOW(gtk_widget_get_toplevel(widget)), | |
195 | - GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, | |
196 | - GTK_MESSAGE_ERROR,GTK_BUTTONS_CLOSE, | |
197 | - "%s",_( "Print operation failed" )); | |
198 | - | |
199 | - g_warning("%s",err->message); | |
200 | - | |
201 | - gtk_window_set_title(GTK_WINDOW(dialog),_("Error")); | |
202 | - | |
203 | - gtk_message_dialog_format_secondary_markup(GTK_MESSAGE_DIALOG(dialog),"%s",err->message); | |
204 | - | |
205 | - gtk_dialog_run(GTK_DIALOG(dialog)); | |
206 | - gtk_widget_destroy(dialog); | |
207 | -} | |
208 | -*/ | |
68 | +/*--[ Implement ]------------------------------------------------------------------------------------*/ | |
209 | 69 | |
210 | - static void done(GtkPrintOperation *prt, GtkPrintOperationResult result, PRINT_INFO *info) | |
70 | + static void done(GtkPrintOperation *prt, GtkPrintOperationResult result) | |
211 | 71 | { |
212 | - debug("%s(%p)",__FUNCTION__,info->widget); | |
213 | - g_signal_emit(info->widget, v3270_widget_signal[SIGNAL_PRINT_DONE], 0, prt, (guint) result); | |
72 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(prt); | |
214 | 73 | |
215 | 74 | debug("%s",__FUNCTION__); |
216 | - if(info->font.scaled) | |
217 | - cairo_scaled_font_destroy(info->font.scaled); | |
218 | - | |
219 | - debug("%s",__FUNCTION__); | |
220 | - if(info->text) | |
221 | - g_strfreev(info->text); | |
222 | - | |
223 | - debug("%s",__FUNCTION__); | |
224 | - if(info->font.family) | |
225 | - g_free(info->font.family); | |
226 | - | |
227 | - debug("%s",__FUNCTION__); | |
228 | - g_free(info); | |
229 | - debug("%s",__FUNCTION__); | |
230 | - } | |
231 | - | |
232 | -#ifndef AUTO_FONT_SIZE | |
233 | - | |
234 | -#if GTK_CHECK_VERSION(3,2,0) | |
235 | - static gboolean filter_monospaced(const PangoFontFamily *family,const PangoFontFace *face,gpointer data) | |
236 | - { | |
237 | - return pango_font_family_is_monospace((PangoFontFamily *) family); | |
238 | - } | |
239 | -#endif // GTK(3,2,0) | |
240 | - | |
241 | - static void font_set(GtkFontButton *widget, PRINT_INFO *info) | |
242 | - { | |
243 | - if(info->font) | |
244 | - g_free(info->font); | |
245 | - info->font = g_strdup(gtk_font_button_get_font_name(widget)); | |
246 | - } | |
247 | - | |
248 | -#else | |
249 | - | |
250 | - static void font_name_changed(GtkComboBox *combo, PRINT_INFO *info) | |
251 | - { | |
252 | - GValue value = { 0, }; | |
253 | - GtkTreeIter iter; | |
254 | - | |
255 | - if(!gtk_combo_box_get_active_iter(combo,&iter)) | |
256 | - return; | |
257 | - | |
258 | - gtk_tree_model_get_value(gtk_combo_box_get_model(combo),&iter,0,&value); | |
259 | 75 | |
260 | - if(info->font.family) | |
261 | - g_free(info->font.family); | |
262 | - | |
263 | - info->font.family = g_value_dup_string(&value); | |
76 | + if(operation->widget) | |
77 | + g_signal_emit(GTK_WIDGET(operation->widget), v3270_widget_signal[SIGNAL_PRINT_DONE], 0, prt, (guint) result); | |
264 | 78 | |
265 | 79 | } |
266 | 80 | |
267 | -#endif // !AUTO_FONT_SIZE | |
268 | - | |
269 | - static void toggle_show_selection(GtkToggleButton *togglebutton,PRINT_INFO *info) | |
81 | +#ifndef _WIN32 | |
82 | + static GtkWidget * create_custom_widget(GtkPrintOperation *prt) | |
270 | 83 | { |
271 | - gboolean active = gtk_toggle_button_get_active(togglebutton); | |
272 | - info->show_selection = active ? 1 : 0; | |
273 | - } | |
274 | - | |
275 | - static GObject * create_custom_widget(GtkPrintOperation *prt, PRINT_INFO *info) | |
276 | - { | |
277 | - GtkWidget * container = gtk_table_new(3,2,FALSE); | |
278 | - static const gchar * text[] = { N_( "_Font:" ), N_( "C_olor scheme:" ) }; | |
279 | - GtkWidget * label[G_N_ELEMENTS(text)]; | |
280 | - GtkWidget * widget; | |
281 | - size_t f; | |
282 | - | |
283 | - for(f=0;f<G_N_ELEMENTS(label);f++) | |
84 | + static const gchar * text[] = | |
284 | 85 | { |
285 | - label[f] = gtk_label_new_with_mnemonic(gettext(text[f])); | |
286 | - gtk_misc_set_alignment(GTK_MISC(label[f]),0,0.5); | |
287 | - gtk_table_attach(GTK_TABLE(container),label[f],0,1,f,f+1,GTK_FILL,GTK_FILL,0,0); | |
288 | - } | |
86 | + N_( "_Font:" ), | |
87 | + N_( "C_olor scheme:" ) | |
88 | + }; | |
289 | 89 | |
290 | - // Font selection button | |
291 | -#ifdef AUTO_FONT_SIZE | |
292 | - { | |
293 | - GtkTreeModel * model = (GtkTreeModel *) gtk_list_store_new(1,G_TYPE_STRING); | |
294 | - GtkCellRenderer * renderer = gtk_cell_renderer_text_new(); | |
295 | - PangoFontFamily **families; | |
296 | - gint n_families, i; | |
297 | - GtkTreeIter iter; | |
90 | + size_t f; | |
298 | 91 | |
299 | - widget = gtk_combo_box_new_with_model(model); | |
92 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(prt); | |
300 | 93 | |
301 | - gtk_cell_layout_pack_start(GTK_CELL_LAYOUT(widget), renderer, TRUE); | |
302 | - gtk_cell_layout_set_attributes(GTK_CELL_LAYOUT(widget), renderer, "text", 0, NULL); | |
94 | + if(operation->widget) | |
95 | + g_signal_emit(operation->widget, v3270_widget_signal[SIGNAL_PRINT_SETUP], 0, prt); | |
303 | 96 | |
304 | - g_signal_connect(G_OBJECT(widget),"changed",G_CALLBACK(font_name_changed),info); | |
97 | + // Create dialog | |
305 | 98 | |
306 | - pango_context_list_families(gtk_widget_get_pango_context(container),&families, &n_families); | |
99 | + GtkGrid * grid = GTK_GRID(gtk_grid_new()); | |
100 | + GtkWidget * font = v3270_font_selection_new(operation->font.name); | |
101 | + GtkWidget * color = v3270_color_scheme_new(); | |
307 | 102 | |
308 | - for(i=0; i<n_families; i++) | |
309 | - { | |
310 | - if(pango_font_family_is_monospace(families[i])) | |
311 | - { | |
312 | - const gchar *name = pango_font_family_get_name (families[i]); | |
313 | - gtk_list_store_append((GtkListStore *) model,&iter); | |
314 | - gtk_list_store_set((GtkListStore *) model, &iter,0, name, -1); | |
103 | + gtk_container_set_border_width(GTK_CONTAINER(grid),10); | |
104 | + gtk_grid_set_row_spacing(grid,5); | |
105 | + gtk_grid_set_column_spacing(grid,5); | |
315 | 106 | |
316 | - if(!g_ascii_strcasecmp(name,info->font.family)) | |
317 | - gtk_combo_box_set_active_iter(GTK_COMBO_BOX(widget),&iter); | |
318 | - } | |
319 | - } | |
107 | + v3270_color_scheme_set_rgba(color,operation->color); | |
320 | 108 | |
321 | - g_free(families); | |
322 | - } | |
323 | -#else | |
109 | + for(f=0;f<G_N_ELEMENTS(text);f++) | |
324 | 110 | { |
325 | - widget = gtk_font_button_new_with_font(info->font); | |
326 | - gtk_font_button_set_show_size((GtkFontButton *) widget,TRUE); | |
327 | - gtk_font_button_set_use_font((GtkFontButton *) widget,TRUE); | |
328 | - gtk_label_set_mnemonic_widget(GTK_LABEL(label[0]),widget); | |
329 | - g_free(info->font); | |
330 | - | |
331 | -#if GTK_CHECK_VERSION(3,2,0) | |
332 | - gtk_font_chooser_set_filter_func((GtkFontChooser *) widget,filter_monospaced,NULL,NULL); | |
333 | -#endif // GTK(3,2,0) | |
334 | - | |
335 | - g_signal_connect(G_OBJECT(widget),"font-set",G_CALLBACK(font_set),info); | |
336 | - | |
111 | + GtkWidget *label = gtk_label_new_with_mnemonic(gettext(text[f])); | |
112 | + gtk_misc_set_alignment(GTK_MISC(label),0,0.5); | |
113 | + gtk_grid_attach(grid,label,0,f,1,1); | |
337 | 114 | } |
338 | -#endif | |
339 | - | |
340 | - gtk_table_attach(GTK_TABLE(container),widget,1,2,0,1,GTK_EXPAND|GTK_FILL,GTK_FILL,5,0); | |
341 | - | |
342 | - g_signal_emit(info->widget, v3270_widget_signal[SIGNAL_PRINT_BEGIN], 0, prt); | |
343 | 115 | |
116 | + gtk_grid_attach(grid,font,1,0,1,1); | |
117 | + gtk_grid_attach(grid,color,1,1,1,1); | |
344 | 118 | |
345 | - widget = v3270_color_scheme_new(); | |
346 | - v3270_color_scheme_set_rgba(widget,info->color); | |
347 | - gtk_label_set_mnemonic_widget(GTK_LABEL(label[1]),widget); | |
348 | - | |
349 | - g_object_set_data(G_OBJECT(container),"combo",widget); | |
350 | - gtk_table_attach(GTK_TABLE(container),widget,1,2,1,2,GTK_EXPAND|GTK_FILL,GTK_FILL,5,0); | |
351 | - | |
352 | - // Selection checkbox | |
353 | - widget = gtk_check_button_new_with_label( _("Print selection box") ); | |
119 | + gtk_widget_show_all(GTK_WIDGET(grid)); | |
120 | + return GTK_WIDGET(grid); | |
121 | + } | |
354 | 122 | |
355 | - if(info->src == LIB3270_PRINT_ALL) | |
356 | - { | |
357 | - info->show_selection = FALSE; | |
358 | - gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget),info->show_selection); | |
359 | - g_signal_connect(G_OBJECT(widget),"toggled",G_CALLBACK(toggle_show_selection),info); | |
360 | - } | |
361 | - else | |
362 | - { | |
363 | - gtk_widget_set_sensitive(widget,FALSE); | |
364 | - } | |
123 | + static void custom_widget_apply(GtkPrintOperation *prt, GtkWidget *widget) | |
124 | + { | |
125 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(prt); | |
365 | 126 | |
366 | - gtk_table_attach(GTK_TABLE(container),widget,1,2,2,3,GTK_EXPAND|GTK_FILL,GTK_FILL,5,0); | |
127 | + debug("%s",__FUNCTION__); | |
367 | 128 | |
368 | - // Show and return | |
369 | - gtk_widget_show_all(container); | |
129 | + if(operation->widget) | |
130 | + g_signal_emit(operation->widget, v3270_widget_signal[SIGNAL_PRINT_APPLY], 0, prt); | |
370 | 131 | |
371 | - return G_OBJECT(container); | |
372 | 132 | } |
133 | +#endif // _WIN32 | |
373 | 134 | |
374 | - static void custom_widget_apply(GtkPrintOperation *prt, GtkWidget *widget, PRINT_INFO *info) | |
135 | + static void dispose(GObject *object) | |
375 | 136 | { |
376 | - g_signal_emit(info->widget, v3270_widget_signal[SIGNAL_PRINT_APPLY], 0, prt); | |
377 | - | |
378 | - /* | |
379 | - GtkWidget * combo = g_object_get_data(G_OBJECT(widget),"combo"); | |
380 | - GdkRGBA * clr = g_object_get_data(G_OBJECT(combo),"selected"); | |
381 | - | |
382 | - trace("%s starts combo=%p clr=%p widget=%p",__FUNCTION__,combo,clr,widget); | |
137 | + debug("%s",__FUNCTION__); | |
383 | 138 | |
384 | - if(info->font.family) | |
385 | - set_string_to_config("print",FONT_CONFIG,info->font.family); | |
139 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(object); | |
386 | 140 | |
387 | - if(clr) | |
388 | - { | |
389 | - int f; | |
390 | - GString *str = g_string_new(""); | |
391 | - for(f=0;f<V3270_COLOR_COUNT;f++) | |
392 | - { | |
393 | - info->color[f] = clr[f]; | |
394 | - if(f) | |
395 | - g_string_append_c(str,';'); | |
396 | - g_string_append_printf(str,"%s",gdk_rgba_to_string(clr+f)); | |
397 | - } | |
398 | - set_string_to_config("print","colors","%s",str->str); | |
399 | - g_string_free(str,TRUE); | |
400 | - } | |
401 | - | |
402 | - trace("%s ends",__FUNCTION__); | |
403 | - */ | |
141 | + g_free(operation->font.name); | |
404 | 142 | |
405 | 143 | } |
406 | 144 | |
407 | - static GtkPrintOperation * begin_print_operation(GtkWidget *widget, PRINT_INFO **info) | |
145 | + static void V3270PrintOperation_class_init(V3270PrintOperationClass *klass) | |
408 | 146 | { |
409 | - GtkPrintOperation * print = gtk_print_operation_new(); | |
410 | - GtkPrintSettings * settings = gtk_print_settings_new(); | |
411 | - GtkPageSetup * setup = gtk_page_setup_new(); | |
412 | - // GtkPaperSize * papersize = NULL; | |
413 | - | |
414 | - *info = g_new0(PRINT_INFO,1); | |
415 | - (*info)->cols = 80; | |
416 | - (*info)->widget = widget; | |
417 | - (*info)->font.family = g_strdup(DEFAULT_FONT); | |
147 | + GtkPrintOperationClass * operation = GTK_PRINT_OPERATION_CLASS(klass); | |
418 | 148 | |
419 | - debug("%s",__FUNCTION__); | |
420 | - gtk_print_operation_set_custom_tab_label(print, _( "Options" ) ); | |
421 | - gtk_print_operation_set_show_progress(print,TRUE); | |
149 | + G_OBJECT_CLASS(klass)->dispose = dispose; | |
150 | + operation->done = done; | |
422 | 151 | |
423 | - // Common signals | |
152 | +#ifndef _WIN32 | |
153 | + operation->create_custom_widget = create_custom_widget; | |
154 | + operation->custom_widget_apply = custom_widget_apply; | |
155 | +#endif // _WIN32 | |
156 | + /* | |
157 | + // Common signals | |
424 | 158 | g_signal_connect(print,"done",G_CALLBACK(done),*info); |
425 | 159 | |
426 | 160 | #if GTK_CHECK_VERSION(3,0,0) && !defined(WIN32) |
427 | - g_signal_connect(print,"create-custom-widget",G_CALLBACK(create_custom_widget), *info); | |
428 | - g_signal_connect(print,"custom-widget-apply",G_CALLBACK(custom_widget_apply), *info); | |
161 | + g_signal_connect(print,"create-custom-widget",G_CALLBACK(create_custom_widget), *info); | |
162 | + g_signal_connect(print,"custom-widget-apply",G_CALLBACK(custom_widget_apply), *info); | |
429 | 163 | #endif // !WIN32 |
164 | +*/ | |
430 | 165 | |
431 | - // Finish settings | |
432 | - gtk_print_operation_set_print_settings(print,settings); | |
433 | - //gtk_page_setup_set_paper_size_and_default_margins(setup,papersize); | |
434 | - gtk_print_operation_set_default_page_setup(print,setup); | |
435 | - | |
436 | - return print; | |
437 | 166 | } |
438 | 167 | |
439 | - static void draw_text(GtkPrintOperation *prt, GtkPrintContext *context, gint pg, PRINT_INFO *info) | |
168 | + static void V3270PrintOperation_init(V3270PrintOperation *widget) | |
440 | 169 | { |
441 | - cairo_t * cr = gtk_print_context_get_cairo_context(context); | |
442 | - GdkRectangle rect; | |
443 | - int row = pg*info->lpp; | |
444 | - int l; | |
170 | + // Setup print operation. | |
171 | + gtk_print_operation_set_custom_tab_label(GTK_PRINT_OPERATION(widget), _( "Options" ) ); | |
172 | + gtk_print_operation_set_show_progress(GTK_PRINT_OPERATION(widget),TRUE); | |
173 | + gtk_print_operation_set_print_settings(GTK_PRINT_OPERATION(widget),gtk_print_settings_new()); | |
174 | + gtk_print_operation_set_default_page_setup(GTK_PRINT_OPERATION(widget),gtk_page_setup_new()); | |
445 | 175 | |
446 | - cairo_set_scaled_font(cr,info->font.scaled); | |
447 | 176 | |
448 | - memset(&rect,0,sizeof(rect)); | |
449 | - rect.y = 2; | |
450 | - rect.height = (info->font.height + info->font.descent)+1; | |
451 | - rect.width = info->font.width+1; | |
177 | + // Setup defaults | |
178 | + widget->mode = LIB3270_PRINT_ALL; | |
179 | + widget->show_selection = FALSE; | |
180 | + widget->font.name = g_strdup(v3270_default_font); | |
452 | 181 | |
453 | - for(l=0;l<info->lpp && row < info->rows;l++) | |
454 | - { | |
455 | - cairo_move_to(cr,2,rect.y+rect.height); | |
456 | - cairo_show_text(cr, info->text[row]); | |
457 | - cairo_stroke(cr); | |
458 | - row++; | |
459 | - rect.y += (rect.height-1); | |
460 | - } | |
182 | + v3270_set_mono_color_table(widget->color,"#000000","#FFFFFF"); | |
461 | 183 | |
462 | 184 | } |
463 | 185 | |
464 | - static void print_operation(GtkWidget *widget, GtkPrintOperationAction oper, LIB3270_PRINT_MODE mode) | |
465 | - { | |
466 | - PRINT_INFO * info = NULL; | |
467 | - GtkPrintOperation * print; | |
468 | - gchar * text; | |
469 | - GError * err = NULL; | |
470 | - | |
471 | - g_return_if_fail(GTK_IS_V3270(widget)); | |
472 | - | |
473 | - print = begin_print_operation(widget,&info); | |
474 | - if(!print) | |
475 | - return; | |
476 | - | |
477 | - lib3270_get_screen_size(info->widget->host,&info->rows,&info->cols); | |
186 | +V3270PrintOperation * v3270_print_operation_new(GtkWidget *widget, LIB3270_PRINT_MODE mode) | |
187 | +{ | |
188 | + g_return_val_if_fail(GTK_IS_V3270(widget),NULL); | |
478 | 189 | |
479 | - info->src = mode; | |
480 | - | |
481 | - g_signal_connect(print,"begin_print",G_CALLBACK(begin_print),info); | |
482 | - | |
483 | - switch(mode) | |
484 | - { | |
485 | - case LIB3270_PRINT_ALL: | |
486 | - case LIB3270_PRINT_SELECTED: | |
487 | - g_signal_connect(print,"draw_page",G_CALLBACK(draw_screen),info); | |
488 | - break; | |
190 | + V3270PrintOperation * operation = GTK_V3270_PRINT_OPERATION(g_object_new(GTK_TYPE_V3270_PRINT_OPERATION, NULL)); | |
489 | 191 | |
490 | - case LIB3270_PRINT_COPY: | |
192 | + operation->mode = mode; | |
193 | + operation->widget = GTK_V3270(widget); | |
194 | + operation->session = v3270_get_session(widget); | |
491 | 195 | |
492 | - text = v3270_get_copy(widget); | |
493 | - | |
494 | - if(text) | |
495 | - { | |
496 | - int r; | |
497 | - | |
498 | - info->text = g_strsplit(text,"\n",-1); | |
499 | - info->rows = g_strv_length(info->text); | |
500 | - | |
501 | - for(r=0;r < info->rows;r++) | |
502 | - { | |
503 | - size_t sz = strlen(info->text[r]); | |
504 | - if(sz > info->cols) | |
505 | - info->cols = sz; | |
506 | - } | |
507 | - g_free(text); | |
508 | - } | |
509 | - g_signal_connect(print,"draw_page",G_CALLBACK(draw_text),info); | |
510 | - break; | |
511 | - | |
512 | - | |
513 | - } | |
514 | - | |
515 | - // Run Print dialog | |
516 | - gtk_print_operation_run(print,oper,GTK_WINDOW(gtk_widget_get_toplevel(widget)),&err); | |
517 | - | |
518 | - if(err) | |
519 | - g_error_free(err); | |
520 | - | |
521 | - g_object_unref(print); | |
196 | + return operation; | |
197 | +} | |
522 | 198 | |
523 | - } | |
199 | +/*--[ Convenience ]----------------------------------------------------------------------------------*/ | |
524 | 200 | |
525 | 201 | void v3270_print(GtkWidget *widget, LIB3270_PRINT_MODE mode) |
526 | 202 | { |
527 | - print_operation(widget,GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG, mode); | |
203 | + g_autoptr(GError) err = NULL; | |
204 | + | |
205 | + V3270PrintOperation * operation = v3270_print_operation_new(widget, mode); | |
206 | + gtk_print_operation_run(GTK_PRINT_OPERATION(operation),GTK_PRINT_OPERATION_ACTION_PRINT_DIALOG,GTK_WINDOW(gtk_widget_get_toplevel(widget)),&err); | |
207 | + g_object_unref(operation); | |
208 | + | |
528 | 209 | } |
529 | 210 | |
530 | 211 | void v3270_print_all(GtkWidget *widget) | ... | ... |
src/v3270/private.h
src/v3270/widget.c
... | ... | @@ -497,18 +497,7 @@ static void v3270_class_init(v3270Class *klass) |
497 | 497 | G_TYPE_BOOLEAN, 3, G_TYPE_BOOLEAN, G_TYPE_UINT, G_TYPE_POINTER); |
498 | 498 | |
499 | 499 | |
500 | - /* | |
501 | - v3270_widget_signal[SIGNAL_PRINT] = | |
502 | - g_signal_new( "print", | |
503 | - G_OBJECT_CLASS_TYPE (gobject_class), | |
504 | - G_SIGNAL_RUN_FIRST, | |
505 | - 0, | |
506 | - NULL, NULL, | |
507 | - v3270_VOID__VOID, | |
508 | - G_TYPE_NONE, 0); | |
509 | - */ | |
510 | - | |
511 | - v3270_widget_signal[SIGNAL_PRINT_BEGIN] = | |
500 | + v3270_widget_signal[SIGNAL_PRINT_SETUP] = | |
512 | 501 | g_signal_new( "print-begin", |
513 | 502 | G_OBJECT_CLASS_TYPE (gobject_class), |
514 | 503 | G_SIGNAL_RUN_FIRST, | ... | ... |