Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(599)

Unified Diff: ui/aura_shell/input_method_event_filter.cc

Issue 8576005: IME (input method editor) support for Aura, part 3 of 3: Use ui::InputMethod in ash. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: review fixes Created 9 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ui/aura_shell/input_method_event_filter.cc
diff --git a/ui/aura_shell/input_method_event_filter.cc b/ui/aura_shell/input_method_event_filter.cc
new file mode 100644
index 0000000000000000000000000000000000000000..da6db511c73e14a48d8e426a9ab8e89a9dac5672
--- /dev/null
+++ b/ui/aura_shell/input_method_event_filter.cc
@@ -0,0 +1,102 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "ui/aura_shell/input_method_event_filter.h"
+
+#include "ui/aura/client/aura_constants.h"
+#include "ui/aura/event.h"
+#include "ui/aura/root_window.h"
+#include "ui/aura_shell/event.h"
+#include "ui/aura_shell/shell.h"
+#include "ui/base/ime/input_method.h"
+#include "ui/base/ime/input_method_factory.h"
+
+namespace aura_shell {
+namespace internal {
+
+////////////////////////////////////////////////////////////////////////////////
+// InputMethodEventFilter, public:
+
+InputMethodEventFilter::InputMethodEventFilter()
+ : EventFilter(aura::RootWindow::GetInstance()),
+ ALLOW_THIS_IN_INITIALIZER_LIST(
+ input_method_(ui::CreateInputMethod(this))),
+ root_window_destroyed_(false) {
+ aura::RootWindow* root_window = aura::RootWindow::GetInstance();
+
+ // TODO(yusukes): Check if the root window is currently focused and pass the
+ // result to Init().
+ input_method_->Init(true);
+ root_window->SetProperty(aura::kRootWindowInputMethod, input_method_.get());
+ root_window->AddObserver(this);
+}
+
+InputMethodEventFilter::~InputMethodEventFilter() {
+ if (root_window_destroyed_) {
Ben Goodger (Google) 2011/12/20 21:02:02 In this case, we should just not unhook these obse
Yusuke Sato 2011/12/21 16:57:27 Done.
+ // On Linux and Chrome OS, RootWindow is deleted before this function is
+ // called (see RootWindowHostLinux::WillDestroyCurrentMessageLoop in for
+ // details). In this case, calling RootWindow::GetInstance here results in
+ // regeneration of the singleton which is not what we want to do.
+ return;
+ }
+ aura::RootWindow* root_window = aura::RootWindow::GetInstance();
+ root_window->SetProperty(aura::kRootWindowInputMethod, NULL);
+ root_window->RemoveObserver(this);
+}
+
+////////////////////////////////////////////////////////////////////////////////
+// InputMethodEventFilter, EventFilter implementation:
+
+bool InputMethodEventFilter::PreHandleKeyEvent(aura::Window* target,
+ aura::KeyEvent* event) {
+ const ui::EventType type = event->type();
+ if (type == ui::ET_TRANSLATED_KEY_PRESS ||
+ type == ui::ET_TRANSLATED_KEY_RELEASE) {
+ // The |event| is already handled by this object, change the type of the
+ // event to ui::ET_KEY_* and pass it to the next filter.
+ static_cast<TranslatedKeyEvent*>(event)->ConvertToKeyEvent();
+ return false;
+ } else {
+ input_method_->DispatchKeyEvent(event->native_event());
+ return true;
+ }
+}
+
+bool InputMethodEventFilter::PreHandleMouseEvent(aura::Window* target,
+ aura::MouseEvent* event) {
+ return false;
+}
+
+ui::TouchStatus InputMethodEventFilter::PreHandleTouchEvent(
+ aura::Window* target,
+ aura::TouchEvent* event) {
+ return ui::TOUCH_STATUS_UNKNOWN;
+}
+
+////////////////////////////////////////////////////////////////////////////////
+// InputMethodEventFilter, ui::InputMethodDelegate implementation:
+
+void InputMethodEventFilter::DispatchKeyEventPostIME(
+ const base::NativeEvent& event) {
+ TranslatedKeyEvent aura_event(event, false /* is_char */);
+ aura::RootWindow::GetInstance()->DispatchKeyEvent(&aura_event);
+}
+
+void InputMethodEventFilter::DispatchFabricatedKeyEventPostIME(
+ ui::EventType type,
+ ui::KeyboardCode key_code,
+ int flags) {
+ TranslatedKeyEvent aura_event(type == ui::ET_KEY_PRESSED, key_code, flags);
+ aura::RootWindow::GetInstance()->DispatchKeyEvent(&aura_event);
+}
+
+////////////////////////////////////////////////////////////////////////////////
+// InputMethodEventFilter, aura::WindowObserver implementation:
+
+void InputMethodEventFilter::OnWindowDestroyed(aura::Window* window) {
+ root_window_destroyed_ = true;
+}
+
+} // namespace internal
+} // namespace aura_shell

Powered by Google App Engine
This is Rietveld 408576698