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

Unified Diff: chrome/browser/ui/input_method/input_method_engine_base.cc

Issue 1771173002: Implement input.ime.sendKeyEvents API. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix test failure. Created 4 years, 9 months 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: chrome/browser/ui/input_method/input_method_engine_base.cc
diff --git a/chrome/browser/ui/input_method/input_method_engine_base.cc b/chrome/browser/ui/input_method/input_method_engine_base.cc
index 6764d7d2198afee5d60406df3b801e7c1cc59458..3257e732f49d51f24e20ad29ce7ecfe07a847d2e 100644
--- a/chrome/browser/ui/input_method/input_method_engine_base.cc
+++ b/chrome/browser/ui/input_method/input_method_engine_base.cc
@@ -27,6 +27,7 @@
#include "ui/events/event_processor.h"
#include "ui/events/event_utils.h"
#include "ui/events/keycodes/dom/dom_code.h"
+#include "ui/events/keycodes/dom/keycode_converter.h"
#include "ui/keyboard/keyboard_controller.h"
#include "ui/keyboard/keyboard_util.h"
@@ -419,4 +420,37 @@ std::string InputMethodEngineBase::AddRequest(
return request_id;
}
+bool InputMethodEngineBase::SendKeyEvents(
+ int context_id,
+ const std::vector<KeyboardEvent>& events) {
+ // context_id == 0, means sending key events to non-input field.
+ // context_id_ == -1, means the focus is not in an input field.
+ if (!IsActive() ||
+ (context_id != 0 && (context_id != context_id_ || context_id_ == -1)))
+ return false;
+
+ for (size_t i = 0; i < events.size(); ++i) {
+ const KeyboardEvent& event = events[i];
+ const ui::EventType type =
+ (event.type == "keyup") ? ui::ET_KEY_RELEASED : ui::ET_KEY_PRESSED;
+ ui::KeyboardCode key_code = static_cast<ui::KeyboardCode>(event.key_code);
+
+ int flags = ui::EF_NONE;
+ flags |= event.alt_key ? ui::EF_ALT_DOWN : ui::EF_NONE;
+ flags |= event.ctrl_key ? ui::EF_CONTROL_DOWN : ui::EF_NONE;
+ flags |= event.shift_key ? ui::EF_SHIFT_DOWN : ui::EF_NONE;
+ flags |= event.caps_lock ? ui::EF_CAPS_LOCK_ON : ui::EF_NONE;
+
+ ui::KeyEvent ui_event(
+ type, key_code, ui::KeycodeConverter::CodeStringToDomCode(event.code),
+ flags, ui::KeycodeConverter::KeyStringToDomKey(event.key),
+ ui::EventTimeForNow());
+ base::AutoReset<const ui::KeyEvent*> reset_sent_key(&sent_key_event_,
+ &ui_event);
+ if (!SendKeyEvent(&ui_event, event.code))
+ return false;
+ }
+ return true;
+}
+
} // namespace input_method

Powered by Google App Engine
This is Rietveld 408576698