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, | ... | ... |