From d69f4ae581a7f2c21879fc1731b1a0bf5f276fa3 Mon Sep 17 00:00:00 2001 From: florian Date: Tue, 17 Jun 2008 13:25:20 +0000 Subject: git-svn-id: https://svn.neo-layout.org@534 b9310e46-f624-0410-8ea1-cfbb3a30dc96 --- windows/kbdneo2/Quelldateien/1st_README.txt | 17 + windows/kbdneo2/Quelldateien/kbdneo2.c | 460 +++++++++++++-------- windows/kbdneo2/Quelldateien/kbdneo2.h | 16 +- windows/kbdneo2/Quelldateien/kbdneo2.rc | 2 +- windows/kbdneo2/Treiber/1stREADME.txt | 36 ++ .../Treiber/32bit_Windows_Server_2003/NEO20.dll | Bin 9728 -> 0 bytes .../Treiber/32bit_Windows_Server_2003/kbdneo2.dll | Bin 0 -> 10752 bytes .../NEO20.dll | Bin 9728 -> 0 bytes .../kbdneo2.dll | Bin 0 -> 10752 bytes windows/kbdneo2/Treiber/32bit_Windows_XP/NEO20.dll | Bin 9728 -> 0 bytes .../kbdneo2/Treiber/32bit_Windows_XP/kbdneo2.dll | Bin 0 -> 10752 bytes .../NEO20.dll | Bin 10752 -> 0 bytes .../kbdneo2.dll | Bin 0 -> 11776 bytes .../NEO20.dll | Bin 10752 -> 0 bytes .../kbdneo2.dll | Bin 0 -> 11776 bytes windows/kbdneo2/Treiber/README.txt | 16 - windows/kbdneo2/Treiber/kbdneo2_install.reg | Bin 0 -> 2260 bytes windows/kbdneo2/Treiber/kbdneo2_uninstall.reg | Bin 0 -> 2266 bytes windows/kbdneo2/Treiber/reg_backup.bat | 3 + 19 files changed, 348 insertions(+), 202 deletions(-) create mode 100644 windows/kbdneo2/Quelldateien/1st_README.txt create mode 100644 windows/kbdneo2/Treiber/1stREADME.txt delete mode 100644 windows/kbdneo2/Treiber/32bit_Windows_Server_2003/NEO20.dll create mode 100644 windows/kbdneo2/Treiber/32bit_Windows_Server_2003/kbdneo2.dll delete mode 100644 windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll create mode 100644 windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll delete mode 100644 windows/kbdneo2/Treiber/32bit_Windows_XP/NEO20.dll create mode 100644 windows/kbdneo2/Treiber/32bit_Windows_XP/kbdneo2.dll delete mode 100644 windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/NEO20.dll create mode 100644 windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/kbdneo2.dll delete mode 100644 windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll create mode 100644 windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll delete mode 100644 windows/kbdneo2/Treiber/README.txt create mode 100644 windows/kbdneo2/Treiber/kbdneo2_install.reg create mode 100644 windows/kbdneo2/Treiber/kbdneo2_uninstall.reg create mode 100644 windows/kbdneo2/Treiber/reg_backup.bat (limited to 'windows/kbdneo2') diff --git a/windows/kbdneo2/Quelldateien/1st_README.txt b/windows/kbdneo2/Quelldateien/1st_README.txt new file mode 100644 index 0000000..9f7179d --- /dev/null +++ b/windows/kbdneo2/Quelldateien/1st_README.txt @@ -0,0 +1,17 @@ +1. WinDDK installieren (Bestandteil von WDK, über das MSDN zu erhalten). + +2. Im Ordner \src\input\layout\all_kbds\kbdneo2 des WDKs einen neuen Ordner namens 'kbdneo2' anlegen. + +3. Alle Quelldateien in diesen Ordner kopieren. + +4. Die Datei 'dirs' im Ordner \src\input\layout\all_kbds\ des WinnDDKs um die Zeile 'kbdneo2' erweitern. Die Datei könnte nun so aussehen: +> DIRS= \ +> kbdfr \ +> kbdgr \ +> kbdneo2 + +5. Mit einem normalem Texteditor können nun die Quelldateien bearbeitet werden. Kommentare befinden sich in den jeweiligen Dateien. + +6. Zum kompilieren des Treibers die 'Checked Build Environment' starten und zum Ordner mit den Quelldateien wechseln und den Befehl »Build« ausführen. +> cd src\input\layout\all_kbds\kbdneo2 +> build diff --git a/windows/kbdneo2/Quelldateien/kbdneo2.c b/windows/kbdneo2/Quelldateien/kbdneo2.c index 32e8ec4..6bf2a1f 100644 --- a/windows/kbdneo2/Quelldateien/kbdneo2.c +++ b/windows/kbdneo2/Quelldateien/kbdneo2.c @@ -1,9 +1,7 @@ /***************************************************************************\ * Module Name: KBDNEO2.C * -* keyboard layout for German -* -* Copyright (c) 1985-2000, Microsoft Corporation +* keyboard layout for German NEO 2.0 * * History: \***************************************************************************/ @@ -131,18 +129,15 @@ static ALLOC_SECTION_LDATA VSC_VK aE1VscToVk[] = { * aVkToBits[] - map Virtual Keys to Modifier Bits * * See kbd.h for a full description. -* -* German Keyboard has only three shifter keys: -* SHIFT (L & R) affects alphabnumeric keys, -* CTRL (L & R) is used to generate control characters -* ALT (L & R) used for generating characters by number with numpad \***************************************************************************/ +// Es wird nicht zwischen linken und/oder rechtem Modifier unterschieden static ALLOC_SECTION_LDATA VK_TO_BIT aVkToBits[] = { - { VK_SHIFT , KBDSHIFT }, - { VK_CONTROL , KBDCTRL }, - { VK_MENU , KBDALT }, - { VK_KANA , KBDKANA }, - { 0 , 0 } + { VK_SHIFT , KBDSHIFT }, + { VK_CONTROL , KBDCTRL }, + { VK_MENU , KBDALT }, + { VK_KANA , KBDKANA }, //Mod 3 + { VK_OEM_102 , 16 }, //Mod 4 + { 0 , 0 } }; /***************************************************************************\ @@ -151,38 +146,48 @@ static ALLOC_SECTION_LDATA VK_TO_BIT aVkToBits[] = { * See kbd.h for a full description. * \***************************************************************************/ + static ALLOC_SECTION_LDATA MODIFIERS CharModifiers = { &aVkToBits[0], - 14, + 25, //Anzahl der verwendeten Ebenen (inklusive der INVALIDen!) { // Modifier NEO - // Ebene 1 - nix - // Ebene 2 - Shift - // Ebene 3 - Kana - // Ebene 4 - AltGr - // Ebene 5 - Kana+Shift - // Ebene 6 - AltGr+Kana + // Ebene 0 - nix + // Ebene 1 - Shift + // Ebene 2 - Kana = Mod 3 + // Ebene 3 - Neu = Mod 4 + // Ebene 4 - Kana+Shift + // Ebene 5 - Neu+Kana // // Modification# // Keys Pressed - // ============= // ============= - 0, // 0000 - 1, // 0001 Shift - 6, // 0010 Strg - 7, // 0011 Shift + Strg - SHFT_INVALID, // 0100 Menu - SHFT_INVALID, // 0101 Shift + Menu - 3, // 0110 Strg + Menu - SHFT_INVALID, // 0111 Shift + Strg + Menu - 2, // 1000 Kana - 4, // 1001 Shift + Kana - SHFT_INVALID, // 1010 Strg + Kana - SHFT_INVALID, // 1011 Shift + Strg + Kana - SHFT_INVALID, // 1100 Menu + Kana - SHFT_INVALID, // 1101 Shift + Menu + Kana - 5 // 1110 Menu + Strg + Kana - + // ============= // =========== Neu Kana Alt Strg Shift + 0, // 0 0 0 0 0 + 1, // 0 0 0 0 1 + 6, // 0 0 0 1 0 + 7, // 0 0 0 1 1 + SHFT_INVALID, // 0 0 1 0 0 + SHFT_INVALID, // 0 0 1 0 1 + SHFT_INVALID, // 0 0 1 1 0 + SHFT_INVALID, // 0 0 1 1 1 + 2, // 0 1 0 0 0 + 4, // 0 1 0 0 1 + SHFT_INVALID, // 0 1 0 1 0 + SHFT_INVALID, // 0 1 0 1 1 + SHFT_INVALID, // 0 1 1 0 0 + SHFT_INVALID, // 0 1 1 0 1 + SHFT_INVALID, // 0 1 1 1 0 + SHFT_INVALID, // 0 1 1 1 1 + 3, // 1 0 0 0 0 + 8, // 1 0 0 0 1 (für Pseudo-Ebene) + SHFT_INVALID, // 1 0 0 1 0 + SHFT_INVALID, // 1 0 0 1 1 + SHFT_INVALID, // 1 0 1 0 0 + SHFT_INVALID, // 1 0 1 0 1 + SHFT_INVALID, // 1 0 1 1 0 + SHFT_INVALID, // 1 0 1 1 1 + 5, // 1 1 0 0 0 } -}; +}; /***************************************************************************\ @@ -215,121 +220,127 @@ static ALLOC_SECTION_LDATA MODIFIERS CharModifiers = { * \***************************************************************************/ -static ALLOC_SECTION_LDATA VK_TO_WCHARS2 aVkToWch2[] = { -// | | Shift | -// |===========|=========| -{VK_DECIMAL ,0 ,',' ,',' }, -{0 ,0 ,0 ,0 } -}; - -static ALLOC_SECTION_LDATA VK_TO_WCHARS4 aVkToWch4[] = { -// | | SHIFT | KANA | ALT+CTL | -// | |===============|================|===============| -{VK_ADD ,0 ,'+' ,'+' ,0x00b1 ,0x2213 }, -{VK_DIVIDE ,0 ,'/' ,'/' ,0x00f7 ,0x2215 }, -{VK_MULTIPLY ,0 ,'*' ,'*' ,0x00d7 ,0x22c5 }, -{VK_SUBTRACT ,0 ,'-' ,'-' ,WCH_NONE ,0x2052 }, -{0 ,0 ,0 ,0 ,0 ,0 } -}; +// Reihenfolge der Ebene wie oben ( ALLOC_SECTION_LDATA MODIFIERS CharModifiers = { &aVkToBits[0],)… festgelegt static ALLOC_SECTION_LDATA VK_TO_WCHARS6 aVkToWch6[] = { -// | | SHIFT | KANA | ALT+CTL | KANA+Shift | ALT+CTL+Kana | +// | | SHIFT | KANA | NEU | KANA+Shift | NEU+Kana | // | |===============|================|===============|===============|================| {VK_OEM_1 ,0 ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD }, {0xff ,0 ,'^' ,0x030c ,0x0306 ,0x00b7 ,0x0335 ,0x0323 }, -{'1' ,CAPLOK ,'1' ,0x00b0 ,0x00B9 ,0x2022 ,0x2640 ,0x00ac }, -{'3' ,CAPLOK ,'3' ,0x00a7 ,0x00b3 ,WCH_NONE ,0x2640 ,0x2227 }, -{'4' ,CAPLOK ,'4' ,0x00bb ,0x203A ,WCH_NONE ,0x2113 ,0x02d4 }, -{'5' ,CAPLOK ,'5' ,0x00ab ,0x2039 ,WCH_NONE ,0x2020 ,0x2221 }, -{'7' ,CAPLOK ,'7' ,0x0024 ,0x00a5 ,0x00a4 ,0x03f0 ,0x2209 }, -{'8' ,CAPLOK ,'8' ,0x201E ,0x201A ,0x002F ,WCH_NONE ,0x2204 }, -{'9' ,CAPLOK ,'9' ,0x201C ,0x2018 ,0x002A ,WCH_NONE ,0x2226 }, -{'0' ,CAPLOK ,'0' ,0x201D ,0x2019 ,0x002D ,WCH_NONE ,0x2205 }, -{VK_OEM_MINUS ,0 ,'-' ,0x2013 ,0x2014 ,0X2011 ,0x00AD ,0x2227 }, +{'1' ,0 ,'1' ,0x00b0 ,0x00B9 ,0x2022 ,0x2640 ,0x00ac }, +{'3' ,0 ,'3' ,0x00a7 ,0x00b3 ,WCH_NONE ,0x2642 ,0x2227 }, +{'4' ,0 ,'4' ,0x00bb ,0x203A ,WCH_NONE ,0x2113 ,0x02d4 }, //WCH_NONE sollte »Bild auf« sein (AHK?) +{'5' ,0 ,'5' ,0x00ab ,0x2039 ,WCH_NONE ,0x2020 ,0x2221 }, +{'7' ,0 ,'7' ,0x0024 ,0x00a5 ,0x00a4 ,0x03f0 ,0x2209 }, +{'8' ,0 ,'8' ,0x201E ,0x201A ,0x002F ,WCH_NONE ,0x2204 }, +{'9' ,0 ,'9' ,0x201C ,0x2018 ,0x002A ,WCH_NONE ,0x2226 }, +{'0' ,0 ,'0' ,0x201D ,0x2019 ,0x002D ,WCH_NONE ,0x2205 }, +{VK_OEM_MINUS ,0 ,'-' ,0x2013 ,0x2014 ,WCH_DEAD ,0x0011 ,0x00ad }, {VK_OEM_2 ,0 ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD }, {0xff ,0 ,0x0301 ,0x0300 ,0x0327 ,0x0307 ,0x0328 ,0x030a }, {VK_TAB ,0 ,'\t' ,'\t' ,'\t' ,'\t' ,'\t' ,'\t' }, {'X' ,CAPLOK ,'x' ,'X' ,WCH_NONE ,WCH_NONE ,0x03BE ,0x039E }, {'V' ,CAPLOK ,'v' ,'V' ,'_' ,'\b' ,WCH_NONE ,0x2259 }, -{'L' ,CAPLOK ,'l' ,'L' ,'[' ,WCH_NONE ,0x03BB ,0x039b }, -{'C' ,CAPLOK ,'c' ,'C' ,']' ,0x007f ,0x03C7 ,0x2102 }, -{'W' ,CAPLOK ,'w' ,'W' ,0x005E ,WCH_NONE ,0x1f7c ,0x03a9 }, +{'L' ,CAPLOK ,'l' ,'L' ,'[' ,WCH_NONE ,0x03BB ,0x039b }, //WCH_NONE sollte »Pfeil hoch« sein (AHK?) +{'C' ,CAPLOK ,'c' ,'C' ,']' ,0x007f ,0x03C7 ,0x2102 }, //0x007f sollte »Entfernen« sein (AHK?) +{'W' ,CAPLOK ,'w' ,'W' ,0x005E ,WCH_NONE ,0x03c9 ,0x03a9 }, //WCH_NONE sollte »Einfügen« sein (AHK?) {'K' ,CAPLOK ,'k' ,'K' ,'!' ,0x00A1 ,0x03BA ,0x221a }, {'H' ,CAPLOK ,'h' ,'H' ,'<' ,'7' ,0x03C8 ,0x03A8 }, {'G' ,CAPLOK ,'g' ,'G' ,'>' ,'8' ,0x03B3 ,0x0393 }, {'F' ,CAPLOK ,'f' ,'F' ,'=' ,'9' ,0x03C6 ,0x03A6 }, -{'Q' ,CAPLOK ,'q' ,'Q' ,'&' ,'+' ,0x0278 ,0x211a }, -{'U' ,CAPLOK ,'u' ,'U' ,'\\' ,WCH_NONE ,WCH_NONE ,0x222e }, -{'I' ,CAPLOK ,'i' ,'I' ,'/' ,WCH_NONE ,0x03B9 ,0x222b }, -{'A' ,CAPLOK ,'a' ,'A' ,'{' ,WCH_NONE ,0x03B1 ,0x2200 }, -{'E' ,CAPLOK ,'e' ,'E' ,'}' ,WCH_NONE ,0x03B5 ,0x2203 }, -{'O' ,CAPLOK ,'o' ,'O' ,'*' ,WCH_NONE ,0x03bf ,0x2208 }, +{'Q' ,CAPLOK ,'q' ,'Q' ,'&' ,'+' ,0x03c6 ,0x211a }, +{'U' ,CAPLOK ,'u' ,'U' ,'\\' ,WCH_NONE ,WCH_NONE ,0x222e }, //1. WCH_NONE sollte »Pos 1« sein (AHK?) +{'I' ,CAPLOK ,'i' ,'I' ,'/' ,WCH_NONE ,0x03B9 ,0x222b }, //WCH_NONE sollte »Pfeil links« sein (AHK?) +{'A' ,CAPLOK ,'a' ,'A' ,'{' ,WCH_NONE ,0x03B1 ,0x2200 }, //WCH_NONE sollte »Pfeil runter« sein (AHK?) +{'E' ,CAPLOK ,'e' ,'E' ,'}' ,WCH_NONE ,0x03B5 ,0x2203 }, //WCH_NONE sollte »Pfeil rechts« sein (AHK?) +{'O' ,CAPLOK ,'o' ,'O' ,'*' ,WCH_NONE ,0x03bf ,0x2208 }, //WCH_NONE sollte »Ende« sein (AHK?) {'S' ,CAPLOK ,'s' ,'S' ,'?' ,0x00BF ,0x03C3 ,0x03A3 }, {'N' ,CAPLOK ,'n' ,'N' ,'(' ,'4' ,0x03BD ,0x2115 }, {'R' ,CAPLOK ,'r' ,'R' ,')' ,'5' ,0x03C1 ,0x211d }, {'T' ,CAPLOK ,'t' ,'T' ,'-' ,'6' ,0x03C4 ,0x2202 }, -{'D' ,CAPLOK ,'d' ,'D' ,':' ,',' ,0x03B4 ,0x0394 }, +{'D' ,CAPLOK ,'d' ,'D' ,':' ,WCH_NONE ,0x03B4 ,0x0394 }, {VK_OEM_5 ,CAPLOK ,0x00FC ,0x00DC ,'#' ,0x001b ,WCH_NONE ,0x221d }, {VK_OEM_6 ,CAPLOK ,0x00F6 ,0x00D6 ,'$' ,'\t' ,WCH_NONE ,0x2111 }, -{VK_OEM_7 ,CAPLOK ,0x00E4 ,0x00C4 ,'|' ,WCH_NONE ,0x03B7 ,0x211c }, +{VK_OEM_7 ,CAPLOK ,0x00E4 ,0x00C4 ,'|' ,WCH_NONE ,0x03B7 ,0x211c }, //WCH_NONE sollte »Bild runter« sein (AHK?) {'P' ,CAPLOK ,'p' ,'P' ,'~' ,'\r' ,0x03C0 ,0x03A0 }, {'Z' ,CAPLOK ,'z' ,'Z' ,'`' ,WCH_NONE ,0x03B6 ,0x2124 }, -{'B' ,CAPLOK ,'b' ,'B' ,'+' ,WCH_NONE ,0x03B2 ,0x212d }, +{'B' ,CAPLOK ,'b' ,'B' ,'+' ,',' ,0x03B2 ,0x21d2 }, {'M' ,CAPLOK ,'m' ,'M' ,'%' ,'1' ,0x00b5 ,0x21d4 }, -{VK_OEM_COMMA ,0 ,',' ,0x22ee ,'\'' ,'2' ,0x03F1 ,0x21d0 }, -{VK_OEM_PERIOD ,0 ,'.' ,0x2026 ,'\"' ,'3' ,0x03B8 ,0x0398 }, +{VK_OEM_COMMA ,0 ,',' ,0x22ee ,'\"' ,'2' ,0x03F1 ,0x21d0 }, +{VK_OEM_PERIOD ,0 ,'.' ,0x2026 ,'\'' ,'3' ,0x03B8 ,0x0398 }, {0 ,0 ,0 ,0 ,0 ,0 ,0 ,0 } }; static ALLOC_SECTION_LDATA VK_TO_WCHARS7 aVkToWch7[] = { -// | | SHIFT | KANA | ALT+CTL | KANA+Shift | ALT+CTL+Kana | Control | +// | | SHIFT | KANA | NEU | KANA+Shift | NEU+Kana | Control | // | |===============|================|===============|===============|================|===============| {VK_OEM_3 ,CAPLOK ,0x00df ,0x1E9E ,0x017F ,WCH_NONE ,0x03C2 ,0x018F ,0x2218 }, {VK_OEM_4 ,0 ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,WCH_DEAD ,0x001d }, {0xff ,0 ,0x0303 ,0x0304 ,0x0308 ,0x0337 ,0x030b ,0x0326 ,WCH_NONE }, {'Y' ,CAPLOK ,'y' ,'Y' ,'@' ,WCH_NONE ,0x03C5 ,0x2207 ,0x001c }, -{VK_SPACE ,0 ,' ' ,' ' ,0x00A0 ,'0' ,' ' ,0x2009 ,' ' }, -{VK_BACK ,0 ,'\b' ,'\b' ,WCH_NONE ,WCH_NONE ,WCH_NONE ,WCH_NONE ,0x007f }, -{VK_ESCAPE ,0 ,0x001b ,0x001b ,WCH_NONE ,WCH_NONE ,WCH_NONE ,WCH_NONE ,0x001b }, +{VK_SPACE ,0 ,' ' ,' ' ,' ' ,'0' ,0x00a0 ,0x2009 ,' ' }, +{VK_BACK ,0 ,'\b' ,'\b' ,'\b' ,'\b' ,'\b' ,'\b' ,0x007f }, +{VK_ESCAPE ,0 ,0x001b ,0x001b ,0x001b ,0x001b ,0x001b ,0x001b ,0x001b }, {VK_RETURN ,0 ,'\r' ,'\r' ,WCH_NONE ,WCH_NONE ,WCH_NONE ,WCH_NONE ,'\n' }, {VK_CANCEL ,0 ,0x0003 ,0x0003 ,WCH_NONE ,WCH_NONE ,WCH_NONE ,WCH_NONE ,0x0003 }, {0 ,0 ,0 ,0 ,0 ,0 ,0 ,0 ,0 } }; static ALLOC_SECTION_LDATA VK_TO_WCHARS8 aVkToWch8[] = { -// | | SHIFT | KANA | ALT+CTL | KANA+Shift | ALT+CTL+Kana | Control | Control+Shift | +// | | SHIFT | KANA | NEU | KANA+Shift | NEU+Kana | Control | Control+Shift | // | |===============|================|===============|===============|================|===============|===============| -{'2' ,CAPLOK ,'2' ,0x2116 ,0x00b2 ,0x2023 ,0x26A5 ,0x2228 ,WCH_NONE ,0x0000 }, -{'6' ,CAPLOK ,'6' ,0x20ac ,0x00Ac ,0x00a3 ,WCH_NONE ,0x2225 ,WCH_NONE ,0x001e }, -{'J' ,CAPLOK ,'j' ,'J' ,';' ,'.' ,0x03D1 ,0x2261 ,WCH_NONE ,0x001f }, +{'2' ,0 ,'2' ,0x2116 ,0x00b2 ,0x2023 ,0x26A5 ,0x2228 ,WCH_NONE ,0x0000 }, +{'6' ,0 ,'6' ,0x20ac ,0x00A2 ,0x00a3 ,WCH_NONE ,0x2225 ,WCH_NONE ,0x001e }, +{'J' ,CAPLOK ,'j' ,'J' ,';' ,WCH_NONE ,0x03D1 ,0x2261 ,WCH_NONE ,0x001f }, {0 ,0 ,0 ,0 ,0 ,0 ,0 ,0 ,0 ,0 } }; // Put this last so that VkKeyScan interprets number characters -// as coming from the main section of the kbd (aVkToWch2 and -// aVkToWch5) before considering the numpad (aVkToWch1). - -static ALLOC_SECTION_LDATA VK_TO_WCHARS1 aVkToWch1[] = { - { VK_NUMPAD0 , 0 , '0' }, - { VK_NUMPAD1 , 0 , '1' }, - { VK_NUMPAD2 , 0 , '2' }, - { VK_NUMPAD3 , 0 , '3' }, - { VK_NUMPAD4 , 0 , '4' }, - { VK_NUMPAD5 , 0 , '5' }, - { VK_NUMPAD6 , 0 , '6' }, - { VK_NUMPAD7 , 0 , '7' }, - { VK_NUMPAD8 , 0 , '8' }, - { VK_NUMPAD9 , 0 , '9' }, - { 0 , 0 , '\0' } -}; +// as coming from the main section of the kbd before considering +// the numpad. + +/* +Entgegen der neo20.txt vorgesehene Belegung 1,2,3,5 ist hier 1,2,3,4 umgesetzt: + +== Vier Ebenen – Ziffernblock == + +-----+ +¦ 1 4 ¦ +¦ 2 3 ¦ + +-----+ +1. Ebene (kein Mod) (Ziffern) +2. Ebene (Umschalt) (Steuertasten) +3. Ebene (Mod3) (Pfeile u.ä.) +4. Ebene (Mod4) (anderes Zeug) +*/ + +static ALLOC_SECTION_LDATA VK_TO_WCHARS4 aVkToWch4[] = { +// | | SHIFT | KANA | NEU | +// | |===============|================|===============| +{VK_ADD ,0 ,'+' ,'+' ,0x00b1 ,0x2213 }, +{VK_DIVIDE ,0 ,'/' ,'/' ,0x00f7 ,0x2215 }, +{VK_MULTIPLY ,0 ,'*' ,'*' ,0x00d7 ,0x2219 }, +{VK_SUBTRACT ,0 ,'-' ,'-' ,0x2052 ,WCH_NONE }, +{VK_DECIMAL ,0 ,',' ,',' ,'.' ,',' }, +{VK_NUMPAD0 ,0 ,'0' ,'0' ,0x0025 ,0x2030 }, +{VK_NUMPAD1 ,0 ,'1' ,'1' ,0x2194 ,0x2264 }, +{VK_NUMPAD2 ,0 ,'2' ,'2' ,0x2193 ,0x222a }, +{VK_NUMPAD3 ,0 ,'3' ,'3' ,0x21cc ,0x2265 }, +{VK_NUMPAD4 ,0 ,'4' ,'4' ,0x2190 ,0x2282 }, +{VK_NUMPAD5 ,0 ,'5' ,'5' ,0x221e ,0x220B }, +{VK_NUMPAD6 ,0 ,'6' ,'6' ,0x2192 ,0x2283 }, +{VK_NUMPAD7 ,0 ,'7' ,'7' ,0x2195 ,0x226a }, +{VK_NUMPAD8 ,0 ,'8' ,'8' ,0x2191 ,0x2229 }, +{VK_NUMPAD9 ,0 ,'9' ,'9' ,0x2297 ,0x226b }, +{0 ,0 ,0 ,0 ,0 ,0 } +}; + +// Hier müssen die verwendeten WChar_Tables vorkommen; Numpad MUSS letzte Zeile sein. static ALLOC_SECTION_LDATA VK_TO_WCHAR_TABLE aVkToWcharTable[] = { - { (PVK_TO_WCHARS1)aVkToWch4, 4, sizeof(aVkToWch4[0]) }, { (PVK_TO_WCHARS1)aVkToWch6, 6, sizeof(aVkToWch6[0]) }, { (PVK_TO_WCHARS1)aVkToWch7, 7, sizeof(aVkToWch7[0]) }, { (PVK_TO_WCHARS1)aVkToWch8, 8, sizeof(aVkToWch8[0]) }, - { (PVK_TO_WCHARS1)aVkToWch2, 2, sizeof(aVkToWch2[0]) }, - { (PVK_TO_WCHARS1)aVkToWch1, 1, sizeof(aVkToWch1[0]) }, + { (PVK_TO_WCHARS1)aVkToWch4, 4, sizeof(aVkToWch4[0]) }, { NULL, 0, 0 }, }; @@ -414,22 +425,22 @@ static ALLOC_SECTION_LDATA DEADKEY_LPWSTR aKeyNamesDead[] = { L"^" L"ZIRKUMFLEX", L"\x030c" L"CARON", L"\x0306" L"BREVIS", - L"\x0335" L"QUERSTRICH", L"\x00b7" L"DOT_MID", + L"\x0335" L"QUERSTRICH", L"\x0323" L"DOT_BELOW", L"\x0301" L"AKUT", L"\x0300" L"GRAVIS", L"\x0327" L"CEDILLA", - L"\x0328" L"OGONEK", L"\x0307" L"DOT_ABOVE", + L"\x0328" L"OGONEK", L"\x030a" L"RING", L"\x0303" L"TILDE", L"\x0304" L"MAKRON", - L"\x0308" L"DIAERASE", - L"\x030b" L"DOPPEL_AKUT", + L"\x0308" L"TREMA", L"\x0337" L"SCHRAEGSTRICH", + L"\x030b" L"DOPPEL_AKUT", L"\x0326" L"KOMMA_BELOW", @@ -437,9 +448,11 @@ static ALLOC_SECTION_LDATA DEADKEY_LPWSTR aKeyNamesDead[] = { }; static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { - +// Schema: +// Deadtrans( Name oder Unicode der normalen Taste, Name oder Unicode der toten Taste, Name oder Unicode der zu bildenden Taste, 0x0000) +// 0, 0 terminiert komplette Liste // Anfang der Taste links neben der 1 - DEADTRANS( L'1' , L'^' , 0x00b9 , 0x0000), //ZIRKUMFLEX + DEADTRANS( L'1' , L'^' , 0x00b9 , 0x0000), //Zirkumflex DEADTRANS( L'2' , L'^' , 0x00b2 , 0x0000), DEADTRANS( L'3' , L'^' , 0x00b3 , 0x0000), DEADTRANS( L'A' , L'^' , 0x00c2 , 0x0000), @@ -486,7 +499,7 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'n' , L'^' , 0x207f , 0x0000), DEADTRANS( L' ' , L'^' , L'^' , 0x0000), - DEADTRANS( L'C' , 0x030c , 0x010c , 0x0000), //CARON + DEADTRANS( L'C' , 0x030c , 0x010c , 0x0000), //Caron DEADTRANS( L'c' , 0x030c , 0x010d , 0x0000), DEADTRANS( L'D' , 0x030c , 0x010e , 0x0000), DEADTRANS( L'd' , 0x030c , 0x010f , 0x0000), @@ -523,7 +536,7 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( 0x00dc , 0x030c , 0x01d9 , 0x0000), DEADTRANS( L' ' , 0x030c , 0x030c , 0x0000), - DEADTRANS( L'A' , 0x0306 , 0x0102 , 0x0000), //BREVIS + DEADTRANS( L'A' , 0x0306 , 0x0102 , 0x0000), //Brevis DEADTRANS( L'a' , 0x0306 , 0x0103 , 0x0000), DEADTRANS( L'E' , 0x0306 , 0x0114 , 0x0000), DEADTRANS( L'e' , 0x0306 , 0x0115 , 0x0000), @@ -536,8 +549,10 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'U' , 0x0306 , 0x016c , 0x0000), DEADTRANS( L'u' , 0x0306 , 0x016d , 0x0000), DEADTRANS( L' ' , 0x0306 , 0x0306 , 0x0000), + + DEADTRANS( L' ' , 0x00b7 , 0x00b7 , 0x0000), //Dot Middle - DEADTRANS( L'1' , 0x0335 , 0x2081 , 0x0000), //QUERSTRICH + DEADTRANS( L'1' , 0x0335 , 0x2081 , 0x0000), //Querstrich DEADTRANS( L'2' , 0x0335 , 0x2082 , 0x0000), DEADTRANS( L'3' , 0x0335 , 0x2083 , 0x0000), DEADTRANS( L'4' , 0x0335 , 0x2084 , 0x0000), @@ -555,9 +570,7 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'x' , 0x0335 , 0x2093 , 0x0000), DEADTRANS( L' ' , 0x0335 , 0x0335 , 0x0000), - DEADTRANS( L' ' , 0x00b7 , 0x00b7 , 0x0000), //DOT_MID - - DEADTRANS( L'B' , 0x0323 , 0x1e04 , 0x0000), //DOT_BELOW + DEADTRANS( L'B' , 0x0323 , 0x1e04 , 0x0000), //Dot Below DEADTRANS( L'b' , 0x0323 , 0x1e05 , 0x0000), DEADTRANS( L'D' , 0x0323 , 0x1e0c , 0x0000), DEADTRANS( L'd' , 0x0323 , 0x1e0d , 0x0000), @@ -596,7 +609,7 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L' ' , 0x0323 , 0x0323 , 0x0000), // Ende der Taste links neben der 1 // Anfang der Tasten zwei rechts neben der 0 - DEADTRANS( L'a' , 0x0301 , 0x00e1 , 0x0000), //AKUT + DEADTRANS( L'a' , 0x0301 , 0x00e1 , 0x0000), //Akut DEADTRANS( L'e' , 0x0301 , 0x00e9 , 0x0000), DEADTRANS( L'i' , 0x0301 , 0x00ed , 0x0000), DEADTRANS( L'o' , 0x0301 , 0x00f3 , 0x0000), @@ -634,7 +647,7 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'w' , 0x0301 , 0x1e83 , 0x0000), DEADTRANS( L' ' , 0x0301 , 0x0301 , 0x0000), - DEADTRANS( L'a' , 0x0300 , 0x00e0 , 0x0000), //GRAVIS + DEADTRANS( L'a' , 0x0300 , 0x00e0 , 0x0000), //Gravis DEADTRANS( L'e' , 0x0300 , 0x00e8 , 0x0000), DEADTRANS( L'i' , 0x0300 , 0x00ec , 0x0000), DEADTRANS( L'o' , 0x0300 , 0x00f2 , 0x0000), @@ -654,7 +667,7 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'y' , 0x0300 , 0x1ef3 , 0x0000), DEADTRANS( L' ' , 0x0300 , 0x0300 , 0x0000), - DEADTRANS( L'C' , 0x0327 , 0x00c7 , 0x0000), //CEDILLA + DEADTRANS( L'C' , 0x0327 , 0x00c7 , 0x0000), //Cedilla DEADTRANS( L'c' , 0x0327 , 0x00e7 , 0x0000), DEADTRANS( L'G' , 0x0327 , 0x0122 , 0x0000), DEADTRANS( L'g' , 0x0327 , 0x0123 , 0x0000), @@ -677,20 +690,8 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'H' , 0x0327 , 0x1e28 , 0x0000), DEADTRANS( L'h' , 0x0327 , 0x1e29 , 0x0000), DEADTRANS( L' ' , 0x0327 , 0x0327 , 0x0000), - - DEADTRANS( L'A' , 0x0328 , 0x0104 , 0x0000), //OGONEK - DEADTRANS( L'a' , 0x0328 , 0x0105 , 0x0000), - DEADTRANS( L'E' , 0x0328 , 0x0118 , 0x0000), - DEADTRANS( L'e' , 0x0328 , 0x0119 , 0x0000), - DEADTRANS( L'I' , 0x0328 , 0x012e , 0x0000), - DEADTRANS( L'i' , 0x0328 , 0x012f , 0x0000), - DEADTRANS( L'U' , 0x0328 , 0x0172 , 0x0000), - DEADTRANS( L'u' , 0x0328 , 0x0173 , 0x0000), - DEADTRANS( L'O' , 0x0328 , 0x01ea , 0x0000), - DEADTRANS( L'o' , 0x0328 , 0x01eb , 0x0000), - DEADTRANS( L' ' , 0x0328 , 0x0328 , 0x0000), - DEADTRANS( L'C' , 0x0307 , 0x010a , 0x0000), //DOT_ABOVE + DEADTRANS( L'C' , 0x0307 , 0x010a , 0x0000), //Dot Above DEADTRANS( L'c' , 0x0307 , 0x010b , 0x0000), DEADTRANS( L'E' , 0x0307 , 0x0116 , 0x0000), DEADTRANS( L'e' , 0x0307 , 0x0117 , 0x0000), @@ -731,71 +732,180 @@ static ALLOC_SECTION_LDATA DEADKEY aDeadKey[] = { DEADTRANS( L'Y' , 0x0307 , 0x1e8e , 0x0000), DEADTRANS( L'y' , 0x0307 , 0x1e8f , 0x0000), DEADTRANS( L' ' , 0x0307 , 0x0307 , 0x0000), + + DEADTRANS( L'A' , 0x0328 , 0x0104 , 0x0000), //Ogonek + DEADTRANS( L'a' , 0x0328 , 0x0105 , 0x0000), + DEADTRANS( L'E' , 0x0328 , 0x0118 , 0x0000), + DEADTRANS( L'e' , 0x0328 , 0x0119 , 0x0000), + DEADTRANS( L'I' , 0x0328 , 0x012e , 0x0000), + DEADTRANS( L'i' , 0x0328 , 0x012f , 0x0000), + DEADTRANS( L'U' , 0x0328 , 0x0172 , 0x0000), + DEADTRANS( L'u' , 0x0328 , 0x0173 , 0x0000), + DEADTRANS( L'O' , 0x0328 , 0x01ea , 0x0000), + DEADTRANS( L'o' , 0x0328 , 0x01eb , 0x0000), + DEADTRANS( L' ' , 0x0328 , 0x0328 , 0x0000), - DEADTRANS( L'E' , 0x030a , 0x0116 , 0x0000), //RING - DEADTRANS( L'e' , 0x030a , 0x030a , 0x0000), - DEADTRANS( L'e' , 0x030a , 0x030a , 0x0000), - - - DEADTRANS( L'e' , 0x030a , 0x030a , 0x0000), - - - - - - - - + DEADTRANS( L'E' , 0x030a , 0x0116 , 0x0000), //Ring + DEADTRANS( L'e' , 0x030a , 0x0117 , 0x0000), + DEADTRANS( L'G' , 0x030a , 0x0120 , 0x0000), + DEADTRANS( L'g' , 0x030a , 0x0121 , 0x0000), + DEADTRANS( L'I' , 0x030a , 0x0130 , 0x0000), + DEADTRANS( L'i' , 0x030a , 0x0131 , 0x0000), + DEADTRANS( L'Z' , 0x030a , 0x017B , 0x0000), + DEADTRANS( L'z' , 0x030a , 0x017C , 0x0000), + DEADTRANS( L'A' , 0x030a , 0x0226 , 0x0000), + DEADTRANS( L'a' , 0x030a , 0x0227 , 0x0000), + DEADTRANS( L'O' , 0x030a , 0x022e , 0x0000), + DEADTRANS( L'o' , 0x030a , 0x022f , 0x0000), + DEADTRANS( L'B' , 0x030a , 0x1e02 , 0x0000), + DEADTRANS( L'b' , 0x030a , 0x1e03 , 0x0000), + DEADTRANS( L'D' , 0x030a , 0x1e0a , 0x0000), + DEADTRANS( L'd' , 0x030a , 0x1e0b , 0x0000), + DEADTRANS( L'F' , 0x030a , 0x1e1e , 0x0000), + DEADTRANS( L'f' , 0x030a , 0x1e1f , 0x0000), + DEADTRANS( L'H' , 0x030a , 0x1e22 , 0x0000), + DEADTRANS( L'h' , 0x030a , 0x1e23 , 0x0000), + DEADTRANS( L'M' , 0x030a , 0x1e40 , 0x0000), + DEADTRANS( L'm' , 0x030a , 0x1e41 , 0x0000), + DEADTRANS( L'N' , 0x030a , 0x1e44 , 0x0000), + DEADTRANS( L'n' , 0x030a , 0x1e45 , 0x0000), + DEADTRANS( L'P' , 0x030a , 0x1e56 , 0x0000), + DEADTRANS( L'p' , 0x030a , 0x1e57 , 0x0000), + DEADTRANS( L'R' , 0x030a , 0x1e58 , 0x0000), + DEADTRANS( L'r' , 0x030a , 0x1e59 , 0x0000), + DEADTRANS( L'S' , 0x030a , 0x1e60 , 0x0000), + DEADTRANS( L's' , 0x030a , 0x1e61 , 0x0000), + DEADTRANS( L'T' , 0x030a , 0x1e6a , 0x0000), + DEADTRANS( L't' , 0x030a , 0x1e6b , 0x0000), + DEADTRANS( L'W' , 0x030a , 0x1e86 , 0x0000), + DEADTRANS( L'w' , 0x030a , 0x1e87 , 0x0000), + DEADTRANS( L'X' , 0x030a , 0x1e8a , 0x0000), + DEADTRANS( L'x' , 0x030a , 0x1e8b , 0x0000), + DEADTRANS( L'Y' , 0x030a , 0x1e8e , 0x0000), + DEADTRANS( L'y' , 0x030a , 0x1e8f , 0x0000), + DEADTRANS( L' ' , 0x030a , 0x030a , 0x0000), + // Ende der Taste zwei rechts neben der 0 + // Anfang der Taste rechts neben dem »ß« + DEADTRANS( L'A' , 0x0303 , 0x00c3 , 0x0000), //Tilde + DEADTRANS( L'N' , 0x0303 , 0x00d1 , 0x0000), + DEADTRANS( L'O' , 0x0303 , 0x00d5 , 0x0000), + DEADTRANS( L'a' , 0x0303 , 0x00e3 , 0x0000), + DEADTRANS( L'n' , 0x0303 , 0x00f1 , 0x0000), + DEADTRANS( L'o' , 0x0303 , 0x00f5 , 0x0000), + DEADTRANS( L'I' , 0x0303 , 0x0128 , 0x0000), + DEADTRANS( L'i' , 0x0303 , 0x0129 , 0x0000), + DEADTRANS( L'U' , 0x0303 , 0x0168 , 0x0000), + DEADTRANS( L'u' , 0x0303 , 0x0169 , 0x0000), + DEADTRANS( L'V' , 0x0303 , 0x1e7c , 0x0000), + DEADTRANS( L'v' , 0x0303 , 0x1e7d , 0x0000), + DEADTRANS( L'E' , 0x0303 , 0x1ebc , 0x0000), + DEADTRANS( L'e' , 0x0303 , 0x1ebd , 0x0000), + DEADTRANS( L'Y' , 0x0303 , 0x1ef8 , 0x0000), + DEADTRANS( L'y' , 0x0303 , 0x1ef9 , 0x0000), + DEADTRANS( L' ' , 0x0303 , 0x0303 , 0x0000), + DEADTRANS( L'A' , 0x0304 , 0x0100 , 0x0000), //Makron + DEADTRANS( L'a' , 0x0304 , 0x0101 , 0x0000), + DEADTRANS( L'E' , 0x0304 , 0x0112 , 0x0000), + DEADTRANS( L'e' , 0x0304 , 0x0113 , 0x0000), + DEADTRANS( L'I' , 0x0304 , 0x012a , 0x0000), + DEADTRANS( L'i' , 0x0304 , 0x012b , 0x0000), + DEADTRANS( L'O' , 0x0304 , 0x014c , 0x0000), + DEADTRANS( L'o' , 0x0304 , 0x014d , 0x0000), + DEADTRANS( L'U' , 0x0304 , 0x016a , 0x0000), + DEADTRANS( L'u' , 0x0304 , 0x016b , 0x0000), + DEADTRANS( L'Y' , 0x0304 , 0x0232 , 0x0000), + DEADTRANS( L'y' , 0x0304 , 0x0233 , 0x0000), + DEADTRANS( L'G' , 0x0304 , 0x1e20 , 0x0000), + DEADTRANS( L'g' , 0x0304 , 0x1e21 , 0x0000), + DEADTRANS( L' ' , 0x0304 , 0x0304 , 0x0000), -// Ende der Tasten zwei rechts neben der 0 -//Fehlt noch viel :( + DEADTRANS( L'A' , 0x0308 , 0x00c4 , 0x0000), //Diaräse + DEADTRANS( L'E' , 0x0308 , 0x00cb , 0x0000), + DEADTRANS( L'I' , 0x0308 , 0x00cf , 0x0000), + DEADTRANS( L'O' , 0x0308 , 0x00d6 , 0x0000), + DEADTRANS( L'U' , 0x0308 , 0x00dc , 0x0000), + DEADTRANS( L'a' , 0x0308 , 0x00e4 , 0x0000), + DEADTRANS( L'e' , 0x0308 , 0x00eb , 0x0000), + DEADTRANS( L'i' , 0x0308 , 0x00ef , 0x0000), + DEADTRANS( L'o' , 0x0308 , 0x00f6 , 0x0000), + DEADTRANS( L'u' , 0x0308 , 0x00fc , 0x0000), + DEADTRANS( L'y' , 0x0308 , 0x0177 , 0x0000), + DEADTRANS( L'Y' , 0x0308 , 0x0178 , 0x0000), + DEADTRANS( L'H' , 0x0308 , 0x1e26 , 0x0000), + DEADTRANS( L'h' , 0x0308 , 0x1e27 , 0x0000), + DEADTRANS( L'W' , 0x0308 , 0x1e84 , 0x0000), + DEADTRANS( L'w' , 0x0308 , 0x1e85 , 0x0000), + DEADTRANS( L'X' , 0x0308 , 0x1e8c , 0x0000), + DEADTRANS( L'x' , 0x0308 , 0x1e8d , 0x0000), + DEADTRANS( L't' , 0x0308 , 0x1e97 , 0x0000), + DEADTRANS( L' ' , 0x0308 , 0x0308 , 0x0000), + + DEADTRANS( L'O' , 0x0337 , 0x00d8 , 0x0000), //Schrägstrich + DEADTRANS( L'o' , 0x0337 , 0x00f8 , 0x0000), + DEADTRANS( L'L' , 0x0337 , 0x0141 , 0x0000), + DEADTRANS( L'l' , 0x0337 , 0x0142 , 0x0000), + DEADTRANS( L' ' , 0x0337 , 0x0337 , 0x0000), + + DEADTRANS( L'O' , 0x030b , 0x0150 , 0x0000), //Doppel Akut + DEADTRANS( L'o' , 0x030b , 0x0151 , 0x0000), + DEADTRANS( L'U' , 0x030b , 0x0170 , 0x0000), + DEADTRANS( L'u' , 0x030b , 0x0171 , 0x0000), + DEADTRANS( L' ' , 0x030b , 0x030b , 0x0000), + + DEADTRANS( L'S' , 0x0326 , 0x0218 , 0x0000), //Komma Below + DEADTRANS( L's' , 0x0326 , 0x0219 , 0x0000), + DEADTRANS( L'T' , 0x0326 , 0x021a , 0x0000), + DEADTRANS( L't' , 0x0326 , 0x021b , 0x0000), + DEADTRANS( L' ' , 0x0326 , 0x0326 , 0x0000), +// Ende der Tasten rechts neben dem »ß« 0, 0 }; static ALLOC_SECTION_LDATA KBDTABLES KbdTables = { - /* - * Modifier keys - */ +/* +* Modifier keys +*/ &CharModifiers, - /* - * Characters tables - */ +/* +* Characters tables +*/ aVkToWcharTable, - /* - * Diacritics - */ +/* +* Diacritics +*/ aDeadKey, - /* - * Names of Keys - */ +/* +* Names of Keys +*/ aKeyNames, aKeyNamesExt, aKeyNamesDead, - /* - * Scan codes to Virtual Keys - */ +/* +* Scan codes to Virtual Keys +*/ ausVK, sizeof(ausVK) / sizeof(ausVK[0]), aE0VscToVk, aE1VscToVk, - /* - * Locale-specific special processing - */ - MAKELONG(KLLF_ALTGR, KBD_VERSION), - - /* - * Ligatures - */ - 0, - 0, - NULL +/* +* Locale-specific special processing +* KLLF_ALTGR damit AltGr = Strg+Alt +*/ + MAKELONG(KLLF_ALTGR, KBD_VERSION), + +/* +* Ligatures +*/ + 0, + 0, + NULL }; PKBDTABLES KbdLayerDescriptor(VOID) diff --git a/windows/kbdneo2/Quelldateien/kbdneo2.h b/windows/kbdneo2/Quelldateien/kbdneo2.h index e4177b1..55df595 100644 --- a/windows/kbdneo2/Quelldateien/kbdneo2.h +++ b/windows/kbdneo2/Quelldateien/kbdneo2.h @@ -1,12 +1,10 @@ /****************************** Module Header ******************************\ * Module Name: KBDNEO2.H * -* keyboard layout header for NEO German +* keyboard layout header for German NEO 2.0 * * Various defines for use by keyboard input code. * -* History: Ver 0.1 -* \***************************************************************************/ /* @@ -30,7 +28,7 @@ * | Scan | | kbd | kbd | kbd | kbd | kbd | kbd | * | code | | type 1 | type 2 | type 3 | type 4 | type 5 | type 6 | \****+-------+_+----------+----------+----------+----------+----------+----------+*/ - +// Tastenumbelegung für Neo 2.0 ; sonstige Tastenzuordnung siehe kbd.h #undef T0D #define T0D _EQ( OEM_2 ) #undef T10 @@ -83,7 +81,6 @@ #define T29 _EQ( OEM_1 ) #undef T2B #define T2B _EQ( KANA ) // Mod 3 -// #define T2B _EQ( OEM_ROYA ) #undef T2C #define T2C _EQ( OEM_5 ) #undef T2D @@ -100,10 +97,9 @@ #define T35 _EQ( 'J' ) #undef T3A #define T3A _EQ( KANA )// Mod 3 -// #define T3A _EQ( OEM_ROYA ) #undef X38 -#define X38 _EQ( RMENU )// Mod 5 -// #define X38 _EQ( OEM_102 ) +//#define X38 _EQ( RMENU )// Mod 4 +#define X38 _EQ( OEM_102 ) #undef T56 -#define T56 _EQ( RMENU )// Mod 5 -// #define T56 _EQ( OEM_102 ) \ No newline at end of file +//#define T56 _EQ( RMENU )// Mod 4 +#define T56 _EQ( OEM_102 ) \ No newline at end of file diff --git a/windows/kbdneo2/Quelldateien/kbdneo2.rc b/windows/kbdneo2/Quelldateien/kbdneo2.rc index ec83d64..7097390 100644 --- a/windows/kbdneo2/Quelldateien/kbdneo2.rc +++ b/windows/kbdneo2/Quelldateien/kbdneo2.rc @@ -3,7 +3,7 @@ #define VER_FILETYPE VFT_DLL #define VER_FILESUBTYPE VFT2_DRV_KEYBOARD -#define VER_FILEDESCRIPTION_STR "NEO2 German ergonomic Keyboard Layout" +#define VER_FILEDESCRIPTION_STR "Deutsch (NEO 2.0 ergonomisch) Tastaturlayout" #define VER_INTERNALNAME_STR "kbdneo2" #define VER_ORIGINALFILENAME_STR "kbdneo2.dll" diff --git a/windows/kbdneo2/Treiber/1stREADME.txt b/windows/kbdneo2/Treiber/1stREADME.txt new file mode 100644 index 0000000..782452f --- /dev/null +++ b/windows/kbdneo2/Treiber/1stREADME.txt @@ -0,0 +1,36 @@ +== Installation der Windows-Treiber == +Zur Zeit gibt es leider noch keine eigene Installationsroutine für diese Treiber. +Deshalb muss der Treiber noch von Hand registriert werden. + +Installation: +1.) reg_backup.bat ausführen. + Dies sichert einen bereits vorhandenen Schlüssel. Wenn der Schlüssel + bislang noch nicht vorhanden war wird auch keine Sicherungsdatei angelegt. +2.) kbdneo2.dll nach \%SystemRoot%\system32\ (in der Regel C:\Windows\system32\) + kopieren. +3.) kbdneo2_install.reg ausführen. +4.) Nun kann das in den Sprachoptionen Neo 2.0 ausgewählt werden. D(Start->Einstellungen->Systemsteuerung) unter „Regions- und Sprachoptionen“ -> Reiter „Sprachen“ -> „Details“ -> „Hinzufügen“ -> „Tastaturlayout/IME“ -> „Deutsch (NEO ergonomisch 2.0)“ hinzugefügt werden. + +Deinstallation: +1.) Neo 2.0 nicht mehr als Tastaturlayout verwenden. Dazu das Layout in den „Regions- und Sprachoptionen“ entfernen. +2.) kbdneo2_uninstall.reg ausführen. Hierbei werden alle vorgenommenen Einträge in der Registry gelöscht. +3.) Falls vorhanden die gesicherten Schlüssel zurückspielen (backup1.reg, backup2.reg und backup3reg –soweit vorhanden– ausführen) + +Je nach Windows-Version sind für die einzelnen Schritte Administrator-Rechte nötig. + + +== Einschränkungen dieser Treiberversion == +1.) Einige spezielle Funktionen lassen sich nicht belegen und sind deshalb nicht + verfügbar. + Dazu gehören leider die Pfeiltasten, Entf, Seite hoch/runter, Einfg, Pos1 und + Ende. +2.) Ein Einrasten von Modifiern ist treibertechnisch leider nicht möglich. +3.) Die Kombo-/Komponier-/Compose-Taste wird von Windows nicht unterstützt. + +Diese Mängel sollen durch einen spezielle AutoHotKey-Treiber noch behoben werden. + + +== Entfernen einer evtl. vorhandenen MSKLC-Treibers == +1. Setup des MSKLC aufrufen +2. „Remove the keyboard layout“ auswählen und mit „Finish“ bestätigen. + diff --git a/windows/kbdneo2/Treiber/32bit_Windows_Server_2003/NEO20.dll b/windows/kbdneo2/Treiber/32bit_Windows_Server_2003/NEO20.dll deleted file mode 100644 index 0f69144..0000000 Binary files a/windows/kbdneo2/Treiber/32bit_Windows_Server_2003/NEO20.dll and /dev/null differ diff --git a/windows/kbdneo2/Treiber/32bit_Windows_Server_2003/kbdneo2.dll b/windows/kbdneo2/Treiber/32bit_Windows_Server_2003/kbdneo2.dll new file mode 100644 index 0000000..307ff71 Binary files /dev/null and b/windows/kbdneo2/Treiber/32bit_Windows_Server_2003/kbdneo2.dll differ diff --git a/windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll b/windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll deleted file mode 100644 index ad26439..0000000 Binary files a/windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll and /dev/null differ diff --git a/windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll b/windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll new file mode 100644 index 0000000..c4cdec6 Binary files /dev/null and b/windows/kbdneo2/Treiber/32bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll differ diff --git a/windows/kbdneo2/Treiber/32bit_Windows_XP/NEO20.dll b/windows/kbdneo2/Treiber/32bit_Windows_XP/NEO20.dll deleted file mode 100644 index f207250..0000000 Binary files a/windows/kbdneo2/Treiber/32bit_Windows_XP/NEO20.dll and /dev/null differ diff --git a/windows/kbdneo2/Treiber/32bit_Windows_XP/kbdneo2.dll b/windows/kbdneo2/Treiber/32bit_Windows_XP/kbdneo2.dll new file mode 100644 index 0000000..801d735 Binary files /dev/null and b/windows/kbdneo2/Treiber/32bit_Windows_XP/kbdneo2.dll differ diff --git a/windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/NEO20.dll b/windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/NEO20.dll deleted file mode 100644 index 8fdcd18..0000000 Binary files a/windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/NEO20.dll and /dev/null differ diff --git a/windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/kbdneo2.dll b/windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/kbdneo2.dll new file mode 100644 index 0000000..93d8333 Binary files /dev/null and b/windows/kbdneo2/Treiber/64bit_Windows_Server_2003_und_Windows_XP/kbdneo2.dll differ diff --git a/windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll b/windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll deleted file mode 100644 index 24c8ce4..0000000 Binary files a/windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/NEO20.dll and /dev/null differ diff --git a/windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll b/windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll new file mode 100644 index 0000000..08e9a67 Binary files /dev/null and b/windows/kbdneo2/Treiber/64bit_Windows_Vista_und_Windows_Server_Longhorn/kbdneo2.dll differ diff --git a/windows/kbdneo2/Treiber/README.txt b/windows/kbdneo2/Treiber/README.txt deleted file mode 100644 index 45491f3..0000000 --- a/windows/kbdneo2/Treiber/README.txt +++ /dev/null @@ -1,16 +0,0 @@ -==Installation der Windows-Treiber == -Zur Zeit gibt es leider noch keine eigene Installationsroutine für diese Treiber. Deshalb muss zuerst noch die MSKLC-Variante installiert werden und anschließend die NEO20.dll-Datei im Ordner \WINDOWS\system32 mit der hier -vorhandenen Datei überschrieben werden. - -1.) MSKLC installieren -2.) NEO20.dll nach \WINDOWS\system32 kopieren und die dort vorhandene Version überschreiben -3.) Jetzt kann in der Systemsteuerung (Start->Einstellungen->Systemsteuerung) unter „Regions- und Sprachoptionen“ -> Reiter „Sprachen“ -> „Details“ -> „Hinzufügen“ -> „Tastaturlayout/IME“ -> „Deutsch (NEO ergonomisch 2.0)“ hinzugefügt werden. - -Es ist keine Registry-Änderung mehr nötig! - -==Installation der Windows-Treiber == -1.) Einige spezielle Funktionen lassen sich (noch?) nicht belegen und sind deshalb leider nicht verfügbar. -Dazu gehören leider die Pfeiltasten, Entf, Seite hoch/runter, Einfg, Pos1 und Ende. -2.) Ein Einrasten von Modifiern ist treibertechnisch leider nicht möglich. -3.) Die Kombo-/Komponier-/Compose-Taste wird nicht unterstützt. -4.) Leider verwenden einige Programme Strg+Alt+… für Shortcuts. Damit kann es zu Konflikten zwischen den Programmen und den Ebenen 4 und 6 kommen. diff --git a/windows/kbdneo2/Treiber/kbdneo2_install.reg b/windows/kbdneo2/Treiber/kbdneo2_install.reg new file mode 100644 index 0000000..3881eca Binary files /dev/null and b/windows/kbdneo2/Treiber/kbdneo2_install.reg differ diff --git a/windows/kbdneo2/Treiber/kbdneo2_uninstall.reg b/windows/kbdneo2/Treiber/kbdneo2_uninstall.reg new file mode 100644 index 0000000..dbb2a2f Binary files /dev/null and b/windows/kbdneo2/Treiber/kbdneo2_uninstall.reg differ diff --git a/windows/kbdneo2/Treiber/reg_backup.bat b/windows/kbdneo2/Treiber/reg_backup.bat new file mode 100644 index 0000000..3c9d647 --- /dev/null +++ b/windows/kbdneo2/Treiber/reg_backup.bat @@ -0,0 +1,3 @@ +start Regedit /e backup1.reg "HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Control\Keyboard Layouts\b0000407" +start Regedit /e backup2.reg "HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Control\Keyboard Layouts\b0000407" +start Regedit /e backup3.reg "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Keyboard Layouts\b0000407" \ No newline at end of file -- cgit v1.2.3