亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

Access設置數字/大寫指示燈的API函數

2024-09-07 19:03:09
字體:
來源:轉載
供稿:網友
在access中使用sendkeys有時會導致數字或大寫指示燈無故熄滅,故安全的辦法還是使用API函數。
但最好盡量少用sendkeys,因為有時因為鍵誤操作導致錯誤。
作者:Dev Ashish
'******** Code Start ***********
      ' 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 VK_SCROLL = &H91
      Const VK_CAPITAL = &H14
      Const KEYEVENTF_EXTENDEDKEY = &H1
      Const KEYEVENTF_KEYUP = &H2
      Const VER_PLATFORM_WIN32_NT = 2
      Const VER_PLATFORM_WIN32_WINDOWS = 1

Function IsCapsLockOn() As Boolean
        Dim o As OSVERSIONINFO

        o.dwOSVersionInfoSize = Len(o)
        GetVersionEx o
        Dim keys(0 To 255) As Byte
        GetKeyboardState keys(0)
        IsCapsLockOn = keys(VK_CAPITAL)
End Function

Sub ToggleCapsLock()
        Dim o As OSVERSIONINFO

        o.dwOSVersionInfoSize = Len(o)
        GetVersionEx o
        Dim keys(0 To 255) As Byte
        GetKeyboardState keys(0)

        If o.dwPlatformId = VER_PLATFORM_WIN32_WINDOWS Then  '=====Win95
        'Toggle capslock
            keys(VK_CAPITAL) = Abs(Not keys(VK_CAPITAL))
            SetKeyboardState keys(0)
        ElseIf o.dwPlatformId = VER_PLATFORM_WIN32_NT Then   '=====WinNT
          'Simulate Key Press>
            keybd_event VK_CAPITAL, &H45, KEYEVENTF_EXTENDEDKEY Or 0, 0
          'Simulate Key Release
            keybd_event VK_CAPITAL, &H45, KEYEVENTF_EXTENDEDKEY _
               Or KEYEVENTF_KEYUP, 0
        End If
End Sub

Function IsNumLockOn() As Boolean
        Dim o As OSVERSIONINFO
       
        o.dwOSVersionInfoSize = Len(o)
        GetVersionEx o
        Dim keys(0 To 255) As Byte
        GetKeyboardState keys(0)
        IsNumLockOn = keys(VK_NUMLOCK)
End Function

Sub ToggleNumLock()
        Dim o As OSVERSIONINFO
               
        o.dwOSVersionInfoSize = Len(o)
        GetVersionEx o
        Dim keys(0 To 255) As Byte
        GetKeyboardState keys(0)

          If o.dwPlatformId = VER_PLATFORM_WIN32_WINDOWS Then  '=====Win95
                keys(VK_NUMLOCK) = Abs(Not keys(VK_NUMLOCK))
                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 Sub

Function IsScrollLockOn()
        Dim o As OSVERSIONINFO
       
        o.dwOSVersionInfoSize = Len(o)
        GetVersionEx o
        Dim keys(0 To 255) As Byte
        GetKeyboardState keys(0)
        IsScrollLockOn = keys(VK_SCROLL)
End Function

Sub ToggleScrollLock()
        Dim o As OSVERSIONINFO
       
        o.dwOSVersionInfoSize = Len(o)
        GetVersionEx o
        Dim keys(0 To 255) As Byte
        GetKeyboardState keys(0)
        If o.dwPlatformId = VER_PLATFORM_WIN32_WINDOWS Then  '=====Win95
            keys(VK_SCROLL) = Abs(Not keys(VK_SCROLL))
            SetKeyboardState keys(0)
        ElseIf o.dwPlatformId = VER_PLATFORM_WIN32_NT Then   '=====WinNT
            'Simulate Key Press
            keybd_event VK_SCROLL, &H45, KEYEVENTF_EXTENDEDKEY Or 0, 0
            'Simulate Key Release
            keybd_event VK_SCROLL, &H45, KEYEVENTF_EXTENDEDKEY Or KEYEVENTF_KEYUP, 0
        End If
End Sub

Sub mySendKeys(sKeys As String, Optional bWait As Boolean = False)
Dim bNumLockState As Boolean
Dim bCapsLockState As Boolean
Dim bScrollLockState As Boolean
    bNumLockState = IsNumLockOn()
    bCapsLockState = IsCapsLockOn()
    bScrollLockState = IsScrollLockOn()
    SendKeys sKeys, bWait
    If IsNumLockOn() <> bNumLockState Then
        ToggleNumLock
    End If
    If IsCapsLockOn() <> bCapsLockState Then
        ToggleCapsLock
    End If
    If IsScrollLockOn() <> bScrollLockState Then
        ToggleScrollLock
    End If
End Sub

Function fSendKeys(sKeys As String, Optional bWait As Boolean = False)
' Function to make it callable from macros
    mySendKeys sKeys, bWait
End Function
'******** Code End ***********
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久久久久ktv| 九九热在线精品视频| 欧美激情视频播放| 久久亚洲成人精品| 国产成人福利夜色影视| 欧美最近摘花xxxx摘花| 国语自产精品视频在免费| 国产日韩欧美影视| 国产欧美精品日韩精品| 欧美性xxxx18| 欧美大片在线影院| 丝袜美腿精品国产二区| 欧美激情亚洲激情| 亚洲精品欧美一区二区三区| 亚洲加勒比久久88色综合| 中文字幕精品视频| 日韩av网站在线| 久久久免费观看视频| 国产精品丝袜久久久久久高清| zzijzzij亚洲日本成熟少妇| 国产精品欧美一区二区三区奶水| 亚洲欧美一区二区三区四区| 欧美精品情趣视频| 91精品国产高清久久久久久久久| 久久综合久久美利坚合众国| 日韩高清免费观看| 久久偷看各类女兵18女厕嘘嘘| 精品国产老师黑色丝袜高跟鞋| 欧美最顶级丰满的aⅴ艳星| 91午夜理伦私人影院| 97精品国产97久久久久久免费| 久久精品国产69国产精品亚洲| 91精品国产91久久久久久最新| 亚洲国产高清福利视频| 欧美激情va永久在线播放| 一区二区三区在线播放欧美| 亚洲成色www8888| 久久久精品国产亚洲| 国模私拍一区二区三区| 精品福利在线视频| xxxxx91麻豆| 久久久久久av| 日韩av中文字幕在线| 日韩成人久久久| 国产精品九九九| 亚洲精品视频播放| 国产午夜精品全部视频在线播放| 成人97在线观看视频| 国产成人精品在线观看| 日韩av色综合| 91美女福利视频高清| 欧美专区第一页| 久久视频这里只有精品| 一区二区三区动漫| 欧美一区在线直播| 欧美成人免费小视频| 久久久国产91| 国模吧一区二区| 亚洲无限乱码一二三四麻| 亚洲精品一区av在线播放| 成人免费在线网址| 中文字幕日韩在线视频| 91精品国产精品| 亚洲欧美一区二区三区久久| 2019亚洲日韩新视频| 亚州欧美日韩中文视频| 亚洲高清福利视频| 亚洲人成网7777777国产| 亚洲片av在线| 欧美日韩一区二区三区在线免费观看| 日本一区二区在线播放| 国产成人中文字幕| 久久精品国产久精国产一老狼| 欧美国产日韩在线| 欧美日韩精品国产| 亚洲视频专区在线| 日韩成人在线播放| 亚洲国产精品久久久久| 亚洲一区二区三区777| 91精品视频网站| 国产一区私人高清影院| 亚洲视频电影图片偷拍一区| 久久成人这里只有精品| 日韩精品在线免费观看视频| 欧美日韩免费区域视频在线观看| 亚洲国产另类 国产精品国产免费| 日韩禁在线播放| 亚洲一区二区三区视频| 国产性猛交xxxx免费看久久| 国产精品亚洲美女av网站| 91久久综合亚洲鲁鲁五月天| 欧美高清无遮挡| 色综合老司机第九色激情| 国产精品久久久久91| 亚洲国产又黄又爽女人高潮的| 欧美成aaa人片免费看| 自拍亚洲一区欧美另类| 蜜月aⅴ免费一区二区三区| 亚洲娇小xxxx欧美娇小| 激情亚洲一区二区三区四区| 亚洲色图欧美制服丝袜另类第一页| 精品久久国产精品| 色狠狠久久aa北条麻妃| 日韩欧美一区二区三区久久| 精品国产鲁一鲁一区二区张丽| 亚洲a区在线视频| 精品国产一区二区三区在线观看| 国产精品jvid在线观看蜜臀| 97超级碰碰碰| 国产91精品在线播放| 亚洲在线视频福利| 欧美另类xxx| 国产精品日韩在线播放| 亚洲tv在线观看| 成人免费网站在线观看| 九九九热精品免费视频观看网站| 亚洲欧洲日产国码av系列天堂| 亚洲视频自拍偷拍| 久久久久久久久久国产精品| 久久在线免费观看视频| 亚洲自拍偷拍区| 波霸ol色综合久久| 曰本色欧美视频在线| 国产精品久久不能| 欧美理论电影在线播放| 久久激情五月丁香伊人| 亚洲夜晚福利在线观看| 欧美大全免费观看电视剧大泉洋| 久热国产精品视频| 奇米影视亚洲狠狠色| 欧美性猛交xxxx乱大交| 精品久久久久久亚洲国产300| 久久综合伊人77777蜜臀| 中文字幕亚洲在线| 久久国产精品偷| 91精品中文在线| 久久激情视频免费观看| 欧美香蕉大胸在线视频观看| 亚洲欧美国产一区二区三区| 久久99国产精品自在自在app| 欧美一级在线亚洲天堂| 亚洲一区二区三区乱码aⅴ| 欧美激情a在线| 久久久免费av| 91色琪琪电影亚洲精品久久| 911国产网站尤物在线观看| 亚洲国产精品嫩草影院久久| 欧美日韩成人免费| 国产精品欧美日韩一区二区| 奇米影视亚洲狠狠色| 大胆人体色综合| 日韩高清中文字幕| 久久夜精品香蕉| 欧美激情久久久久久| 亚洲精品午夜精品| x99av成人免费| 中文欧美在线视频| 欧美专区福利在线| 国产精品免费久久久| 国产精品扒开腿做爽爽爽男男| 久久影视免费观看| 国产91久久婷婷一区二区| 亚洲福利精品在线| 不卡在线观看电视剧完整版|