Symphysodon
Gebruiker
- Lid geworden
- 14 dec 2012
- Berichten
- 468
Beste forummers,
Ik wist niet zeker of ik een nieuwe topic moest openen, omdat hierover al een vraag is gepost. De vraag is hetzelfde de oorzaak is anders. Zoals het advies gegeven, gebruik ik geen send keys, maar krijg toch hetzelfde probleem: Na het openen van het bestand wordt de Numlock uitgeschakeld en de "." werkt niet meer als decimaal scheidingsteken. Ik gebruik de volgende code bij het openen van het bestand:
Ik wist niet zeker of ik een nieuwe topic moest openen, omdat hierover al een vraag is gepost. De vraag is hetzelfde de oorzaak is anders. Zoals het advies gegeven, gebruik ik geen send keys, maar krijg toch hetzelfde probleem: Na het openen van het bestand wordt de Numlock uitgeschakeld en de "." werkt niet meer als decimaal scheidingsteken. Ik gebruik de volgende code bij het openen van het bestand:
Code:
' Declare Type for API call:
Private Type OSVERSIONINFO
dwOSVersionInfoSize As Long
dwMajorVersion As Long
dwMinorVersion As Long
dwBuildNumber As Long
dwPlatformId As Long
szCSDVersion As String * 128 ' Maintenance string for PSS usage
End Type
' API declarations:
Private Declare Function GetVersionEx Lib "kernel32" _
Alias "GetVersionExA" _
(lpVersionInformation As OSVERSIONINFO) As Long
Private Declare Sub keybd_event Lib "user32" _
(ByVal bVk As Byte, _
ByVal bScan As Byte, _
ByVal dwFlags As Long, ByVal dwExtraInfo As Long)
Private Declare Function GetKeyboardState Lib "user32" _
(pbKeyState As Byte) As Long
Private Declare Function SetKeyboardState Lib "user32" _
(lppbKeyState As Byte) As Long
' Constant declarations:
Const VK_NUMLOCK = &H90
Const KEYEVENTF_EXTENDEDKEY = &H1
Const KEYEVENTF_KEYUP = &H2
Const VER_PLATFORM_WIN32_NT = 2
Const VER_PLATFORM_WIN32_WINDOWS = 1
Private Sub Workbook_Open()
Dim o As OSVERSIONINFO
Dim NumLockState As Boolean
landeninstellingen
Application.DecimalSeparator = "."
Application.ThousandsSeparator = ","
Application.UseSystemSeparators = True
'Kruisje deactiveren
ExcelSluitenUitschakelen
o.dwOSVersionInfoSize = Len(o)
GetVersionEx o
Dim keys(0 To 255) As Byte
GetKeyboardState keys(0)
' NumLock handling:
NumLockState = keys(VK_NUMLOCK)
If NumLockState <> True Then 'Turn numlock on
If o.dwPlatformId = VER_PLATFORM_WIN32_WINDOWS Then '=== Win95/98
keys(VK_NUMLOCK) = 1
SetKeyboardState keys(0)
ElseIf o.dwPlatformId = VER_PLATFORM_WIN32_NT Then '=== WinNT
'Simulate Key Press
keybd_event VK_NUMLOCK, &H45, KEYEVENTF_EXTENDEDKEY Or 0, 0
'Simulate Key Release
keybd_event VK_NUMLOCK, &H45, KEYEVENTF_EXTENDEDKEY _
Or KEYEVENTF_KEYUP, 0
End If
End If
Interaction.DDEExecute "^{f1}", True
Application.DisplayFullScreen = True
ActiveWindow.DisplayHeadings = False
Application.DisplayFormulaBar = False
End Sub