Commit bc4c1af21c59d941d9d3e3fa056aaa54342cb600
1 parent
2bc1baf7
Exists in
master
and in
1 other branch
Implementando sinal quando algum elemento da OIA receb um click, incluindo trata…
…mento de ponteiros ao movimentar o mouse sobre a OIA
Showing
5 changed files
with
133 additions
and
34 deletions
Show diff stats
genmarshal
mouse.c
| ... | ... | @@ -128,28 +128,49 @@ void v3270_emit_popup(v3270 *widget, int baddr, GdkEventButton *event) |
| 128 | 128 | gdk_beep(); |
| 129 | 129 | } |
| 130 | 130 | |
| 131 | -gboolean v3270_button_press_event(GtkWidget *widget, GdkEventButton *event) | |
| 131 | +static V3270_OIA_FIELD get_field_from_event(v3270 *widget, GdkEventButton *event) | |
| 132 | 132 | { |
| 133 | - int baddr = v3270_get_offset_at_point(GTK_V3270(widget),event->x,event->y); | |
| 133 | + if(event->y >= widget->oia_rect->y) | |
| 134 | + { | |
| 135 | + V3270_OIA_FIELD f; | |
| 134 | 136 | |
| 135 | - if(baddr < 0) | |
| 136 | - return FALSE; | |
| 137 | + for(f=0;f<V3270_OIA_FIELD_COUNT;f++) | |
| 138 | + { | |
| 139 | + if(event->x >= widget->oia_rect[f].x && event->x <= (widget->oia_rect[f].x+widget->oia_rect[f].width)) | |
| 140 | + return f; | |
| 141 | + } | |
| 142 | + } | |
| 137 | 143 | |
| 138 | -// trace("%s button=%d type=%d",__FUNCTION__,event->button,event->type); | |
| 144 | + return V3270_OIA_FIELD_INVALID; | |
| 145 | +} | |
| 139 | 146 | |
| 140 | - switch(event->button) | |
| 147 | +gboolean v3270_button_press_event(GtkWidget *widget, GdkEventButton *event) | |
| 148 | +{ | |
| 149 | + int baddr = v3270_get_offset_at_point(GTK_V3270(widget),event->x,event->y); | |
| 150 | + | |
| 151 | + if(baddr >= 0) | |
| 141 | 152 | { |
| 142 | - case 1: // Left button | |
| 143 | - button_1_press(widget,event->type,baddr); | |
| 144 | - break; | |
| 153 | + GTK_V3270(widget)->selected_field = V3270_OIA_FIELD_INVALID; | |
| 145 | 154 | |
| 146 | - case 3: // Right button | |
| 147 | - if(event->type == GDK_BUTTON_PRESS) | |
| 148 | - v3270_emit_popup(GTK_V3270(widget),baddr,event); | |
| 149 | - break; | |
| 155 | + switch(event->button) | |
| 156 | + { | |
| 157 | + case 1: // Left button | |
| 158 | + button_1_press(widget,event->type,baddr); | |
| 159 | + break; | |
| 150 | 160 | |
| 151 | - default: | |
| 152 | - trace("%s button=%d type=%d",__FUNCTION__,event->button,event->type); | |
| 161 | + case 3: // Right button | |
| 162 | + if(event->type == GDK_BUTTON_PRESS) | |
| 163 | + v3270_emit_popup(GTK_V3270(widget),baddr,event); | |
| 164 | + break; | |
| 165 | + | |
| 166 | + default: | |
| 167 | + trace("%s button=%d type=%d",__FUNCTION__,event->button,event->type); | |
| 168 | + } | |
| 169 | + } | |
| 170 | + else if(event->button == 1 && event->type == GDK_BUTTON_PRESS) | |
| 171 | + { | |
| 172 | + GTK_V3270(widget)->selected_field = get_field_from_event(GTK_V3270(widget),event); | |
| 173 | + trace("%s field=%d",__FUNCTION__,GTK_V3270(widget)->selected_field); | |
| 153 | 174 | } |
| 154 | 175 | |
| 155 | 176 | return FALSE; |
| ... | ... | @@ -163,24 +184,44 @@ gboolean v3270_button_release_event(GtkWidget *widget, GdkEventButton*event) |
| 163 | 184 | GTK_V3270(widget)->selecting = 0; |
| 164 | 185 | GTK_V3270(widget)->moving = 0; |
| 165 | 186 | GTK_V3270(widget)->resizing = 0; |
| 187 | + | |
| 188 | + if(GTK_V3270(widget)->selected_field != V3270_OIA_FIELD_INVALID && GTK_V3270(widget)->selected_field == get_field_from_event(GTK_V3270(widget),event)) | |
| 189 | + { | |
| 190 | + gboolean handled = FALSE; | |
| 191 | + | |
| 192 | + trace("%s field %d was clicked event=%p",__FUNCTION__,GTK_V3270(widget)->selected_field,event); | |
| 193 | + | |
| 194 | + g_signal_emit(widget, v3270_widget_signal[SIGNAL_FIELD], 0, | |
| 195 | + lib3270_connected(GTK_V3270(widget)->host) ? TRUE : FALSE, | |
| 196 | + GTK_V3270(widget)->selected_field, | |
| 197 | + event, | |
| 198 | + &handled); | |
| 199 | + | |
| 200 | + trace("Handled: %s",handled ? "Yes": "No"); | |
| 201 | + | |
| 202 | + if(!handled) | |
| 203 | + gdk_beep(); | |
| 204 | + | |
| 205 | + } | |
| 206 | + | |
| 207 | + GTK_V3270(widget)->selected_field = V3270_OIA_FIELD_INVALID; | |
| 208 | + | |
| 166 | 209 | break; |
| 167 | 210 | |
| 168 | 211 | default: |
| 169 | 212 | trace("%s button=%d type=%d",__FUNCTION__,event->button,event->type); |
| 170 | 213 | } |
| 171 | 214 | |
| 172 | - | |
| 173 | 215 | return FALSE; |
| 174 | 216 | } |
| 175 | 217 | |
| 176 | - | |
| 177 | 218 | static void update_mouse_pointer(GtkWidget *widget, int baddr) |
| 178 | 219 | { |
| 179 | - v3270 *terminal = GTK_V3270(widget); | |
| 220 | + v3270 * terminal = GTK_V3270(widget); | |
| 221 | + int id = terminal->pointer; | |
| 180 | 222 | |
| 181 | 223 | if(baddr >= 0 && terminal->pointer_id == LIB3270_CURSOR_EDITABLE) |
| 182 | 224 | { |
| 183 | - int id = terminal->pointer; | |
| 184 | 225 | |
| 185 | 226 | switch(lib3270_get_selection_flags(terminal->host,baddr) & 0x8f) |
| 186 | 227 | { |
| ... | ... | @@ -225,9 +266,10 @@ static void update_mouse_pointer(GtkWidget *widget, int baddr) |
| 225 | 266 | |
| 226 | 267 | } |
| 227 | 268 | |
| 228 | - gdk_window_set_cursor(gtk_widget_get_window(widget),v3270_cursor[id]); | |
| 229 | 269 | } |
| 230 | 270 | |
| 271 | + gdk_window_set_cursor(gtk_widget_get_window(widget),v3270_cursor[id]); | |
| 272 | + | |
| 231 | 273 | } |
| 232 | 274 | |
| 233 | 275 | void v3270_update_mouse_pointer(GtkWidget *widget) |
| ... | ... | @@ -244,11 +286,20 @@ void v3270_update_mouse_pointer(GtkWidget *widget) |
| 244 | 286 | |
| 245 | 287 | gboolean v3270_motion_notify_event(GtkWidget *widget, GdkEventMotion *event) |
| 246 | 288 | { |
| 247 | - v3270 * terminal = GTK_V3270(widget); | |
| 248 | - int baddr = v3270_get_offset_at_point(terminal,event->x,event->y); | |
| 289 | + v3270 * terminal = GTK_V3270(widget); | |
| 290 | + int baddr; | |
| 291 | + | |
| 292 | + if(!lib3270_connected(terminal->host)) | |
| 293 | + { | |
| 294 | + gdk_window_set_cursor(gtk_widget_get_window(widget),v3270_cursor[V3270_CURSOR_PROTECTED]); | |
| 295 | + return FALSE; | |
| 296 | + } | |
| 297 | + | |
| 298 | + baddr = v3270_get_offset_at_point(terminal,event->x,event->y); | |
| 249 | 299 | |
| 250 | 300 | if(baddr >= 0) |
| 251 | 301 | { |
| 302 | + | |
| 252 | 303 | if(terminal->selecting) // Select region |
| 253 | 304 | { |
| 254 | 305 | lib3270_select_to(terminal->host,baddr); |
| ... | ... | @@ -263,6 +314,37 @@ gboolean v3270_motion_notify_event(GtkWidget *widget, GdkEventMotion *event) |
| 263 | 314 | update_mouse_pointer(widget,baddr); |
| 264 | 315 | } |
| 265 | 316 | } |
| 317 | + else if(event->y >= terminal->oia_rect->y) | |
| 318 | + { | |
| 319 | + int id = V3270_CURSOR_PROTECTED; | |
| 320 | + | |
| 321 | + if(event->x >= terminal->oia_rect[V3270_OIA_SSL].x && event->x <= (terminal->oia_rect[V3270_OIA_SSL].x + terminal->oia_rect[V3270_OIA_SSL].width)) | |
| 322 | + { | |
| 323 | + switch(lib3270_get_secure(terminal->host)) | |
| 324 | + { | |
| 325 | + case LIB3270_SSL_UNSECURE: /**< No secure connection */ | |
| 326 | + id = V3270_CURSOR_QUESTION; | |
| 327 | + break; | |
| 328 | + | |
| 329 | + case LIB3270_SSL_NEGOTIATING: /**< Negotiating SSL */ | |
| 330 | + id = V3270_CURSOR_WAITING; | |
| 331 | + break; | |
| 332 | + | |
| 333 | + case LIB3270_SSL_NEGOTIATED: /**< Connection secure, no CA or self-signed */ | |
| 334 | + id = V3270_CURSOR_QUESTION; | |
| 335 | + break; | |
| 336 | + | |
| 337 | + case LIB3270_SSL_SECURE: /**< Connection secure with CA check */ | |
| 338 | + id = V3270_CURSOR_QUESTION; | |
| 339 | + break; | |
| 340 | + | |
| 341 | + default: | |
| 342 | + id = V3270_CURSOR_LOCKED; | |
| 343 | + } | |
| 344 | + } | |
| 345 | + | |
| 346 | + gdk_window_set_cursor(gtk_widget_get_window(widget),v3270_cursor[id]); | |
| 347 | + } | |
| 266 | 348 | |
| 267 | 349 | return FALSE; |
| 268 | 350 | } | ... | ... |
| ... | ... | @@ -335,6 +335,13 @@ void v3270_draw_ssl_status(cairo_t *cr, H3270 *host, struct v3270_metrics *metri |
| 335 | 335 | bits = (unsigned char *) unlocked_bits; |
| 336 | 336 | break; |
| 337 | 337 | |
| 338 | + case LIB3270_SSL_NEGOTIATING: /**< Negotiating SSL */ | |
| 339 | + gdk_cairo_set_source_color(cr,color+V3270_COLOR_OIA_STATUS_WARNING); | |
| 340 | + width = unlocked_width; | |
| 341 | + height = unlocked_height; | |
| 342 | + bits = (unsigned char *) unlocked_bits; | |
| 343 | + break; | |
| 344 | + | |
| 338 | 345 | case LIB3270_SSL_NEGOTIATED: /**< Connection secure, no CA or self-signed */ |
| 339 | 346 | gdk_cairo_set_source_color(cr,color+V3270_COLOR_OIA_STATUS_WARNING); |
| 340 | 347 | width = negotiated_width; |
| ... | ... | @@ -342,7 +349,6 @@ void v3270_draw_ssl_status(cairo_t *cr, H3270 *host, struct v3270_metrics *metri |
| 342 | 349 | bits = (unsigned char *) negotiated_bits; |
| 343 | 350 | break; |
| 344 | 351 | |
| 345 | - | |
| 346 | 352 | case LIB3270_SSL_SECURE: /**< Connection secure with CA check */ |
| 347 | 353 | gdk_cairo_set_source_color(cr,color+V3270_COLOR_OIA_STATUS_OK); |
| 348 | 354 | width = locked_width; |
| ... | ... | @@ -350,19 +356,11 @@ void v3270_draw_ssl_status(cairo_t *cr, H3270 *host, struct v3270_metrics *metri |
| 350 | 356 | bits = (unsigned char *) locked_bits; |
| 351 | 357 | break; |
| 352 | 358 | |
| 353 | - case LIB3270_SSL_NEGOTIATING: /**< Negotiating SSL */ | |
| 354 | - gdk_cairo_set_source_color(cr,color+V3270_COLOR_OIA_STATUS_WARNING); | |
| 355 | - width = unlocked_width; | |
| 356 | - height = unlocked_height; | |
| 357 | - bits = (unsigned char *) unlocked_bits; | |
| 358 | - break; | |
| 359 | - | |
| 360 | 359 | default: |
| 361 | 360 | return; |
| 362 | 361 | |
| 363 | 362 | } |
| 364 | 363 | |
| 365 | - | |
| 366 | 364 | icon = cairo_image_surface_create_for_data( bits, |
| 367 | 365 | CAIRO_FORMAT_A1, |
| 368 | 366 | width,height, | ... | ... |
private.h
| ... | ... | @@ -81,10 +81,12 @@ G_BEGIN_DECLS |
| 81 | 81 | SIGNAL_CLIPBOARD, |
| 82 | 82 | SIGNAL_CHANGED, |
| 83 | 83 | SIGNAL_MESSAGE, |
| 84 | + SIGNAL_FIELD, | |
| 84 | 85 | |
| 85 | 86 | LAST_SIGNAL |
| 86 | 87 | }; |
| 87 | 88 | |
| 89 | + | |
| 88 | 90 | /*--[ Globals ]--------------------------------------------------------------------------------------*/ |
| 89 | 91 | |
| 90 | 92 | #define V3270_CURSOR_UNPROTECTED LIB3270_CURSOR_EDITABLE |
| ... | ... | @@ -101,8 +103,9 @@ G_BEGIN_DECLS |
| 101 | 103 | #define V3270_CURSOR_SELECTION_BOTTOM LIB3270_CURSOR_USER+7 |
| 102 | 104 | #define V3270_CURSOR_SELECTION_LEFT LIB3270_CURSOR_USER+8 |
| 103 | 105 | #define V3270_CURSOR_SELECTION_RIGHT LIB3270_CURSOR_USER+9 |
| 106 | + #define V3270_CURSOR_QUESTION LIB3270_CURSOR_USER+10 | |
| 104 | 107 | |
| 105 | - #define V3270_CURSOR_COUNT LIB3270_CURSOR_USER+10 | |
| 108 | + #define V3270_CURSOR_COUNT LIB3270_CURSOR_USER+11 | |
| 106 | 109 | |
| 107 | 110 | |
| 108 | 111 | struct v3270_metrics |
| ... | ... | @@ -144,8 +147,10 @@ G_BEGIN_DECLS |
| 144 | 147 | gchar * clipboard; /**< Clipboard contents (text only) */ |
| 145 | 148 | |
| 146 | 149 | LIB3270_CURSOR pointer_id; |
| 147 | - unsigned char pointer; /** Mouse pointer ID */ | |
| 148 | - int selection_addr; /** Selection addr */ | |
| 150 | + unsigned char pointer; /**< Mouse pointer ID */ | |
| 151 | + int selection_addr; /**< Selection addr */ | |
| 152 | + | |
| 153 | + V3270_OIA_FIELD selected_field; /**< Clicked OIA field */ | |
| 149 | 154 | |
| 150 | 155 | // Font info |
| 151 | 156 | gchar * font_family; | ... | ... |
widget.c
| ... | ... | @@ -333,6 +333,8 @@ static void v3270_class_init(v3270Class *klass) |
| 333 | 333 | // Cursors |
| 334 | 334 | { |
| 335 | 335 | #ifdef WIN32 |
| 336 | + // http://git.gnome.org/browse/gtk+/tree/gdk/win32/gdkcursor-win32.c | |
| 337 | + // http://www.functionx.com/win32/Lesson02b.htm | |
| 336 | 338 | static const gchar * cr[V3270_CURSOR_COUNT] = |
| 337 | 339 | { |
| 338 | 340 | "ibeam", // V3270_CURSOR_UNPROTECTED |
| ... | ... | @@ -348,6 +350,7 @@ static void v3270_class_init(v3270Class *klass) |
| 348 | 350 | "sizens", // V3270_CURSOR_SELECTION_BOTTOM |
| 349 | 351 | "sizewe", // V3270_CURSOR_SELECTION_LEFT |
| 350 | 352 | "sizewe", // V3270_CURSOR_SELECTION_RIGHT |
| 353 | + "help", // V3270_CURSOR_QUESTION | |
| 351 | 354 | }; |
| 352 | 355 | #else |
| 353 | 356 | static const int cr[V3270_CURSOR_COUNT] = |
| ... | ... | @@ -365,6 +368,7 @@ static void v3270_class_init(v3270Class *klass) |
| 365 | 368 | GDK_BOTTOM_SIDE, // V3270_CURSOR_SELECTION_BOTTOM |
| 366 | 369 | GDK_LEFT_SIDE, // V3270_CURSOR_SELECTION_LEFT |
| 367 | 370 | GDK_RIGHT_SIDE, // V3270_CURSOR_SELECTION_RIGHT |
| 371 | + GDK_QUESTION_ARROW, // V3270_CURSOR_QUESTION | |
| 368 | 372 | }; |
| 369 | 373 | #endif // WIN32 |
| 370 | 374 | |
| ... | ... | @@ -516,6 +520,15 @@ static void v3270_class_init(v3270Class *klass) |
| 516 | 520 | pw3270_VOID__VOID_UINT_POINTER_POINTER_POINTER, |
| 517 | 521 | G_TYPE_NONE, 4, G_TYPE_UINT, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING); |
| 518 | 522 | |
| 523 | + v3270_widget_signal[SIGNAL_FIELD] = | |
| 524 | + g_signal_new( "field_clicked", | |
| 525 | + G_OBJECT_CLASS_TYPE (gobject_class), | |
| 526 | + G_SIGNAL_RUN_LAST, | |
| 527 | + 0, | |
| 528 | + NULL, NULL, | |
| 529 | + pw3270_BOOL__VOID_BOOL_UINT_POINTER, | |
| 530 | + G_TYPE_BOOLEAN, 3, G_TYPE_BOOLEAN, G_TYPE_UINT, G_TYPE_POINTER); | |
| 531 | + | |
| 519 | 532 | } |
| 520 | 533 | |
| 521 | 534 | void v3270_update_font_metrics(v3270 *terminal, cairo_t *cr, int width, int height) | ... | ... |