| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/ui/libgtkui/x11_input_method_context_impl_gtk.h" | 5 #include "chrome/browser/ui/libgtkui/x11_input_method_context_impl_gtk.h" |
| 6 | 6 |
| 7 #include <gdk/gdk.h> | 7 #include <gdk/gdk.h> |
| 8 #include <gdk/gdkkeysyms.h> | 8 #include <gdk/gdkkeysyms.h> |
| 9 #include <gdk/gdkx.h> | 9 #include <gdk/gdkx.h> |
| 10 #include <stddef.h> | 10 #include <stddef.h> |
| 11 | 11 |
| 12 #include <gtk/gtk.h> | 12 #include <gtk/gtk.h> |
| 13 | 13 |
| 14 #include <X11/X.h> | 14 #include <X11/X.h> |
| 15 #include <X11/Xlib.h> | 15 #include <X11/Xlib.h> |
| 16 | 16 |
| 17 #include "base/message_loop/message_loop.h" | 17 #include "base/message_loop/message_loop.h" |
| 18 #include "base/strings/utf_string_conversions.h" | 18 #include "base/strings/utf_string_conversions.h" |
| 19 #include "ui/base/ime/composition_text.h" | 19 #include "ui/base/ime/composition_text.h" |
| 20 #include "ui/base/ime/composition_text_util_pango.h" | 20 #include "ui/base/ime/composition_text_util_pango.h" |
| 21 #include "ui/base/ime/text_input_client.h" | 21 #include "ui/base/ime/text_input_client.h" |
| 22 #include "ui/events/event.h" | 22 #include "ui/events/event.h" |
| 23 #include "ui/events/keycodes/keyboard_code_conversion_x.h" | 23 #include "ui/events/keycodes/keyboard_code_conversion_x.h" |
| 24 #include "ui/gfx/geometry/dip_util.h" |
| 24 #include "ui/gfx/x/x11_types.h" | 25 #include "ui/gfx/x/x11_types.h" |
| 26 #include "ui/views/linux_ui/linux_ui.h" |
| 25 | 27 |
| 26 namespace libgtkui { | 28 namespace libgtkui { |
| 27 | 29 |
| 28 X11InputMethodContextImplGtk2::X11InputMethodContextImplGtk2( | 30 X11InputMethodContextImplGtk2::X11InputMethodContextImplGtk2( |
| 29 ui::LinuxInputMethodContextDelegate* delegate, | 31 ui::LinuxInputMethodContextDelegate* delegate, |
| 30 bool is_simple) | 32 bool is_simple) |
| 31 : delegate_(delegate), | 33 : delegate_(delegate), |
| 32 gtk_context_(NULL), | 34 gtk_context_(NULL), |
| 33 gdk_last_set_client_window_(NULL) { | 35 gdk_last_set_client_window_(NULL) { |
| 34 CHECK(delegate_); | 36 CHECK(delegate_); |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 if (event->key.window != gdk_last_set_client_window_) { | 76 if (event->key.window != gdk_last_set_client_window_) { |
| 75 gtk_im_context_set_client_window(gtk_context_, event->key.window); | 77 gtk_im_context_set_client_window(gtk_context_, event->key.window); |
| 76 gdk_last_set_client_window_ = event->key.window; | 78 gdk_last_set_client_window_ = event->key.window; |
| 77 } | 79 } |
| 78 | 80 |
| 79 // Convert the last known caret bounds relative to the screen coordinates | 81 // Convert the last known caret bounds relative to the screen coordinates |
| 80 // to a GdkRectangle relative to the client window. | 82 // to a GdkRectangle relative to the client window. |
| 81 gint x = 0; | 83 gint x = 0; |
| 82 gint y = 0; | 84 gint y = 0; |
| 83 gdk_window_get_origin(event->key.window, &x, &y); | 85 gdk_window_get_origin(event->key.window, &x, &y); |
| 84 GdkRectangle rect = {last_caret_bounds_.x() - x, last_caret_bounds_.y() - y, | 86 |
| 85 last_caret_bounds_.width(), last_caret_bounds_.height()}; | 87 GdkRectangle gdk_rect = { |
| 86 gtk_im_context_set_cursor_location(gtk_context_, &rect); | 88 last_caret_bounds_.x() - x, last_caret_bounds_.y() - y, |
| 89 last_caret_bounds_.width(), last_caret_bounds_.height()}; |
| 90 gtk_im_context_set_cursor_location(gtk_context_, &gdk_rect); |
| 87 | 91 |
| 88 const bool handled = | 92 const bool handled = |
| 89 gtk_im_context_filter_keypress(gtk_context_, &event->key); | 93 gtk_im_context_filter_keypress(gtk_context_, &event->key); |
| 90 gdk_event_free(event); | 94 gdk_event_free(event); |
| 91 return handled; | 95 return handled; |
| 92 } | 96 } |
| 93 | 97 |
| 94 void X11InputMethodContextImplGtk2::Reset() { | 98 void X11InputMethodContextImplGtk2::Reset() { |
| 95 gtk_im_context_reset(gtk_context_); | 99 gtk_im_context_reset(gtk_context_); |
| 96 } | 100 } |
| 97 | 101 |
| 98 void X11InputMethodContextImplGtk2::Focus() { | 102 void X11InputMethodContextImplGtk2::Focus() { |
| 99 gtk_im_context_focus_in(gtk_context_); | 103 gtk_im_context_focus_in(gtk_context_); |
| 100 } | 104 } |
| 101 | 105 |
| 102 void X11InputMethodContextImplGtk2::Blur() { | 106 void X11InputMethodContextImplGtk2::Blur() { |
| 103 gtk_im_context_focus_out(gtk_context_); | 107 gtk_im_context_focus_out(gtk_context_); |
| 104 } | 108 } |
| 105 | 109 |
| 106 void X11InputMethodContextImplGtk2::SetCursorLocation(const gfx::Rect& rect) { | 110 void X11InputMethodContextImplGtk2::SetCursorLocation(const gfx::Rect& rect) { |
| 107 // Remember the caret bounds so that we can set the cursor location later. | 111 // Remember the caret bounds so that we can set the cursor location later. |
| 108 // gtk_im_context_set_cursor_location() takes the location relative to the | 112 // gtk_im_context_set_cursor_location() takes the location relative to the |
| 109 // client window, which is unknown at this point. So we'll call | 113 // client window, which is unknown at this point. So we'll call |
| 110 // gtk_im_context_set_cursor_location() later in ProcessKeyEvent() where | 114 // gtk_im_context_set_cursor_location() later in ProcessKeyEvent() where |
| 111 // (and only where) we know the client window. | 115 // (and only where) we know the client window. |
| 112 last_caret_bounds_ = rect; | 116 if (views::LinuxUI::instance()) { |
| 117 last_caret_bounds_ = gfx::ConvertRectToPixel( |
| 118 views::LinuxUI::instance()->GetDeviceScaleFactor(), rect); |
| 119 } else { |
| 120 last_caret_bounds_ = rect; |
| 121 } |
| 113 } | 122 } |
| 114 | 123 |
| 115 // private: | 124 // private: |
| 116 | 125 |
| 117 void X11InputMethodContextImplGtk2::ResetXModifierKeycodesCache() { | 126 void X11InputMethodContextImplGtk2::ResetXModifierKeycodesCache() { |
| 118 modifier_keycodes_.clear(); | 127 modifier_keycodes_.clear(); |
| 119 meta_keycodes_.clear(); | 128 meta_keycodes_.clear(); |
| 120 super_keycodes_.clear(); | 129 super_keycodes_.clear(); |
| 121 hyper_keycodes_.clear(); | 130 hyper_keycodes_.clear(); |
| 122 | 131 |
| (...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 304 } | 313 } |
| 305 | 314 |
| 306 void X11InputMethodContextImplGtk2::OnPreeditStart(GtkIMContext* context) { | 315 void X11InputMethodContextImplGtk2::OnPreeditStart(GtkIMContext* context) { |
| 307 if (context != gtk_context_) | 316 if (context != gtk_context_) |
| 308 return; | 317 return; |
| 309 | 318 |
| 310 delegate_->OnPreeditStart(); | 319 delegate_->OnPreeditStart(); |
| 311 } | 320 } |
| 312 | 321 |
| 313 } // namespace libgtkui | 322 } // namespace libgtkui |
| OLD | NEW |