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:
commit
28641fd9b8
@ -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);
|
||||||
|
@ -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;
|
||||||
|
|
||||||
|
@ -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();
|
||||||
|
@ -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;
|
||||||
|
Loading…
Reference in New Issue
Block a user