Added text and unmodifiedtext setting when sending char type keyboard events, and made the type of the character read char16, so I can simulate char events from non-english origins.
This commit is contained in:
parent
bb102717b4
commit
70bdfedabf
1 changed files with 9 additions and 6 deletions
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include "atom/common/keyboad_util.h"
|
#include "atom/common/keyboad_util.h"
|
||||||
#include "base/strings/string_util.h"
|
#include "base/strings/string_util.h"
|
||||||
|
#include "base/strings/utf_string_conversions.h"
|
||||||
#include "content/public/browser/native_web_keyboard_event.h"
|
#include "content/public/browser/native_web_keyboard_event.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
#include "third_party/WebKit/public/web/WebDeviceEmulationParams.h"
|
#include "third_party/WebKit/public/web/WebDeviceEmulationParams.h"
|
||||||
|
@ -29,10 +30,10 @@ int VectorToBitArray(const std::vector<T>& vec) {
|
||||||
namespace mate {
|
namespace mate {
|
||||||
|
|
||||||
template<>
|
template<>
|
||||||
struct Converter<char> {
|
struct Converter<base::char16> {
|
||||||
static bool FromV8(v8::Isolate* isolate, v8::Handle<v8::Value> val,
|
static bool FromV8(v8::Isolate* isolate, v8::Handle<v8::Value> val,
|
||||||
char* out) {
|
base::char16* out) {
|
||||||
std::string code = base::StringToLowerASCII(V8ToString(val));
|
base::string16 code = base::UTF8ToUTF16(V8ToString(val));
|
||||||
if (code.length() != 1)
|
if (code.length() != 1)
|
||||||
return false;
|
return false;
|
||||||
*out = code[0];
|
*out = code[0];
|
||||||
|
@ -157,16 +158,18 @@ bool Converter<blink::WebKeyboardEvent>::FromV8(
|
||||||
return false;
|
return false;
|
||||||
if (!ConvertFromV8(isolate, val, static_cast<blink::WebInputEvent*>(out)))
|
if (!ConvertFromV8(isolate, val, static_cast<blink::WebInputEvent*>(out)))
|
||||||
return false;
|
return false;
|
||||||
char code;
|
base::char16 code;
|
||||||
if (!dict.Get("keyCode", &code))
|
if (!dict.Get("keyCode", &code))
|
||||||
return false;
|
return false;
|
||||||
bool shifted = false;
|
bool shifted = false;
|
||||||
out->windowsKeyCode = atom::KeyboardCodeFromCharCode(code, &shifted);
|
out->windowsKeyCode = atom::KeyboardCodeFromCharCode(code, &shifted);
|
||||||
if (out->windowsKeyCode == ui::VKEY_UNKNOWN)
|
|
||||||
return false;
|
|
||||||
if (shifted)
|
if (shifted)
|
||||||
out->modifiers |= blink::WebInputEvent::ShiftKey;
|
out->modifiers |= blink::WebInputEvent::ShiftKey;
|
||||||
out->setKeyIdentifierFromWindowsKeyCode();
|
out->setKeyIdentifierFromWindowsKeyCode();
|
||||||
|
if (out->type == blink::WebInputEvent::Char || out->type == blink::WebInputEvent::RawKeyDown) {
|
||||||
|
out->text[0] = code;
|
||||||
|
out->unmodifiedText[0] = code;
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue