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 |