Merge pull request #5525 from SuperUserNameMan/window_get_latin_kb_variant

windows get_latin_keyboard_variant() implementation and gdscript binding, #5503
This commit is contained in:
Juan Linietsky 2016-07-10 12:41:05 -03:00 committed by GitHub
commit 28641fd9b8
4 changed files with 78 additions and 0 deletions

View File

@ -435,6 +435,18 @@ String _OS::get_locale() const {
return OS::get_singleton()->get_locale(); return OS::get_singleton()->get_locale();
} }
String _OS::get_latin_keyboard_variant() const {
switch( OS::get_singleton()->get_latin_keyboard_variant() ) {
case OS::LATIN_KEYBOARD_QWERTY: return "QWERTY";
case OS::LATIN_KEYBOARD_QWERTZ: return "QWERTZ";
case OS::LATIN_KEYBOARD_AZERTY: return "AZERTY";
case OS::LATIN_KEYBOARD_QZERTY: return "QZERTY";
case OS::LATIN_KEYBOARD_DVORAK: return "DVORAK";
case OS::LATIN_KEYBOARD_NEO : return "NEO";
default: return "ERROR";
}
}
String _OS::get_model_name() const { String _OS::get_model_name() const {
return OS::get_singleton()->get_model_name(); return OS::get_singleton()->get_model_name();
@ -1097,6 +1109,7 @@ void _OS::_bind_methods() {
ObjectTypeDB::bind_method(_MD("get_ticks_msec"),&_OS::get_ticks_msec); ObjectTypeDB::bind_method(_MD("get_ticks_msec"),&_OS::get_ticks_msec);
ObjectTypeDB::bind_method(_MD("get_splash_tick_msec"),&_OS::get_splash_tick_msec); ObjectTypeDB::bind_method(_MD("get_splash_tick_msec"),&_OS::get_splash_tick_msec);
ObjectTypeDB::bind_method(_MD("get_locale"),&_OS::get_locale); ObjectTypeDB::bind_method(_MD("get_locale"),&_OS::get_locale);
ObjectTypeDB::bind_method(_MD("get_latin_keyboard_variant"),&_OS::get_latin_keyboard_variant);
ObjectTypeDB::bind_method(_MD("get_model_name"),&_OS::get_model_name); ObjectTypeDB::bind_method(_MD("get_model_name"),&_OS::get_model_name);
ObjectTypeDB::bind_method(_MD("get_custom_level"),&_OS::get_custom_level); ObjectTypeDB::bind_method(_MD("get_custom_level"),&_OS::get_custom_level);

View File

@ -192,6 +192,8 @@ public:
Vector<String> get_cmdline_args(); Vector<String> get_cmdline_args();
String get_locale() const; String get_locale() const;
String get_latin_keyboard_variant() const;
String get_model_name() const; String get_model_name() const;
MainLoop *get_main_loop() const; MainLoop *get_main_loop() const;

View File

@ -2178,6 +2178,68 @@ String OS_Windows::get_locale() const {
return "en"; return "en";
} }
OS::LatinKeyboardVariant OS_Windows::get_latin_keyboard_variant() const {
unsigned long azerty[] = {
0x00020401, // Arabic (102) AZERTY
0x0001080c, // Belgian (Comma)
0x0000080c, // Belgian French
0x0000040c, // French
0 // <--- STOP MARK
};
unsigned long qwertz[] = {
0x0000041a, // Croation
0x00000405, // Czech
0x00000407, // German
0x00010407, // German (IBM)
0x0000040e, // Hungarian
0x0000046e, // Luxembourgish
0x00010415, // Polish (214)
0x00000418, // Romanian (Legacy)
0x0000081a, // Serbian (Latin)
0x0000041b, // Slovak
0x00000424, // Slovenian
0x0001042e, // Sorbian Extended
0x0002042e, // Sorbian Standard
0x0000042e, // Sorbian Standard (Legacy)
0x0000100c, // Swiss French
0x00000807, // Swiss German
0 // <--- STOP MARK
};
unsigned long dvorak[] = {
0x00010409, // US-Dvorak
0x00030409, // US-Dvorak for left hand
0x00040409, // US-Dvorak for right hand
0 // <--- STOP MARK
};
char name[ KL_NAMELENGTH + 1 ]; name[0] = 0;
GetKeyboardLayoutNameA( name );
unsigned long hex = strtoul(name, NULL, 16);
int i=0;
while( azerty[i] != 0 ) {
if (azerty[i] == hex) return LATIN_KEYBOARD_AZERTY;
i++;
}
i = 0;
while( qwertz[i] != 0 ) {
if (qwertz[i] == hex) return LATIN_KEYBOARD_QWERTZ;
i++;
}
i = 0;
while( dvorak[i] != 0 ) {
if (dvorak[i] == hex) return LATIN_KEYBOARD_DVORAK;
i++;
}
return LATIN_KEYBOARD_QWERTY;
}
void OS_Windows::release_rendering_thread() { void OS_Windows::release_rendering_thread() {
gl_context->release_current(); gl_context->release_current();

View File

@ -266,6 +266,7 @@ public:
virtual String get_executable_path() const; virtual String get_executable_path() const;
virtual String get_locale() const; virtual String get_locale() const;
virtual LatinKeyboardVariant get_latin_keyboard_variant() const;
virtual void move_window_to_foreground(); virtual void move_window_to_foreground();
virtual String get_data_dir() const; virtual String get_data_dir() const;