From 8b3e3dd6c07ae571ab099be4ff1b5adfdc48322a Mon Sep 17 00:00:00 2001 From: Eric Kohl Date: Sat, 14 Apr 2007 14:26:46 +0000 Subject: [PATCH] - Swap mouse buttons on-the-fly. - Add mouse button preview icons. - Change double click speed on-the-fly. - Add double click test icons. - Fix double click speed calculation. - Get rid of rsrc.rc. svn path=/trunk/; revision=26338 --- reactos/dll/cpl/main/lang/cs-CZ.rc | 8 +- reactos/dll/cpl/main/lang/de-DE.rc | 10 +- reactos/dll/cpl/main/lang/en-US.rc | 10 +- reactos/dll/cpl/main/lang/es-ES.rc | 8 +- reactos/dll/cpl/main/lang/fr-FR.rc | 8 +- reactos/dll/cpl/main/lang/hu-HU.rc | 8 +- reactos/dll/cpl/main/lang/id-ID.rc | 8 +- reactos/dll/cpl/main/lang/it-IT.rc | 8 +- reactos/dll/cpl/main/lang/ja-JP.rc | 8 +- reactos/dll/cpl/main/lang/nl-NL.rc | 8 +- reactos/dll/cpl/main/lang/ru-RU.rc | 8 +- reactos/dll/cpl/main/lang/uk-UA.rc | 8 +- reactos/dll/cpl/main/main.rc | 26 +- reactos/dll/cpl/main/mouse.c | 577 ++++++++++++++++++----------- reactos/dll/cpl/main/resource.h | 7 +- reactos/dll/cpl/main/rsrc.rc | 24 -- 16 files changed, 438 insertions(+), 296 deletions(-) delete mode 100644 reactos/dll/cpl/main/rsrc.rc diff --git a/reactos/dll/cpl/main/lang/cs-CZ.rc b/reactos/dll/cpl/main/lang/cs-CZ.rc index 4c67eed455c..f107d6e2b46 100644 --- a/reactos/dll/cpl/main/lang/cs-CZ.rc +++ b/reactos/dll/cpl/main/lang/cs-CZ.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Nastavení tlaèítek", -1, 5, 5, 230, 70 CHECKBOX "Z&amìnit levé a pravé tlaèítko", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Zaškrtnutím toto políèka nastavíte pravé tlaèítko jako primární pro funkce jako výbìr nebo pøetažení.", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Zaškrtnutím toto políèka nastavíte pravé tlaèítko jako primární pro funkce jako výbìr nebo pøetažení.", -1, 10, 30, 150, 30 GROUPBOX "Rychlost poklepání", -1, 5, 75, 230, 70 - LTEXT "Poklepejte na složku pro otestování nastavení. Pokud se složka neotevøe, zkuste nižší rychlost.", -1, 10, 85, 160, 30 + LTEXT "Poklepejte na složku pro otestování nastavení. Pokud se složka neotevøe, zkuste nižší rychlost.", -1, 10, 85, 150, 30 LTEXT "&Rychlost: Malá", -1, 10, 120, 90, 8 LTEXT "Velká", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "Funkce ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Zapnout funkci ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 100, 20 PUSHBUTTON "&Nastavení...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/de-DE.rc b/reactos/dll/cpl/main/lang/de-DE.rc index b56ef9e4e7a..34d94cad604 100644 --- a/reactos/dll/cpl/main/lang/de-DE.rc +++ b/reactos/dll/cpl/main/lang/de-DE.rc @@ -55,17 +55,17 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Tastenkonfiguration", -1, 5, 5, 230, 70 CHECKBOX "&Primäre und sekundäre Taste umschalten", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 145, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Aktivieren Sie dieses Kontrollkästchen, um die rechte Maustaste für primäre Funktionen, wie Auswählen und Ziehen zu verwenden.", -1, 10, 30, 140, 31 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Aktivieren Sie dieses Kontrollkästchen, um die rechte Maustaste für primäre Funktionen, wie Auswählen und Ziehen zu verwenden.", -1, 10, 30, 150, 31 GROUPBOX "Doppelklickgeschwindigkeit", -1, 5, 75, 230, 70 - LTEXT "Doppelklicken Sie auf den Ordner, um die Einstellung zu testen. Verwenden Sie eine langsamere Einstellung, wenn der Ordner sich nicht öffnen oder schließen lässt.", -1, 10, 85, 160, 32 + LTEXT "Doppelklicken Sie auf den Ordner, um die Einstellung zu testen. Verwenden Sie eine langsamere Einstellung, wenn der Ordner sich nicht öffnen oder schließen lässt.", -1, 10, 85, 150, 32 LTEXT "Langsam", -1, 10, 120, 90, 8 LTEXT "Schnell", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "KlickEinrasten", -1, 5, 150, 230, 70 CHECKBOX "&KlickEinrasten aktivieren", IDC_CHECK_CLICK_LOCK, 10, 160, 91, 20 - PUSHBUTTON "&Einstellungen...", IDC_BUTTON_CLICK_LOCK, 167, 160, 53, 10 + PUSHBUTTON "&Einstellungen...", IDC_BUTTON_CLICK_LOCK, 167, 160, 60, 14 LTEXT "Ermöglicht das Markieren oder Ziehen, ohne die Maustaste ständig gedrückt zu halten. Drücken Sie die Maustaste kurzzeitig, um die Funktion zu verwenden. Klicken Sie die Maustaste erneut, um die Tastenfeststellung zu beenden.", -1, 10, 180, 190, 33 END diff --git a/reactos/dll/cpl/main/lang/en-US.rc b/reactos/dll/cpl/main/lang/en-US.rc index f8fd59c9918..bbd22b4c053 100644 --- a/reactos/dll/cpl/main/lang/en-US.rc +++ b/reactos/dll/cpl/main/lang/en-US.rc @@ -53,17 +53,17 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Button configuration", -1, 5, 5, 230, 70 CHECKBOX "&Switch primary and secondary buttons", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 150, 30 GROUPBOX "Double-click speed", -1, 5, 75, 230, 70 - LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 160, 30 + LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 150, 30 LTEXT "Spee&d: Slow", -1, 10, 120, 90, 8 LTEXT "Fast", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Turn on ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 - PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 + PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 LTEXT "Enables you to highlight or drag without holding down the mouse button. To set, briefly press the mouse button. To release, click the mouse button again", -1, 10, 180, 190, 30 END diff --git a/reactos/dll/cpl/main/lang/es-ES.rc b/reactos/dll/cpl/main/lang/es-ES.rc index ae7f0ab9224..b65c3541fb8 100644 --- a/reactos/dll/cpl/main/lang/es-ES.rc +++ b/reactos/dll/cpl/main/lang/es-ES.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Button configuration", -1, 5, 5, 230, 70 CHECKBOX "&Switch primary and secondary buttons", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 150, 30 GROUPBOX "Double-click speed", -1, 5, 75, 230, 70 - LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 160, 30 + LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 150, 30 LTEXT "Spee&d: Slow", -1, 10, 120, 90, 8 LTEXT "Fast", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Turn on ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/fr-FR.rc b/reactos/dll/cpl/main/lang/fr-FR.rc index 6c2608d30f2..5a0cff64cb2 100644 --- a/reactos/dll/cpl/main/lang/fr-FR.rc +++ b/reactos/dll/cpl/main/lang/fr-FR.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Configuration des boutons", -1, 5, 5, 230, 70 CHECKBOX "&Inverser les boutons gauche et droite", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Cochez cette case pour faire du bouton droit le bouton principal pour les fonctions telles que la sélection et le déplacement.", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Cochez cette case pour faire du bouton droit le bouton principal pour les fonctions telles que la sélection et le déplacement.", -1, 10, 30, 150, 30 GROUPBOX "Vitesse du double-click ", -1, 5, 75, 230, 70 - LTEXT "Double-cliquer le dossier pour tester le paramètre. Si le dossier ne s'ouvre pas ou se ferme, essayez un réglage plus lent.", -1, 10, 85, 135, 30 + LTEXT "Double-cliquer le dossier pour tester le paramètre. Si le dossier ne s'ouvre pas ou se ferme, essayez un réglage plus lent.", -1, 10, 85, 150, 30 LTEXT "Vite&sse: Lente", -1, 10, 120, 90, 8 LTEXT "Rapide", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "Verrouillage clic", -1, 5, 150, 230, 70 CHECKBOX "&Activer le Verrouillage clic", IDC_CHECK_CLICK_LOCK, 10, 160, 95, 20 PUSHBUTTON "&Paramètres...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 15 diff --git a/reactos/dll/cpl/main/lang/hu-HU.rc b/reactos/dll/cpl/main/lang/hu-HU.rc index 51491df03dd..fb773334054 100644 --- a/reactos/dll/cpl/main/lang/hu-HU.rc +++ b/reactos/dll/cpl/main/lang/hu-HU.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Button configuration", -1, 5, 5, 230, 70 CHECKBOX "&Switch primary and secondary buttons", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 150, 30 GROUPBOX "Double-click speed", -1, 5, 75, 230, 70 - LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 160, 30 + LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 150, 30 LTEXT "Spee&d: Slow", -1, 10, 120, 90, 8 LTEXT "Fast", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Turn on ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/id-ID.rc b/reactos/dll/cpl/main/lang/id-ID.rc index 09ba591337b..70a9686154b 100644 --- a/reactos/dll/cpl/main/lang/id-ID.rc +++ b/reactos/dll/cpl/main/lang/id-ID.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Konfigurasi tombol", -1, 5, 5, 230, 70 CHECKBOX "&Saklar primer dan tombol sekunder", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Pilih kotak centang ini untuk membuat tombol yang benar yang biasa anda pakai fungsi primer seperi memilih dan menggeser", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Pilih kotak centang ini untuk membuat tombol yang benar yang biasa anda pakai fungsi primer seperi memilih dan menggeser", -1, 10, 30, 150, 30 GROUPBOX "Kecepatan klik-dobel", -1, 5, 75, 230, 70 - LTEXT "Klik-dobel folder untuk menguji setelan anda. Jika folder tidak membuka atau menutup, coba menggunakan setelan lebih lambat.", -1, 10, 85, 160, 30 + LTEXT "Klik-dobel folder untuk menguji setelan anda. Jika folder tidak membuka atau menutup, coba menggunakan setelan lebih lambat.", -1, 10, 85, 150, 30 LTEXT "Ke&cepatan: Lambat", -1, 10, 120, 90, 8 LTEXT "Cepat", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "Kunci Klik", -1, 5, 150, 230, 70 CHECKBOX "&Hidupkan KunciKlik", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Setelan...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/it-IT.rc b/reactos/dll/cpl/main/lang/it-IT.rc index 9f05c73589a..c3345b67191 100644 --- a/reactos/dll/cpl/main/lang/it-IT.rc +++ b/reactos/dll/cpl/main/lang/it-IT.rc @@ -55,14 +55,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Configurazione dei bottoni", -1, 5, 5, 230, 70 CHECKBOX "&Scambia il bottone secondario e primario", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Assegna al tasto destro del mouse le funzioni principali come ad esempio la selezione e il trascinamento", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Assegna al tasto destro del mouse le funzioni principali come ad esempio la selezione e il trascinamento", -1, 10, 30, 150, 30 GROUPBOX "Velocità del doppio clic", -1, 5, 75, 230, 70 - LTEXT "Fai doppio clic sulla cartella per verificare le impostazioni. Se la cartella non si apre o chiude, prova a usare una velocità minore.", -1, 10, 85, 160, 30 + LTEXT "Fai doppio clic sulla cartella per verificare le impostazioni. Se la cartella non si apre o chiude, prova a usare una velocità minore.", -1, 10, 85, 150, 30 LTEXT "Velocità: Lenta", -1, 10, 120, 90, 8 LTEXT "Veloce", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "Blocca clic", -1, 5, 150, 230, 70 CHECKBOX "&Abilita Blocca Clic", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Impostazioni...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/ja-JP.rc b/reactos/dll/cpl/main/lang/ja-JP.rc index d2bb36a7cc0..2cde10b534a 100644 --- a/reactos/dll/cpl/main/lang/ja-JP.rc +++ b/reactos/dll/cpl/main/lang/ja-JP.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Button configuration", -1, 5, 5, 230, 70 CHECKBOX "&Switch primary and secondary buttons", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 150, 30 GROUPBOX "Double-click speed", -1, 5, 75, 230, 70 - LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 160, 30 + LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 150, 30 LTEXT "Spee&d: Slow", -1, 10, 120, 90, 8 LTEXT "Fast", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Turn on ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/nl-NL.rc b/reactos/dll/cpl/main/lang/nl-NL.rc index 6566cd049e5..e0baaf17da4 100644 --- a/reactos/dll/cpl/main/lang/nl-NL.rc +++ b/reactos/dll/cpl/main/lang/nl-NL.rc @@ -52,14 +52,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Button configuration", -1, 5, 5, 230, 70 CHECKBOX "&Switch primary and secondary buttons", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 150, 30 GROUPBOX "Double-click speed", -1, 5, 75, 230, 70 - LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 160, 30 + LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 150, 30 LTEXT "Spee&d: Slow", -1, 10, 120, 90, 8 LTEXT "Fast", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Turn on ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/ru-RU.rc b/reactos/dll/cpl/main/lang/ru-RU.rc index d913c831d35..013d177463f 100644 --- a/reactos/dll/cpl/main/lang/ru-RU.rc +++ b/reactos/dll/cpl/main/lang/ru-RU.rc @@ -53,14 +53,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Button configuration", -1, 5, 5, 230, 70 CHECKBOX "&Switch primary and secondary buttons", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Select this checkbox to make the button the right one the one you use for primary functions such as selecting and dragging", -1, 10, 30, 150, 30 GROUPBOX "Double-click speed", -1, 5, 75, 230, 70 - LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 160, 30 + LTEXT "Double-click the folder to test your settings. If the folder does not open or close, try using a slower setting.", -1, 10, 85, 150, 30 LTEXT "Spee&d: Slow", -1, 10, 120, 90, 8 LTEXT "Fast", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "ClickLock", -1, 5, 150, 230, 70 CHECKBOX "&Turn on ClickLock", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Settings...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/lang/uk-UA.rc b/reactos/dll/cpl/main/lang/uk-UA.rc index 79c93c9ae2e..ae829ffa281 100644 --- a/reactos/dll/cpl/main/lang/uk-UA.rc +++ b/reactos/dll/cpl/main/lang/uk-UA.rc @@ -61,14 +61,14 @@ FONT 8, "MS Shell Dlg" BEGIN GROUPBOX "Êîíô³ãóðàö³ÿ êíîïîê", -1, 5, 5, 230, 70 CHECKBOX "&Ïîì³íÿòè ïðèçíà÷åííÿ êíîïîê", IDC_SWAP_MOUSE_BUTTONS, 10, 15, 140, 10 - CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_OWNERDRAW, 155, 15, 75, 57, WS_EX_STATICEDGE - LTEXT "Âñòàíîâ³òü öåé ïðàïîðåöü, ùîá ïðèçíà÷èòè ïðàâó êíîïêó äëÿ âèêîíàííÿ òàêèõ îñíîâíèõ ôóíêö³é, ÿê âèá³ð ³ ïåðåòÿãóâàííÿ", -1, 10, 30, 140, 30 + CONTROL "", IDC_IMAGE_SWAP_MOUSE, "Static", SS_ICON | SS_CENTERIMAGE | WS_VISIBLE, 165, 15, 65, 57, WS_EX_STATICEDGE + LTEXT "Âñòàíîâ³òü öåé ïðàïîðåöü, ùîá ïðèçíà÷èòè ïðàâó êíîïêó äëÿ âèêîíàííÿ òàêèõ îñíîâíèõ ôóíêö³é, ÿê âèá³ð ³ ïåðåòÿãóâàííÿ", -1, 10, 30, 150, 30 GROUPBOX "Øâèäê³ñòü ïîäâ³éíîãî êëàöàííÿ", -1, 5, 75, 230, 70 - LTEXT "Çðîá³òü ïîäâ³éíå êëàöàííÿ ïî ïàïö³. ßêùî ïàïêà íå â³äêðèâàºòüñÿ àáî íå çàêðèâàºòüñÿ, âèáåð³òü íèæ÷ó øâèäê³ñòü.", -1, 10, 85, 160, 30 + LTEXT "Çðîá³òü ïîäâ³éíå êëàöàííÿ ïî ïàïö³. ßêùî ïàïêà íå â³äêðèâàºòüñÿ àáî íå çàêðèâàºòüñÿ, âèáåð³òü íèæ÷ó øâèäê³ñòü.", -1, 10, 85, 150, 30 LTEXT "&Øâèäê³ñòü: Íèæ÷å", -1, 10, 120, 90, 8 LTEXT "Âèùå", -1, 140, 120, 30, 8 CONTROL "",IDC_SLIDER_DOUBLE_CLICK_SPEED, "msctls_trackbar32",TBS_AUTOTICKS | WS_TABSTOP, 60, 120, 70, 17 - CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_OWNERDRAW, 165, 85, 65, 57, WS_EX_STATICEDGE + CONTROL "", IDC_IMAGE_DOUBLE_CLICK_SPEED, "Static", SS_ICON | SS_NOTIFY | SS_CENTERIMAGE | WS_VISIBLE, 165, 85, 65, 57, WS_EX_STATICEDGE GROUPBOX "Çàë³ïàí³ÿ", -1, 5, 150, 230, 70 CHECKBOX "&³âìêíóòè Çàë³ïàí³ÿ", IDC_CHECK_CLICK_LOCK, 10, 160, 70, 20 PUSHBUTTON "&Ïàðàìåòðè...", IDC_BUTTON_CLICK_LOCK, 170, 160, 50, 10 diff --git a/reactos/dll/cpl/main/main.rc b/reactos/dll/cpl/main/main.rc index 7d6265943ef..06353d24dea 100644 --- a/reactos/dll/cpl/main/main.rc +++ b/reactos/dll/cpl/main/main.rc @@ -3,14 +3,36 @@ #include #include "resource.h" + +/* define language neutral resources */ + +LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL + #define REACTOS_VERSION_DLL #define REACTOS_STR_FILE_DESCRIPTION "ReactOS Sample Control Panel\0" #define REACTOS_STR_INTERNAL_NAME "main\0" #define REACTOS_STR_ORIGINAL_FILENAME "main.cpl\0" #include - IDC_CPLICON_1 ICON "resources/mouse.ico" IDC_CPLICON_2 ICON "resources/keyboard.ico" +IDI_FOLDER_OPEN ICON "resources/folder_open.ico" +IDI_FOLDER_CLOSED ICON "resources/folder_closed.ico" +IDI_MOUSE_LEFT ICON "resources/mouse_left.ico" +IDI_MOUSE_RIGHT ICON "resources/mouse_right.ico" -#include "rsrc.rc" + +/* include localised resources */ + +#include "lang/cs-CZ.rc" +#include "lang/de-DE.rc" +#include "lang/en-US.rc" +#include "lang/es-ES.rc" +#include "lang/fr-FR.rc" +#include "lang/hu-HU.rc" +#include "lang/id-ID.rc" +#include "lang/it-IT.rc" +#include "lang/ja-JP.rc" +#include "lang/nl-NL.rc" +#include "lang/ru-RU.rc" +#include "lang/uk-UA.rc" diff --git a/reactos/dll/cpl/main/mouse.c b/reactos/dll/cpl/main/mouse.c index de7208b2301..5cc43992117 100644 --- a/reactos/dll/cpl/main/mouse.c +++ b/reactos/dll/cpl/main/mouse.c @@ -1,6 +1,6 @@ /* * ReactOS - * Copyright (C) 2004 ReactOS Team + * Copyright (C) 2004, 2007 ReactOS Team * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -27,7 +27,6 @@ //TODO: //detect slider changes - for apply stuff -//implement Double-Click Speed measuring // cursor icon shows - may need overriden items // implement Pointer-APPLY // implement Pointer-Browser @@ -57,15 +56,30 @@ #define MAX_DOUBLE_CLICK_SPEED 900 #define DEFAULT_WHEEL_SCROLL_LINES 3 + +typedef struct _BUTTON_DATA +{ + ULONG g_SwapMouseButtons; + ULONG g_OrigSwapMouseButtons; + ULONG g_DoubleClickSpeed; // = DEFAULT_DOUBLE_CLICK_SPEED; + ULONG g_OrigDoubleClickSpeed; + BOOL g_ClickLockEnabled; // = 0; + DWORD g_ClickLockTime; // = DEFAULT_CLICK_LOCK_TIME; + + HICON hButtonLeft; + HICON hButtonRight; + + HICON hIcon1; + HICON hIcon2; + BOOL bClicked; +} BUTTON_DATA, *PBUTTON_DATA; + + ULONG g_Initialized = 0; UINT g_WheelScrollLines = 5; -ULONG g_SwapMouseButtons = 0; -ULONG g_DoubleClickSpeed = DEFAULT_DOUBLE_CLICK_SPEED; -BOOL g_ClickLockEnabled = 0; BOOL g_DropShadow = 0; -DWORD g_ClickLockTime = DEFAULT_CLICK_LOCK_TIME; ULONG g_MouseSensitivity = DEFAULT_MOUSE_SENSITIVITY; ULONG g_MouseSpeed = 1; ULONG g_MouseThreshold1 = DEFAULT_MOUSE_THRESHOLD1; @@ -96,12 +110,13 @@ TCHAR g_szHand[MAX_PATH]; TCHAR g_szNewScheme[MAX_PATH]; + /* Property page dialog callback */ static INT_PTR CALLBACK MouseHardwareProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { GUID Guids[1]; Guids[0] = GUID_DEVCLASS_MOUSE; @@ -112,21 +127,20 @@ MouseHardwareProc(IN HWND hwndDlg, switch(uMsg) { case WM_INITDIALOG: - { /* create the hardware page */ DeviceCreateHardwarePageEx(hwndDlg, Guids, sizeof(Guids) / sizeof(Guids[0]), HWPD_STANDARDLIST); break; - } } return FALSE; } -BOOL InitializeMouse() +static BOOL +InitializeMouse(VOID) { /* mouse trails */ SystemParametersInfo(SPI_GETMOUSETRAILS, 0, &g_MouseTrails, 0); @@ -147,12 +161,6 @@ BOOL InitializeMouse() /* hide pointer while typing */ SystemParametersInfo(SPI_GETMOUSEVANISH, 0, &g_HidePointer, 0); - /* click lock time */ - SystemParametersInfo(SPI_GETMOUSECLICKLOCK, 0, &g_ClickLockEnabled, 0); - SystemParametersInfo(SPI_GETMOUSECLICKLOCKTIME, 0, &g_ClickLockTime, 0); - - g_DoubleClickSpeed = GetDoubleClickTime(); - g_SwapMouseButtons = GetSystemMetrics(SM_SWAPBUTTON); /* show pointer with Ctrl-Key */ @@ -163,184 +171,235 @@ BOOL InitializeMouse() static INT_PTR CALLBACK ClickLockProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { HWND hDlgCtrl; int pos; - UNREFERENCED_PARAMETER(lParam); + + PBUTTON_DATA pButtonData; + + pButtonData = (PBUTTON_DATA)GetWindowLongPtr(hwndDlg, DWLP_USER); switch(uMsg) { case WM_INITDIALOG: - { + pButtonData = (PBUTTON_DATA)lParam; + SetWindowLongPtr(hwndDlg, DWLP_USER, (LONG_PTR)pButtonData); + hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_CLICK_LOCK); SendMessage(hDlgCtrl, TBM_SETRANGE, (WPARAM)TRUE, (LPARAM)MAKELONG(0, 10)); - pos = (g_ClickLockTime-200) / 200; + pos = (pButtonData->g_ClickLockTime - 200) / 200; SendMessage(hDlgCtrl, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)pos); return TRUE; - } + case WM_COMMAND: - { if (LOWORD(wParam) == IDOK) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_CLICK_LOCK); - g_ClickLockTime = (DWORD) (SendMessage(hDlgCtrl, TBM_GETPOS, 0, 0) * 200) + 200; + pButtonData->g_ClickLockTime = (DWORD) (SendMessage(hDlgCtrl, TBM_GETPOS, 0, 0) * 200) + 200; EndDialog(hwndDlg, TRUE); } else if (LOWORD(wParam) == IDCANCEL) { EndDialog(hwndDlg, FALSE); } - } + break; } return FALSE; } + static INT_PTR CALLBACK ButtonProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { HWND hDlgCtrl; LRESULT lResult; - float pos; LPPSHNOTIFY lppsn; - switch(uMsg) + PBUTTON_DATA pButtonData; + + pButtonData = (PBUTTON_DATA)GetWindowLongPtr(hwndDlg, DWLP_USER); + + switch (uMsg) { case WM_INITDIALOG: - { - if (InitializeMouse()) + pButtonData = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(BUTTON_DATA)); + SetWindowLongPtr(hwndDlg, DWLP_USER, (LONG_PTR)pButtonData); + + pButtonData->g_SwapMouseButtons = GetSystemMetrics(SM_SWAPBUTTON); + pButtonData->g_OrigSwapMouseButtons = pButtonData->g_SwapMouseButtons; + pButtonData->g_DoubleClickSpeed = GetDoubleClickTime(); + pButtonData->g_OrigDoubleClickSpeed = pButtonData->g_DoubleClickSpeed; + + /* Click lock time */ + SystemParametersInfo(SPI_GETMOUSECLICKLOCK, 0, &pButtonData->g_ClickLockEnabled, 0); + SystemParametersInfo(SPI_GETMOUSECLICKLOCKTIME, 0, &pButtonData->g_ClickLockTime, 0); + + /* Load mouse button icons */ + pButtonData->hButtonLeft = LoadImage(hApplet, MAKEINTRESOURCE(IDI_MOUSE_LEFT), IMAGE_ICON, 48, 48, LR_DEFAULTCOLOR); + pButtonData->hButtonRight = LoadImage(hApplet, MAKEINTRESOURCE(IDI_MOUSE_RIGHT), IMAGE_ICON, 48, 48, LR_DEFAULTCOLOR); + + /* Load folder icons */ + pButtonData->hIcon1 = LoadImage(hApplet, MAKEINTRESOURCE(IDI_FOLDER_CLOSED), IMAGE_ICON, 48, 48, LR_DEFAULTCOLOR); + pButtonData->hIcon2 = LoadImage(hApplet, MAKEINTRESOURCE(IDI_FOLDER_OPEN), IMAGE_ICON, 48, 48, LR_DEFAULTCOLOR); + + if (pButtonData->g_SwapMouseButtons) { - if (g_SwapMouseButtons) - { - hDlgCtrl = GetDlgItem(hwndDlg, IDC_SWAP_MOUSE_BUTTONS); - SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); - } - if (g_ClickLockEnabled) - { - hDlgCtrl = GetDlgItem(hwndDlg, IDC_CHECK_CLICK_LOCK); - SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); - } - else - { - hDlgCtrl = GetDlgItem(hwndDlg, IDC_BUTTON_CLICK_LOCK); - EnableWindow(hDlgCtrl, FALSE); - } - hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_DOUBLE_CLICK_SPEED); - SendMessage(hDlgCtrl, TBM_SETRANGE, (WPARAM)TRUE, (LPARAM)MAKELONG(0, 14)); - pos = ((float)g_DoubleClickSpeed / MAX_DOUBLE_CLICK_SPEED); - pos /= (1.0f/11.0f); - SendMessage(hDlgCtrl, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)(INT)ceil(pos)); - - + SendDlgItemMessage(hwndDlg, IDC_SWAP_MOUSE_BUTTONS, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); + SendDlgItemMessage(hwndDlg, IDC_IMAGE_SWAP_MOUSE, STM_SETIMAGE, IMAGE_ICON, (LPARAM)pButtonData->hButtonRight); } + else + { + SendDlgItemMessage(hwndDlg, IDC_IMAGE_SWAP_MOUSE, STM_SETIMAGE, IMAGE_ICON, (LPARAM)pButtonData->hButtonLeft); + } + + if (pButtonData->g_ClickLockEnabled) + { + hDlgCtrl = GetDlgItem(hwndDlg, IDC_CHECK_CLICK_LOCK); + SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); + } + else + { + hDlgCtrl = GetDlgItem(hwndDlg, IDC_BUTTON_CLICK_LOCK); + EnableWindow(hDlgCtrl, FALSE); + } + + hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_DOUBLE_CLICK_SPEED); + SendMessage(hDlgCtrl, TBM_SETRANGE, (WPARAM)TRUE, (LPARAM)MAKELONG(0, 14)); + SendMessage(hDlgCtrl, TBM_SETPOS, (WPARAM)TRUE, 14 - ((pButtonData->g_DoubleClickSpeed - 200) / 50)); + + + SendDlgItemMessage(hwndDlg, IDC_IMAGE_DOUBLE_CLICK_SPEED, STM_SETIMAGE, IMAGE_ICON, (LPARAM)pButtonData->hIcon1); + pButtonData->bClicked = TRUE; return TRUE; - } + + case WM_DESTROY: + DestroyIcon(pButtonData->hButtonLeft); + DestroyIcon(pButtonData->hButtonRight); + DestroyIcon(pButtonData->hIcon1); + DestroyIcon(pButtonData->hIcon2); + HeapFree(GetProcessHeap(), 0, pButtonData); + break; + case WM_COMMAND: - { switch(LOWORD(wParam)) { case IDC_SWAP_MOUSE_BUTTONS: - { lResult = SendMessage((HWND)lParam, BM_GETCHECK, (WPARAM)0, (LPARAM)0); if (lResult == BST_CHECKED) { - g_SwapMouseButtons = FALSE; + pButtonData->g_SwapMouseButtons = FALSE; SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_UNCHECKED, (LPARAM)0); + SendDlgItemMessage(hwndDlg, IDC_IMAGE_SWAP_MOUSE, STM_SETIMAGE, IMAGE_ICON, (LPARAM)pButtonData->hButtonLeft); } else if (lResult == BST_UNCHECKED) { - g_SwapMouseButtons = TRUE; + pButtonData->g_SwapMouseButtons = TRUE; SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); + SendDlgItemMessage(hwndDlg, IDC_IMAGE_SWAP_MOUSE, STM_SETIMAGE, IMAGE_ICON, (LPARAM)pButtonData->hButtonRight); } + SystemParametersInfo(SPI_SETMOUSEBUTTONSWAP, pButtonData->g_SwapMouseButtons, NULL, SPIF_SENDCHANGE); + PropSheet_Changed(GetParent(hwndDlg), hwndDlg); break; - } + case IDC_CHECK_CLICK_LOCK: - { lResult = SendMessage((HWND)lParam, BM_GETCHECK, (WPARAM)0, (LPARAM)0); hDlgCtrl = GetDlgItem(hwndDlg, IDC_BUTTON_CLICK_LOCK); if (lResult == BST_CHECKED) { SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_UNCHECKED, (LPARAM)0); - g_ClickLockEnabled = FALSE; + pButtonData->g_ClickLockEnabled = FALSE; EnableWindow(hDlgCtrl, FALSE); } else if (lResult == BST_UNCHECKED) { SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); EnableWindow(hDlgCtrl, TRUE); - g_ClickLockEnabled = TRUE; + pButtonData->g_ClickLockEnabled = TRUE; + } + PropSheet_Changed(GetParent(hwndDlg), hwndDlg); + break; + + case IDC_BUTTON_CLICK_LOCK: + DialogBoxParam(hApplet, MAKEINTRESOURCE(IDD_CLICK_LOCK), hwndDlg, ClickLockProc, (LPARAM)pButtonData); + break; + + case IDC_IMAGE_DOUBLE_CLICK_SPEED: + if (HIWORD(wParam) == STN_DBLCLK) + { + pButtonData->bClicked = !pButtonData->bClicked; + SendDlgItemMessage(hwndDlg, IDC_IMAGE_DOUBLE_CLICK_SPEED, STM_SETIMAGE, IMAGE_ICON, + (LPARAM)(pButtonData->bClicked ? pButtonData->hIcon1 : pButtonData->hIcon2)); } break; - } - case IDC_BUTTON_CLICK_LOCK: - { - lResult = DialogBox(hApplet, MAKEINTRESOURCE(IDD_CLICK_LOCK), hwndDlg, ClickLockProc); - if ((INT)lResult == FALSE) - return FALSE; // no need to enable apply button - break; - } } - PropSheet_Changed(GetParent(hwndDlg), hwndDlg); break; - } + case WM_NOTIFY: - { - lppsn = (LPPSHNOTIFY) lParam; + lppsn = (LPPSHNOTIFY) lParam; if (lppsn->hdr.code == PSN_APPLY) { - /* apply swap mouse button */ - SystemParametersInfo(SPI_SETMOUSEBUTTONSWAP, g_SwapMouseButtons, NULL, SPIF_SENDCHANGE); - - /* apply double click speed */ - hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_DOUBLE_CLICK_SPEED); - lResult = SendMessage(hDlgCtrl, TBM_GETPOS, 0, 0); - g_DoubleClickSpeed = (INT)lResult * 50 + 200; - SystemParametersInfo(SPI_SETDOUBLECLICKTIME, g_DoubleClickSpeed, NULL, SPIF_SENDCHANGE); - #if (WINVER >= 0x0500) - SystemParametersInfo(SPI_SETMOUSECLICKLOCK, g_ClickLockEnabled, NULL, SPIF_SENDCHANGE); - if (g_ClickLockEnabled) - SystemParametersInfo(SPI_SETMOUSECLICKLOCKTIME, g_ClickLockTime, NULL, SPIF_SENDCHANGE); -#endif + SystemParametersInfo(SPI_SETMOUSECLICKLOCK, pButtonData->g_ClickLockEnabled, NULL, SPIF_SENDCHANGE); + if (pButtonData->g_ClickLockEnabled) + SystemParametersInfo(SPI_SETMOUSECLICKLOCKTIME, pButtonData->g_ClickLockTime, NULL, SPIF_SENDCHANGE); +#endif SetWindowLong(hwndDlg, DWL_MSGRESULT, PSNRET_NOERROR); - return TRUE; } + else if (lppsn->hdr.code == PSN_RESET) + { + /* Reset swap mouse button setting */ + SystemParametersInfo(SPI_SETMOUSEBUTTONSWAP, pButtonData->g_OrigSwapMouseButtons, NULL, SPIF_SENDCHANGE); - } - case WM_DRAWITEM: - { - LPDRAWITEMSTRUCT drawItem; - drawItem = (LPDRAWITEMSTRUCT)lParam; - if(drawItem->CtlID == IDC_IMAGE_SWAP_MOUSE) - { - //FIXME - //show mouse with left/right button highlighted - // depending on val g_SwapMouseButtons - return TRUE; + /* Reset double click speed setting */ +// SystemParametersInfo(SPI_SETDOUBLECLICKTIME, pButtonData->g_OrigDoubleClickSpeed, NULL, SPIF_SENDCHANGE); + SetDoubleClickTime(pButtonData->g_OrigDoubleClickSpeed); } - else if (drawItem->CtlID == IDC_IMAGE_DOUBLE_CLICK_SPEED) - { - //FIXME - //measure click speed && draw item - } - break; - } + return TRUE; + case WM_HSCROLL: - { - PropSheet_Changed(GetParent(hwndDlg), hwndDlg); + if ((HWND)lParam == GetDlgItem(hwndDlg, IDC_SLIDER_DOUBLE_CLICK_SPEED)) + { + switch (LOWORD(wParam)) + { + case TB_LINEUP: + case TB_LINEDOWN: + case TB_PAGEUP: + case TB_PAGEDOWN: + case TB_TOP: + case TB_BOTTOM: + case TB_ENDTRACK: + lResult = SendDlgItemMessage(hwndDlg, IDC_SLIDER_DOUBLE_CLICK_SPEED, TBM_GETPOS, 0, 0); + pButtonData->g_DoubleClickSpeed = (14 - (INT)lResult) * 50 + 200; +// SystemParametersInfo(SPI_SETDOUBLECLICKTIME, pButtonData->g_DoubleClickSpeed, NULL, SPIF_SENDCHANGE); + SetDoubleClickTime(pButtonData->g_DoubleClickSpeed); + PropSheet_Changed(GetParent(hwndDlg), hwndDlg); + break; + + case TB_THUMBTRACK: + pButtonData->g_DoubleClickSpeed = (14 - (INT)HIWORD(wParam)) * 50 + 200; +// SystemParametersInfo(SPI_SETDOUBLECLICKTIME, pButtonData->g_DoubleClickSpeed, NULL, SPIF_SENDCHANGE); + SetDoubleClickTime(pButtonData->g_DoubleClickSpeed); + PropSheet_Changed(GetParent(hwndDlg), hwndDlg); + break; + } + } break; - } } + return FALSE; } -BOOL ReadActiveCursorScheme() + +#if 0 +static BOOL +ReadActiveCursorScheme(VOID) { HKEY hCuKey; HKEY hCuCursorKey; @@ -359,7 +418,7 @@ BOOL ReadActiveCursorScheme() RegCloseKey(hCuKey); return FALSE; } - + memset(g_szArrow, 0x0, sizeof(g_szArrow)); memset(g_szHelp, 0x0, sizeof(g_szHelp)); memset(g_szAppStarting, 0x0, sizeof(g_szAppStarting)); @@ -377,12 +436,11 @@ BOOL ReadActiveCursorScheme() memset(g_szHand, 0x0, sizeof(g_szHand)); dwIndex = 0; - do + for (;;) { dwValueName = sizeof(szValueName) / sizeof(TCHAR); dwValueData = sizeof(szValueData) / sizeof(TCHAR); dwResult = RegEnumValue(hCuCursorKey, dwIndex, szValueName, &dwValueName, NULL, NULL, (LPBYTE)szValueData, &dwValueData); - if (dwResult == ERROR_NO_MORE_ITEMS) break; @@ -418,15 +476,18 @@ BOOL ReadActiveCursorScheme() _tcsncpy(g_szHand, szValueData, MAX_PATH); dwIndex++; - }while(1); + } RegCloseKey(hCuCursorKey); RegCloseKey(hCuKey); - + return TRUE; } +#endif -BOOL EnumerateCursorSchemes(HWND hwndDlg) + +static BOOL +EnumerateCursorSchemes(HWND hwndDlg) { HKEY hCuKey; HKEY hCuCursorKey; @@ -442,9 +503,8 @@ BOOL EnumerateCursorSchemes(HWND hwndDlg) BOOL ProcessedHKLM = FALSE; if (RegOpenCurrentUser(KEY_READ, &hCuKey) != ERROR_SUCCESS) - { return FALSE; - } + if (RegOpenKeyEx(hCuKey, _T("Control Panel\\Cursors\\Schemes"), 0, KEY_READ, &hCuCursorKey) != ERROR_SUCCESS) { RegCloseKey(hCuKey); @@ -455,12 +515,12 @@ BOOL EnumerateCursorSchemes(HWND hwndDlg) SendMessage(hDlgCtrl, CB_RESETCONTENT, 0, 0); dwIndex = 0; - do + for (;;) { dwValueName = sizeof(szValueName) / sizeof(TCHAR); dwValueData = sizeof(szValueData) / sizeof(TCHAR); dwResult = RegEnumValue(hCuCursorKey, dwIndex, szValueName, &dwValueName, NULL, NULL, (LPBYTE)szValueData, &dwValueData); - + if (dwResult == ERROR_NO_MORE_ITEMS) { if(!ProcessedHKLM) @@ -479,30 +539,36 @@ BOOL EnumerateCursorSchemes(HWND hwndDlg) } break; } + if(_tcslen(szValueData) > 0) { TCHAR * copy = _tcsdup(szValueData); if (ProcessedHKLM) + { + _tcscat(szValueName, TEXT(" ")); _tcscat(szValueName, szSystemScheme); - lResult = SendMessage(hDlgCtrl, CB_ADDSTRING, (WPARAM)0, (LPARAM)szValueName); - SendMessage(hDlgCtrl, CB_SETITEMDATA, (WPARAM)lResult, (LPARAM)copy); + } + lResult = SendMessage(hDlgCtrl, CB_ADDSTRING, (WPARAM)0, (LPARAM)szValueName); + SendMessage(hDlgCtrl, CB_SETITEMDATA, (WPARAM)lResult, (LPARAM)copy); } dwIndex++; - }while(1); + } RegCloseKey(hCuCursorKey); RegCloseKey(hCuKey); LoadString(hApplet, IDS_NONE, szSystemScheme, MAX_PATH); - SendMessage(hDlgCtrl, CB_ADDSTRING, (WPARAM)0, (LPARAM)szSystemScheme); + lResult = SendMessage(hDlgCtrl, CB_ADDSTRING, (WPARAM)0, (LPARAM)szSystemScheme); + SendMessage(hDlgCtrl, CB_SETITEMDATA, (WPARAM)lResult, (LPARAM)NULL); SendMessage(hDlgCtrl, CB_SETCURSEL, (WPARAM)0, (LPARAM)0); return TRUE; } -void RefreshCursorList(HWND hwndDlg) +static VOID +RefreshCursorList(HWND hwndDlg) { TCHAR szCursorName[MAX_PATH]; HWND hDlgCtrl; @@ -517,12 +583,11 @@ void RefreshCursorList(HWND hwndDlg) column.mask = LVCF_SUBITEM | LVCF_WIDTH; column.iSubItem = 0; column.cx = 200; - + (void)ListView_InsertColumn(hDlgCtrl, 0, &column); - LoadString(hApplet, IDS_ARROW, szCursorName, MAX_PATH); - + ZeroMemory(&listItem, sizeof(LV_ITEM)); listItem.mask = LVIF_TEXT | LVIF_PARAM | LVIF_STATE | LVIF_IMAGE; listItem.pszText = szCursorName; @@ -534,7 +599,7 @@ void RefreshCursorList(HWND hwndDlg) (void)ListView_InsertItem(hDlgCtrl, &listItem); LoadString(hApplet, IDS_HELP, szCursorName, MAX_PATH); - listItem.iItem = index++; + listItem.iItem = index++; (void)ListView_InsertItem(hDlgCtrl, &listItem); LoadString(hApplet, IDS_APPSTARTING, szCursorName, MAX_PATH); @@ -587,32 +652,37 @@ void RefreshCursorList(HWND hwndDlg) (void)ListView_InsertItem(hDlgCtrl, &listItem); } -BOOL DeleteUserCursorScheme(TCHAR * szScheme) + +static BOOL +DeleteUserCursorScheme(TCHAR * szScheme) { HKEY hCuKey; HKEY hCuCursorKey; LONG Result; + if (RegOpenCurrentUser(KEY_READ | KEY_SET_VALUE, &hCuKey) != ERROR_SUCCESS) - { return FALSE; - } + if (RegOpenKeyEx(hCuKey, _T("Control Panel\\Cursors\\Schemes"), 0, KEY_READ | KEY_SET_VALUE, &hCuCursorKey) != ERROR_SUCCESS) { RegCloseKey(hCuKey); return FALSE; } + Result = RegDeleteValue(hCuCursorKey, szScheme); RegCloseKey(hCuCursorKey); RegCloseKey(hCuKey); + return (Result == ERROR_SUCCESS); } + static INT_PTR CALLBACK SaveSchemeProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { HWND hDlgCtrl; UNREFERENCED_PARAMETER(lParam); @@ -620,7 +690,6 @@ SaveSchemeProc(IN HWND hwndDlg, switch(uMsg) { case WM_COMMAND: - { if (LOWORD(wParam) == IDOK) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_EDIT_SCHEME_NAME); @@ -631,13 +700,15 @@ SaveSchemeProc(IN HWND hwndDlg, { EndDialog(hwndDlg, FALSE); } - } + break; } return FALSE; } -BOOL BrowseCursor(TCHAR * szFileName, HWND hwndDlg) + +static BOOL +BrowseCursor(TCHAR * szFileName, HWND hwndDlg) { //FIXME load text resources from string OPENFILENAME ofn; @@ -662,11 +733,100 @@ BOOL BrowseCursor(TCHAR * szFileName, HWND hwndDlg) } +static VOID +LoadCurrentCursorScheme(LPTSTR lpName, BOOL bSystem) +{ + HKEY hCursorKey; + TCHAR szValue[2048]; + TCHAR szRaw[256]; + DWORD dwValueLen; + LONG lError; + LPTSTR ptrStart, ptrEnd; + INT_PTR len; + int i; + + if (lpName == NULL) + { + memset(g_szArrow, 0x0, sizeof(g_szArrow)); + memset(g_szHelp, 0x0, sizeof(g_szHelp)); + memset(g_szAppStarting, 0x0, sizeof(g_szAppStarting)); + memset(g_szWait, 0x0, sizeof(g_szWait)); + memset(g_szCrosshair, 0x0, sizeof(g_szCrosshair)); + memset(g_szIBeam, 0x0, sizeof(g_szIBeam)); + memset(g_szNWPen, 0x0, sizeof(g_szNWPen)); + memset(g_szNo, 0x0, sizeof(g_szNo)); + memset(g_szSizeNS, 0x0, sizeof(g_szSizeNS)); + memset(g_szSizeWE, 0x0, sizeof(g_szSizeWE)); + memset(g_szSizeNWSE, 0x0, sizeof(g_szSizeNWSE)); + memset(g_szSizeNESW, 0x0, sizeof(g_szSizeNESW)); + memset(g_szSizeAll, 0x0, sizeof(g_szSizeAll)); + memset(g_szUpArrow, 0x0, sizeof(g_szUpArrow)); + memset(g_szHand, 0x0, sizeof(g_szHand)); + } + else + { + if (bSystem) + { + if (RegOpenKeyEx(HKEY_LOCAL_MACHINE, + _T("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Control Panel\\Cursors\\Schemes"), + 0, KEY_READ, &hCursorKey)) + return; + } + else + { + if (RegOpenKeyEx(HKEY_CURRENT_USER, + _T("Control Panel\\Cursors\\Schemes"), + 0, KEY_READ, &hCursorKey) != ERROR_SUCCESS) + return; + } + + dwValueLen = 2048 * sizeof(TCHAR); + lError = RegQueryValueEx(hCursorKey, lpName, NULL, NULL, (LPBYTE)szValue, &dwValueLen); + + RegCloseKey(hCursorKey); + + if (lError == ERROR_SUCCESS) + { + ptrStart = szValue; + for (i = 0; ; i++) + { + ptrEnd = _tcschr(ptrStart, TEXT(',')); + if (ptrEnd != NULL) + { + len = (ptrEnd - ptrStart) / sizeof(TCHAR); + _tcsncpy(szRaw, ptrStart, len); + szRaw[len] = 0; + } + else + { + _tcscpy(szRaw, ptrStart); + } + + switch (i) + { + case 0: + ExpandEnvironmentStrings(szRaw, g_szArrow, MAX_PATH); + break; + + } + + + + if (ptrEnd == NULL) + break; + + ptrStart = ptrEnd + 1; + } + } + } +} + + static INT_PTR CALLBACK PointerProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { LPPSHNOTIFY lppsn; TCHAR buffer[MAX_PATH]; @@ -679,7 +839,6 @@ PointerProc(IN HWND hwndDlg, switch(uMsg) { case WM_INITDIALOG: - { EnumerateCursorSchemes(hwndDlg); RefreshCursorList(hwndDlg); /* drop shadow */ @@ -693,9 +852,8 @@ PointerProc(IN HWND hwndDlg, return TRUE; else return FALSE; - } + case WM_NOTIFY: - { lppsn = (LPPSHNOTIFY) lParam; if (lppsn->hdr.code == PSN_APPLY) { @@ -706,46 +864,46 @@ PointerProc(IN HWND hwndDlg, return TRUE; } break; - } + case WM_COMMAND: - { switch(HIWORD(wParam)) { case CBN_SELENDOK: { BOOL bEnable; + LPTSTR lpName; + wParam = SendMessage((HWND)lParam, CB_GETCURSEL, 0, 0); if(wParam == CB_ERR) break; SendMessage((HWND)lParam, CB_GETLBTEXT, wParam, (LPARAM)buffer); LoadString(hApplet, IDS_SYSTEM_SCHEME, szSystemScheme, MAX_PATH); if(_tcsstr(buffer, szSystemScheme) || wParam == 0) //avoid the default scheme can be deleted - bEnable = 0; + bEnable = FALSE; else - bEnable = 1; - + bEnable = TRUE; + /* delete button */ hDlgCtrl = GetDlgItem(hwndDlg, IDC_BUTTON_DELETE_SCHEME); EnableWindow(hDlgCtrl, bEnable); - + + lpName = (LPTSTR)SendMessage((HWND)lParam, CB_GETITEMDATA, wParam, 0); + LoadCurrentCursorScheme(lpName, !bEnable); break; } } - switch(LOWORD(wParam)) + switch (LOWORD(wParam)) { case IDC_BUTTON_SAVEAS_SCHEME: - { - if(DialogBox(hApplet, MAKEINTRESOURCE(IDD_CURSOR_SCHEME_SAVEAS), hwndDlg, SaveSchemeProc)) + if (DialogBox(hApplet, MAKEINTRESOURCE(IDD_CURSOR_SCHEME_SAVEAS), hwndDlg, SaveSchemeProc)) { //FIXME - //save cursor scheme - + //save cursor scheme } break; - } + case IDC_BUTTON_USE_DEFAULT_CURSOR: - { hDlgCtrl = GetDlgItem(hwndDlg, IDC_LISTVIEW_CURSOR); lResult = SendMessage(hDlgCtrl, CB_GETCURSEL, 0, 0); if (lResult != CB_ERR) @@ -782,9 +940,8 @@ PointerProc(IN HWND hwndDlg, memset(g_szHand, 0x0, MAX_PATH * sizeof(TCHAR)); } break; - } + case IDC_BUTTON_BROWSE_CURSOR: - { memset(buffer, 0x0, sizeof(buffer)); hDlgCtrl = GetDlgItem(hwndDlg, IDC_LISTVIEW_CURSOR); lResult = SendMessage(hDlgCtrl, CB_GETCURSEL, 0, 0); @@ -792,7 +949,6 @@ PointerProc(IN HWND hwndDlg, MessageBox(hwndDlg, _T("CB_ERR"), _T(""),MB_ICONERROR); if (BrowseCursor(buffer, hwndDlg)) { - if ((INT)lResult == 0) _tcsncpy(g_szArrow, buffer, MAX_PATH); else if ((INT)lResult == 1) @@ -838,9 +994,8 @@ PointerProc(IN HWND hwndDlg, ReleaseDC(hDlgCtrl, memDC); } break; - } + case IDC_BUTTON_DELETE_SCHEME: - { hDlgCtrl = GetDlgItem(hwndDlg, IDC_COMBO_CURSOR_SCHEME); wParam = SendMessage(hDlgCtrl, CB_GETCURSEL, 0, 0); if(wParam == CB_ERR) @@ -852,9 +1007,8 @@ PointerProc(IN HWND hwndDlg, SendMessage(hDlgCtrl, CB_SETCURSEL, (WPARAM)0, (LPARAM)0); } break; - } + case IDC_CHECK_DROP_SHADOW: - { if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_DROP_SHADOW)) { g_DropShadow = 0; @@ -864,22 +1018,20 @@ PointerProc(IN HWND hwndDlg, { g_DropShadow = 1; SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); - } - } + } } break; - } - } return FALSE; } + static INT_PTR CALLBACK OptionProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { HWND hDlgCtrl; LPPSHNOTIFY lppsn; @@ -888,14 +1040,13 @@ OptionProc(IN HWND hwndDlg, switch(uMsg) { case WM_INITDIALOG: - { if (InitializeMouse()) { /* set mouse sensitivity */ hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_MOUSE_SENSITIVITY); SendMessage(hDlgCtrl, TBM_SETRANGE, (WPARAM)TRUE, (LPARAM)MAKELONG(0, 19)); SendMessage(hDlgCtrl, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)g_MouseSensitivity-1); - + if (g_MouseSpeed) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_CHECK_POINTER_PRECISION); @@ -921,23 +1072,19 @@ OptionProc(IN HWND hwndDlg, hDlgCtrl = GetDlgItem(hwndDlg, IDC_CHECK_SHOW_POINTER); SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } - + if (g_HidePointer) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_CHECK_HIDE_POINTER); SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } - } - break; - } + case WM_COMMAND: - { switch(LOWORD(wParam)) { case IDC_CHECK_POINTER_PRECISION: - { if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_POINTER_PRECISION)) { g_MouseSpeed = 0; @@ -953,9 +1100,8 @@ OptionProc(IN HWND hwndDlg, SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } break; - } + case IDC_CHECK_SNAP_TO: - { if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_SNAP_TO)) { g_SnapToDefaultButton = 0; @@ -967,9 +1113,8 @@ OptionProc(IN HWND hwndDlg, SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } break; - } + case IDC_CHECK_POINTER_TRAIL: - { hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_POINTER_TRAIL); if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_POINTER_TRAIL)) { @@ -983,10 +1128,9 @@ OptionProc(IN HWND hwndDlg, EnableWindow(hDlgCtrl, TRUE); g_MouseTrails = (ULONG) SendMessage(hDlgCtrl, TBM_GETPOS, 0, 0) + 2; } - break; - } + break; + case IDC_CHECK_SHOW_POINTER: - { if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_SHOW_POINTER)) { g_ShowPointer = 0; @@ -998,9 +1142,8 @@ OptionProc(IN HWND hwndDlg, SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } break; - } + case IDC_CHECK_HIDE_POINTER: - { if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_HIDE_POINTER)) { g_HidePointer = 0; @@ -1012,27 +1155,27 @@ OptionProc(IN HWND hwndDlg, SendMessage((HWND)lParam, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } break; - } } PropSheet_Changed(GetParent(hwndDlg), hwndDlg); break; - } + case WM_NOTIFY: - { lppsn = (LPPSHNOTIFY) lParam; if (lppsn->hdr.code == PSN_APPLY) { /* set snap to default button */ SystemParametersInfo(SPI_SETSNAPTODEFBUTTON, g_SnapToDefaultButton, 0, SPIF_SENDCHANGE); - + /* set mouse trails */ if(IsDlgButtonChecked(hwndDlg, IDC_CHECK_POINTER_TRAIL)) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_POINTER_TRAIL); lResult = SendMessage(hDlgCtrl, TBM_GETPOS, 0, 0); } - else + else + { lResult = 0; + } SystemParametersInfo(SPI_SETMOUSETRAILS, (UINT) lResult, 0, SPIF_SENDCHANGE); @@ -1044,7 +1187,6 @@ OptionProc(IN HWND hwndDlg, hDlgCtrl = GetDlgItem(hwndDlg, IDC_SLIDER_MOUSE_SENSITIVITY); lResult = SendMessage(hDlgCtrl, TBM_GETPOS, 0, 0) + 1; SystemParametersInfo(SPI_SETMOUSESPEED, 0, (PVOID)g_MouseSensitivity, SPIF_SENDCHANGE); - /* hide pointer while typing */ SystemParametersInfo(SPI_SETMOUSEVANISH, 0, (PVOID)g_HidePointer, SPIF_SENDCHANGE); @@ -1055,17 +1197,18 @@ OptionProc(IN HWND hwndDlg, return TRUE; } break; - } + case WM_HSCROLL: - { PropSheet_Changed(GetParent(hwndDlg), hwndDlg); break; - } } + return FALSE; } -static void ShowDialogWheelControls(HWND hwndDlg) + +static VOID +ShowDialogWheelControls(HWND hwndDlg) { HWND hDlgCtrl; @@ -1073,7 +1216,7 @@ static void ShowDialogWheelControls(HWND hwndDlg) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_RADIO_WHEEL_SCROLL_LINES); SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); - + hDlgCtrl = GetDlgItem(hwndDlg, IDC_EDIT_WHEEL_SCROLL_LINES); EnableWindow(hDlgCtrl, TRUE); @@ -1097,25 +1240,24 @@ static void ShowDialogWheelControls(HWND hwndDlg) hDlgCtrl = GetDlgItem(hwndDlg, IDC_RADIO_WHEEL_SCROLL_PAGE); SendMessage(hDlgCtrl, BM_SETCHECK, (WPARAM)BST_CHECKED, (LPARAM)0); } - } + static INT_PTR CALLBACK WheelProc(IN HWND hwndDlg, - IN UINT uMsg, - IN WPARAM wParam, - IN LPARAM lParam) + IN UINT uMsg, + IN WPARAM wParam, + IN LPARAM lParam) { HWND hDlgCtrl; WCHAR buffer[MAX_PATH]; LPPSHNOTIFY lppsn; - switch(uMsg) + switch (uMsg) { case WM_INITDIALOG: - { ShowDialogWheelControls(hwndDlg); - SendMessage(GetDlgItem(hwndDlg, IDC_UPDOWN_WHEEL_SCROLL_LINES), UDM_SETRANGE, 0, MAKELONG ((short) 100, (short) 0)); + SendMessage(GetDlgItem(hwndDlg, IDC_UPDOWN_WHEEL_SCROLL_LINES), UDM_SETRANGE, 0, MAKELONG ((short) 100, (short) 0)); if (g_WheelScrollLines != UINT_MAX) { hDlgCtrl = GetDlgItem(hwndDlg, IDC_EDIT_WHEEL_SCROLL_LINES); @@ -1123,10 +1265,9 @@ WheelProc(IN HWND hwndDlg, SendMessage(hDlgCtrl, WM_SETTEXT, (WPARAM)0, (LPARAM)buffer); } return TRUE; - } + case WM_COMMAND: - { - switch(LOWORD(wParam)) + switch (LOWORD(wParam)) { case IDC_RADIO_WHEEL_SCROLL_LINES: { @@ -1145,9 +1286,8 @@ WheelProc(IN HWND hwndDlg, } PropSheet_Changed(GetParent(hwndDlg), hwndDlg); break; - } + case WM_NOTIFY: - { lppsn = (LPPSHNOTIFY) lParam; if (lppsn->hdr.code == PSN_APPLY) { @@ -1155,18 +1295,17 @@ WheelProc(IN HWND hwndDlg, SendMessageW(hDlgCtrl, WM_GETTEXT, (WPARAM)MAX_PATH, (LPARAM)buffer); g_WheelScrollLines = _wtoi(buffer); SystemParametersInfo(SPI_SETWHEELSCROLLLINES, g_WheelScrollLines, 0, SPIF_SENDCHANGE); - + SetWindowLong(hwndDlg, DWL_MSGRESULT, PSNRET_NOERROR); return TRUE; } - - } - + break; } return FALSE; } + LONG APIENTRY MouseApplet(HWND hwnd, UINT uMsg, LONG lParam1, LONG lParam2) { diff --git a/reactos/dll/cpl/main/resource.h b/reactos/dll/cpl/main/resource.h index b2e5671e47c..8659d0f676f 100644 --- a/reactos/dll/cpl/main/resource.h +++ b/reactos/dll/cpl/main/resource.h @@ -1,10 +1,15 @@ #ifndef __CPL_RESOURCE_H #define __CPL_RESOURCE_H - +/* Icons */ #define IDC_CPLICON_1 100 #define IDC_CPLICON_2 200 +#define IDI_FOLDER_OPEN 201 +#define IDI_FOLDER_CLOSED 202 +#define IDI_MOUSE_LEFT 203 +#define IDI_MOUSE_RIGHT 204 + #define IDD_PAGE_BUTTON 101 #define IDD_PAGE_POINTER 102 #define IDD_PAGE_OPTION 103 diff --git a/reactos/dll/cpl/main/rsrc.rc b/reactos/dll/cpl/main/rsrc.rc deleted file mode 100644 index 02d3904a18d..00000000000 --- a/reactos/dll/cpl/main/rsrc.rc +++ /dev/null @@ -1,24 +0,0 @@ - - -#include -#include -#include "resource.h" - -/* define language neutral resources */ - -LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL - -/* include localised resources */ - -#include "lang/cs-CZ.rc" -#include "lang/de-DE.rc" -#include "lang/en-US.rc" -#include "lang/es-ES.rc" -#include "lang/fr-FR.rc" -#include "lang/hu-HU.rc" -#include "lang/id-ID.rc" -#include "lang/it-IT.rc" -#include "lang/ja-JP.rc" -#include "lang/nl-NL.rc" -#include "lang/ru-RU.rc" -#include "lang/uk-UA.rc"