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

首頁 > 數據庫 > Access > 正文

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

2024-09-07 19:05:28
字體:
來源:轉載
供稿:網友
在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
一个人看的www久久| 日韩欧美在线中文字幕| 国产精品欧美激情在线播放| 亚洲精选在线观看| 精品福利樱桃av导航| 美女视频黄免费的亚洲男人天堂| 日韩中文字幕在线视频| 欧美电影免费观看| 国产脚交av在线一区二区| 国内久久久精品| 精品亚洲一区二区三区四区五区| 欧美巨乳在线观看| 在线观看精品国产视频| 国产97人人超碰caoprom| 欧美性猛交99久久久久99按摩| 欧美日韩国产激情| 午夜精品久久久久久久99热浪潮| 亚洲成av人乱码色午夜| 中文字幕av一区中文字幕天堂| 久久精品国产91精品亚洲| 亚洲欧美日韩国产中文专区| 国内精品免费午夜毛片| 日韩av网站导航| 69影院欧美专区视频| 国产精品久久久久久久7电影| 97久久精品国产| 亚洲一级免费视频| 亚洲人成欧美中文字幕| 日韩视频免费看| 97视频在线观看网址| 久久久免费精品视频| 在线观看久久久久久| 欧美午夜激情在线| 日韩精品小视频| 久久精彩免费视频| 91精品久久久久久久久久| 亚洲国产日韩欧美在线图片| 亚洲美女在线视频| 亚洲精品美女久久久久| 亚洲自拍偷拍色片视频| 欧美成人午夜剧场免费观看| 欧美大胆在线视频| 色与欲影视天天看综合网| 日韩福利伦理影院免费| 久久久精品在线观看| 日韩在线播放视频| 欧洲中文字幕国产精品| 在线中文字幕日韩| 中文在线不卡视频| 国产97在线播放| 日韩免费观看在线观看| 成人免费在线网址| 国产啪精品视频网站| 欧美激情啊啊啊| 国产精品劲爆视频| 日韩av快播网址| 社区色欧美激情 | 日韩免费观看视频| 国产精品视频网| 欧美中文字幕在线视频| 福利一区福利二区微拍刺激| 91精品国产91久久久久福利| 亚洲变态欧美另类捆绑| 精品久久久免费| 亚洲日本欧美中文幕| 国产日本欧美一区二区三区在线| 欧美老少做受xxxx高潮| 亚洲欧洲在线看| 欧美亚洲国产视频小说| 久久久久久久爱| 成人精品一区二区三区| 亚洲国产高清福利视频| 日产日韩在线亚洲欧美| 国产99久久精品一区二区| 久久久国产精品一区| 亚洲区免费影片| 日本国产一区二区三区| 黄色一区二区在线观看| 欧美日韩在线视频一区二区| 91亚洲国产精品| 狠狠躁夜夜躁人人躁婷婷91| 国产成人免费av电影| 亚洲va久久久噜噜噜| 国产色婷婷国产综合在线理论片a| 国产亚洲成av人片在线观看桃| 亚洲国产一区二区三区在线观看| 深夜福利亚洲导航| 欧美久久精品一级黑人c片| 久久夜精品香蕉| 日韩精品免费观看| 国产精品美女av| 不卡av日日日| 一区国产精品视频| 亚洲福利在线播放| 国产美女主播一区| 最近2019中文字幕一页二页| 欧美专区在线视频| 欧美性猛交xxxx乱大交蜜桃| 色综合久久久久久中文网| 日韩美女在线播放| 性欧美视频videos6一9| 中文字幕精品久久久久| 亚州欧美日韩中文视频| 国产精品91久久久久久| 亚洲国产精品成人一区二区| 777午夜精品福利在线观看| 日韩一区二区三区在线播放| 欧美性xxxx极品hd欧美风情| 国产美女直播视频一区| 68精品久久久久久欧美| 久久久久久久久久久av| 日韩久久午夜影院| 国产精品扒开腿做爽爽爽视频| 国产精品久久久久久久一区探花| 欧洲美女7788成人免费视频| 日韩69视频在线观看| 国产精品日韩在线| 成人激情在线观看| 久久久亚洲福利精品午夜| 欧美激情一区二区三区久久久| 欧美性猛交xxxx久久久| 亚洲视频777| 国产91精品高潮白浆喷水| 亚洲二区中文字幕| 国产精品美乳一区二区免费| 中文字幕日韩欧美精品在线观看| 久久久国产在线视频| 国产成人自拍视频在线观看| 日韩在线视频国产| 国产美女精品免费电影| 亚洲精品成人av| 成人免费观看49www在线观看| 91精品国产91久久久久久吃药| 亚洲国产女人aaa毛片在线| 欧美一区二区影院| 日韩电影第一页| 海角国产乱辈乱精品视频| 中文字幕日韩在线视频| 久久国产精品久久久久久久久久| 久久久久久久久久久网站| 日本sm极度另类视频| 成人中文字幕在线观看| 亚洲男人第一av网站| 最近2019免费中文字幕视频三| 中文字幕日韩综合av| 最近2019年好看中文字幕视频| 国产精品视频一区国模私拍| 久久久天堂国产精品女人| 亚洲欧美成人在线| 高清欧美性猛交xxxx| 色七七影院综合| 国产亚洲日本欧美韩国| 久久久视频在线| 国产成人精品久久二区二区91| 欧美精品videosex极品1| 清纯唯美亚洲综合| 久久视频免费在线播放| 国产精品久久久999| 日韩电影免费在线观看| 色妞色视频一区二区三区四区| 欧美激情视频一区二区| 日韩电影中文字幕在线| 不卡av日日日| 亚洲福利视频免费观看|