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

Unified Diff: ui/base/ime/input_method_base.cc

Issue 8659033: IME (input method editor) support for Aura, part 1 of 3: Add ui/base/ime/ classes (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase, review fix 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
« no previous file with comments | « ui/base/ime/input_method_base.h ('k') | ui/base/ime/input_method_delegate.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/base/ime/input_method_base.cc
diff --git a/ui/base/ime/input_method_base.cc b/ui/base/ime/input_method_base.cc
new file mode 100644
index 0000000000000000000000000000000000000000..b691fe896a86c00016fccda0188cfc216b7932fd
--- /dev/null
+++ b/ui/base/ime/input_method_base.cc
@@ -0,0 +1,91 @@
+// 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/base/ime/input_method_base.h"
+
+#include "base/logging.h"
+#include "ui/base/ime/input_method_delegate.h"
+#include "ui/base/ime/text_input_client.h"
+
+namespace ui {
+
+InputMethodBase::InputMethodBase()
+ : delegate_(NULL),
+ text_input_client_(NULL),
+ system_toplevel_window_focused_(false) {
+}
+
+InputMethodBase::~InputMethodBase() {
+}
+
+void InputMethodBase::SetDelegate(
+ internal::InputMethodDelegate* delegate) {
+ delegate_ = delegate;
+}
+
+void InputMethodBase::Init(bool focused) {
+ if (focused)
+ OnFocus();
+}
+
+void InputMethodBase::OnFocus() {
+ DCHECK(!system_toplevel_window_focused_);
+ system_toplevel_window_focused_ = true;
+}
+
+void InputMethodBase::OnBlur() {
+ DCHECK(system_toplevel_window_focused_);
+ system_toplevel_window_focused_ = false;
+}
+
+void InputMethodBase::SetFocusedTextInputClient(TextInputClient* client) {
+ TextInputClient* old = text_input_client_;
+ OnWillChangeFocusedClient(old, client);
+ text_input_client_ = client; // NULL allowed.
+ OnDidChangeFocusedClient(old, client);
+}
+
+TextInputClient* InputMethodBase::GetTextInputClient() const {
+ return system_toplevel_window_focused_ ? text_input_client_ : NULL;
+}
+
+void InputMethodBase::OnTextInputTypeChanged(const TextInputClient* client) {
+ if (!IsTextInputClientFocused(client))
+ return;
+ // TODO(yusukes): Support TextInputTypeTracker for TOUCH_UI.
+}
+
+TextInputType InputMethodBase::GetTextInputType() const {
+ TextInputClient* client = GetTextInputClient();
+ return client ? client->GetTextInputType() : TEXT_INPUT_TYPE_NONE;
+}
+
+bool InputMethodBase::IsTextInputClientFocused(const TextInputClient* client) {
+ return client && (client == GetTextInputClient());
+}
+
+bool InputMethodBase::IsTextInputTypeNone() const {
+ return GetTextInputType() == TEXT_INPUT_TYPE_NONE;
+}
+
+void InputMethodBase::OnInputMethodChanged() const {
+ TextInputClient* client = GetTextInputClient();
+ if (client && client->GetTextInputType() != TEXT_INPUT_TYPE_NONE)
+ client->OnInputMethodChanged();
+}
+
+void InputMethodBase::DispatchKeyEventPostIME(
+ const base::NativeEvent& native_event) const {
+ if (delegate_)
+ delegate_->DispatchKeyEventPostIME(native_event);
+}
+
+void InputMethodBase::DispatchFabricatedKeyEventPostIME(EventType type,
+ KeyboardCode key_code,
+ int flags) const {
+ if (delegate_)
+ delegate_->DispatchFabricatedKeyEventPostIME(type, key_code, flags);
+}
+
+} // namespace ui
« no previous file with comments | « ui/base/ime/input_method_base.h ('k') | ui/base/ime/input_method_delegate.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698