(转)API在VB中应用之技巧集锦

    
     API函数在VB中得到了充分的运用,同时也让无数VB爱好者沉溺于其中。以下是笔者几年来收集整理的几十个API函数在VB中应用的实例,现在写出来与大伙分享,希望能对大伙有所帮助。
    
     1、如何让窗体总在最前面?
    
     *API函数声明
     Declare Function SetWindowPos Lib "user32" ( ByVal hwnd As Long, ByVal   hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long
     注释:常量声明
     Private Const SWP_NOSIZE = &H1
     Private Const SWP_NOMOVE = &H2
     Private Const HWND_TOPMOST = -1
     Private Const HWND_NOTOPMOST = -2
     注释: 在某个form里写:
     SetWindowPos me.hWnd,WND_TOPMOST,0,0,0,0, SWP_NOMOVE 注释:或下面
     SetWindowPos me.hWnd,WND_TOPMOST,0,0,0,0,  SWP_NOSIZE
    
     2、使用API函数sendmessage,获得光标所在行和列。
    
     Sub getcaretpos(byval  TextHwnd&,LineNo&,ColNo&)
      注释:TextHwnd为TextBox的hWnd属性值,  LineNo为所在行数,ColNo为列数
       dim i&,j&,k& 注释:获取起始位置到光标所在位置字节数         i=SendMessage(TextHwnd,&HB0&,0,0) j=i/2^16 注释:确定所在行      LineNo=SendMessage(TextHwnd,&HC9&,j,0)+1
       注释:确定所在列
       k=SendMessage(TextHwnd,&HBB&,-1,0)
       ColNo=j-k+1
     End sub
    
     3、如何以某种颜色填充某区域?
    
     *API函数声明
     Private Declare Sub FloodFill Lib "gdi32" _ (ByVal hDC As Long, ByVal X As Long, ByVal Y As _ Long, ByVal crColor As Long
     注释:设(fillx,filly)为此区域内任一点
     注释:Color为某种颜色
     FloodFill Picture1.hDC, fillx, filly,Color
    
     4、如何关闭计算机?
     *API函数声明
     Declare Function ExitWindows Lib "User" (ByVal dwReturnCode As Long, ByVal wReserved As Integer) As Integer
     注释:执行
     Dim DUMMY
     DUMMY=ExitWindows(0,0)
    
     5、如何获取Windows目录和System目录?
    
     注释:复制以下代码到一模块中
     Public Declare Function GetWindowsDirectory Lib "kernel32" Alias "GetWindowsDirectoryA" (ByVal lpBuffer As String, ByVal nSize As Long) As Long
     Public Declare Function GetSystemDirectory Lib "kernel32" Alias "GetSystemDirectoryA" (ByVal lpBuffer As String, ByVal nSize As Long) As Long
     注释:在程序中调用
     Dim WindowsDirectory As String, SystemDirectory As String, x As Long
     WindowsDirectory = Space(255)
     SystemDirectory = Space(255)
     x = GetWindowsDirectory(WindowsDirectory, 255)
     x = GetSystemDirectory(SystemDirectory, 255)
     MsgBox "Windows的安装目录是:" + WindowsDirectory+",系统目录是:" + SystemDirectory
    
     6、如何建立简单的超级连接?
    
     *API函数声明
     Private Declare Function ShellExecute Lib "shell32.dll" Alias "ShellExecute A" (ByVal hWnd As Long, ByVal lpOperation As String, ByVal lpFile As String, ByVal lpParameters As String, ByVal lpDirectory As String, ByVal nShowCmd A s Long) As Long
     注释:打开某个网址
     ShellExecute 0, "open", "http://tyvb.126.com", vbNullString, vbNullString, 3
     注释:给某个信箱发电子邮件
     ShellExecute hwnd, "open", "mailto:sst95@21cn.com", vbNullString, vbNullString, 0
    
     7、如何得知TextBox中文字所有的行数?
    
     *API函数声明
     Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
     Public Const EM_GETLINECOUNT = &HBA
     注释:在程序中调用
     LineCnt = SendMessage(ctl.hwnd, EM_GETLINECOUNT, 0, 0)
     注释:LineCnt即为此TextBox的行数。
    
     8、如何设置ListBox的水平卷动轴的宽度?
    
     *API函数声明
     Const LB_SETHORIZONTALEXTENT = &H194
     Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" _ (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, _ lParam As Any) As Long
     注释:调用
     Call SendMessage(List1.hwnd, LB_SETHORIZONTALEXTENT, 400, ByVal 0&)
     注释:注意400是以象素为单位,你可以根据情况自行设定。
    
     9、如何交换鼠标按键?
    
     *API函数声明
     Declare Function SwapMouseButton& Lib "user32" _ (ByVal bSwap as long)
     要交换鼠标按键,将bSwap参数设置为True。要恢复正常设置,将bSwap设置为False。 然后调用函数就可以交换和恢复鼠标按键了。
    
     10、如何让窗体的标题条闪烁以引起用户注意?
    
     在窗体中放一个Timer控件Timer1,设置其Inteval=200
     *API函数声明
     Private Declare Function FlashWindow Lib "user32" (ByVal hwnd As Long, ByVal bInvert As Long) As Long
     注释:在窗体中写下如下代码:
     Private Sub Timer1_Timer()
      FlashWindow Me.hwnd, True
     End Sub
    
     11、怎样找到鼠标指针的XY坐标?
    
     *API函数声明
     Type POINTAPI
     x As Long
     y As Long
     End Type
     Declare Function GetCursorPos Lib "user32" (lpPoint As POINTAPI) As Long
     调用:
     GetCursorPos z
     print z.x
     print z.y
    
    
     12、怎样获得和改变双击鼠标的时间间隔?
    
     获得鼠标双击间隔时间:
     Public Declare Function GetDoubleClickTime Lib "user32" Alias _ "GetDoubleClickTime" () As Long
    
     获得鼠标双击间隔时间:
     Declare Function SetDoubleClickTime Lib "user32" Alias "SetDoubleClickTime" (ByVal wCount As Long) As Long
     注释:注意:这种改变将影响到整个操作系统
    
     以上两个函数都可精确到毫秒级。   
      

 

13、在程序中如何打开和关闭光驱门?
    
     *API函数声明如下:
     Private Declare Function mciSendString Lib "winmm.dll" Alias "mciSendStringA" (ByVal lpstrCommand As String, ByVal lpstrReturnString As String, ByVal uReturnLength As Long, ByVal hwndCallback As Long) As Long
     注释:调用时的代码如下
     Dim Ret As Long
     Dim RetStr As String
     注释:打开光驱门
     Ret = mciSendString("set CDAudio door open", RetStr, 0, 0)
     注释:关闭光驱门
     Ret = mciSendString("set CDAudio door closed", RetStr, 0, 0)
    
    
     14、如何获得Windows启动方式?
    
     在Form1中加入一个CommandButton、一个Label并加入如下代码:
     Private Declare Function GetSystemMetrics Lib "user32" (ByVal nIndex As Long) As Long
     Const SM_CLEANBOOT = 67
    
     Private Sub Command1_Click()
      Select Case GetSystemMetrics(SM_CLEANBOOT)
      Case 1
       Label1 = "安全模式."
      Case 2
       Label1 = "支持网络的安全模式."
      Case Else
       Label1 = "Windows运行在普通模式."
      End Select
     End Sub
    
    
     15、怎样使Ctrl-Alt-Delete无效?
    
     *API函数声明
     Private Declare Function SystemParametersInfo Lib "user32" Alias "SystemParametersInfoA" (ByVal uAction As Long, ByVal uParam As Long, ByVal lpvParam As Any, ByVal fuWinIni As Long) As Long
     编写如下函数:
     Sub DisableCtrlAltDelete(bDisabled As Boolean)
     Dim X As Long
     X = SystemParametersInfo(97, bDisabled, CStr(1), 0)
     End Sub
     使Ctrl-Alt-Delete无效 :
     Call DisableCtrlAltDelete(True)
     恢复Ctrl-Alt-Delete :
     Call DisableCtrlAltDelete(False)
    
    
     16、如何移动没有标题栏的窗口?
    
     我们一般是用鼠标按住窗口的标题栏,然后移动窗口,当窗口没有标题栏时,我们可以用下面的方法来移动窗口:
    
     *API函数声明:
     Declare Function ReleaseCapture Lib "user32" () As Long Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
     Public Const HTCAPTION = 2
     Public Const WM_NCLBUTTONDOWN = &HA1
     在 Form_MouseDown 事件中:
     Private Sub Form_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single)
     ReleaseCapture SendMessage hwnd, WM_NCLBUTTONDOWN, HTCAPTION,0&
     End Sub
    
    
     17、VB中如何使用延时函数?
    
     *API函数声明:
     Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long)
     调用:
     注释:延时1秒
     Call Sleep(1000)
    
    
     18、调用修改屏幕保护口令的窗口:
    
     Private Declare Function PwdChangePassword Lib "mpr" Alias "PwdChangePasswordA" (ByVal lpcRegkeyname As String, ByVal hwnd As Long, ByVal uiReserved1 As Long, ByVal uiReserved2 As Long) As Long
     调用:
     Call PwdChangePassword("SCRSAVE", Me.hwnd, 0, 0)
    
     19、使Windows开始屏幕保护:
     *API函数声明
     Private Declare Function SendMessage Lib "user32"
     Alias "SendMessageA" (ByVal hWnd As Long, ByVal wMsg
     As Long, ByVal wParam As Long, ByVal lParam As Long)
     As Long
     Const WM_SYSCOMMAND = &H112&
     Const SC_SCREENSAVE = &HF140&
     注释:调用
     Dim result As Long
     result = SendMessage(Form1.hWnd, WM_SYSCOMMAND, SC_SCREENSAVE, 0&)
    
    
     20、如何改变Windows桌面背景?
     *API函数声明
     Const SPI_SETDESKWALLPAPER = 20
     Const SPIF_UPDATEINIFILE = &H1
     Declare Function SystemParametersInfo Lib "user32" Alias "SystemParametersInfoA" (ByVal uAction As Long, ByVal uParam As Long, ByVal lpvParam As Any, ByVal fuWinIni As Long) As Long
     注释:调用
     Call SystemParametersInfo(SPI_SETDESKWALLPAPER, 0, "C:windowsClouds.bmp", SPIF_UPDATEINIFILE)
    
    
     21、怎样确定系统是否安装了声卡?
    
     *API函数声明:
     Declare Function waveOutGetNumDevs Lib "winmm.dll" Alias "waveOutGetNumDevs" () As Long
     代码如下:
     Dim i As Integer
     i = waveOutGetNumDevs()
     If i > 0 Then MsgBox "你的系统可以播放声音。", vbInformation, "声卡检测"
     Else
     MsgBox "你的系统不能播放声音。", vbInformation, "声卡检测"
     End If
    
    
     22、如何找到CD-ROM驱动器的盘号?
     下面的函数将检查你计算机所有的驱动器看是否是 CD-ROM,如果是就返回驱动器号,如果没有就返回空字符
     Public Function GetCDROMDrive() As String
      Dim lType As Long,i As Integer,tmpDrive as String,found as Boolean
      On Error GoTo errL
      For i = 0 To 25
       tmpDrive = Chr(65 + i) & ":"
       lType = GetDriveType(tmpDrive) 注释:Win32 API 函数
       If (lType = DRIVE_CDROM) Then 注释:Win32 API 常数
        found = True
        Exit For
       End If
      Next
      If Not found Then tmpDrive = ""
      BI_GetCDROMDrive = tmpDrive
      exit Function
      errL: msgbox error$
     End Function
    
    
     23、如何将文件放入回收站?
    
     **API函数声明
     Public Type SHFILEOPSTRUCT
     hwnd As Long
     wFunc As Long
     pFrom As String
     pTo As String
     fFlags As Integer
     fAnyOperationsAborted As Long
     hNameMappings As Long
     lpszProgressTitle As Long
     End Type
     Public Declare Function SHFileOperation Lib _ "shell32.dll" Alias "SHFileOperationA" (lpFileOp As SHFILEOPSTRUCT) As Long
     Public Const FO_DELETE = &H3
     Public Const FOF_ALLOWUNDO = &H40
     注释:调用
     Dim SHop As SHFILEOPSTRUCT, strFile as string
     With SHop
     .wFunc = FO_DELETE
     .pFrom = strFile + Chr(0)
     .fFlags = FOF_ALLOWUNDO
     End With
    
    
     24、VB中如何使用未安装的字体?
     Declare Function AddFontResource Lib "gdi32" Alias "AddFontResourceA" (ByVal lpFileName As String) As Long
     Declare Function RemoveFontResource Lib "gdi32" Alias "RemoveFontResourceA" (ByVal lpFileName As String) As Long
     增加字体:
     Dim lResult As Long
     lResult = AddFontResource("c:myAppmyFont.ttf")
     删除字体:
     Dim lResult As Long
     lResult = RemoveFontResource("c:myAppmyFont.ttf")

 

├─Example001-悬挂式窗口 ├─Example002-半透明窗口 ├─Example003-椭圆形窗口 ├─Example004-组合圆形窗口 ├─Example005-多边形窗口 ├─Example006-艺术窗口 ├─Example007-字形窗口 ├─Example008-移动没有标题栏的窗口 ├─Example009-窗口背景花纹的实现 ├─Example010-渐变的窗口背景 ├─Example011-让窗口运行在不同的分辨率下 ├─Example012-控件随着窗口大小按比例变化 ├─Example013-在运行显示或隐藏窗口的标题栏 ├─Example014-制作软件封面 ├─Example015-霓虹灯效果文字 ├─Example016-保存窗口设置 ├─Example017-窗口的动画效果 ├─Example018-显示动画光标 ├─Example019-制作工具栏 ├─Example020-Office或IE风格的工具栏 ├─Example021-通过鼠标拖动停靠工具栏 ├─Example022-在VB制作和使用菜单 ├─Example023-设计弹出菜单 ├─Example024-向菜单添加图标 ├─Example025-动态装入菜单项 ├─Example026-动态创建控件 ├─Example027-具有动感的图片按钮 ├─Example029-图像的打印 ├─Example030-利用VB内部机制实现图像格式换 ├─Example031-鼠标绘图 ├─Example032-旋文字效果演示 ├─Example033-用WebBrowse控件显示GIF动画 ├─Example034-肾形图案 ├─Example035-函数图形 ├─Example036-图像的剪切、复制和粘贴 ├─Example037-任意旋图像 ├─Example038-分割图像 ├─Example039-反颜色 ├─Example040-生成各颜色分量的单色图像 ├─Example041-彩色图像换为灰度图像 ├─Example042-图像的锐化 ├─Example043-浮雕效果 ├─Example044-降低图像的分辨率 ├─Example045-图像的放大 ├─Example046-图像的缩小 ├─Example047-淡入淡出效果 ├─Example048-图像的合成 ├─Example049-图像动画 ├─Example050-使用DED ├─Example051-父子关系的Command对象 ├─Example052-在DED使用参数 ├─Example056-查找记录 ├─Example057-动态创建数据库 ├─Example058-复制数据库的结构 ├─Example059-调用COM对象操作数据库 ├─Example060-获得表的索引信息 ├─Example061-换Access数据库为Excel文件 ├─Example062-访问Excel文件 ├─Example063-将Access表数据按一定格式存储到Txt文件 ├─Example064-使用Access报表 ├─Example065-压缩和修复数据库 ├─Example066-设置数据库密码 ├─Example067-修改数据库密码 ├─Example068-使用Stream读写存储的图像 ├─Example069-绘制图表 ├─Example070-保存rtf文件到数据库 ├─Example071-打开对话框 ├─Example072-保存对话框 ├─Example073-字体对话框 ├─Example074-颜色对话框 ├─Example075-输入对话框和消息对话框 ├─Example076-同时打开多个文件并在多个窗口显示 ├─Example077-将文本以列表形式显示 ├─Example078-设置段落缩进 ├─Example079-密码形式的TextBox控件 ├─Example080-能自动选文本的TextBox控件 ├─Example081-确定文本的行数 ├─Example082-自动滚屏功能 ├─Example083-MaskEdBox控件 ├─Example084-对ComboBox的输入进行检查 ├─Example085-ComboBox控件的自动查询技术 ├─Example086-在ListBox控件间移动列表项 ├─Example087-简单的文件浏览器 ├─Example088-使用ListView控件增强文件浏览器 ├─Example089-播放Flash动画 ├─Example090-MMControl控件播放多媒体文件 ├─Example091-判断控件类型 ├─Example092-Line控件 ├─Example093-使用Shape控件 ├─Example094-引入系统监视器 ├─Example095-媒体文件浏览器 ├─Example096-列表播放媒体文件 ├─Example097-在应用程序之间进行拖放操作 ├─Example098-文本文件的拖放操作 ├─Example099-图像和图像文件的拖放 ├─Example100-使用WebBrowser控件浏览网页 ├─Example101-属性 ├─Example102-复制文件(copyfile) ├─Example103-文件夹的创建~删除 ├─Example104-回收站 ├─Example105-清空回收站 ├─Example106-回收站察看器 ├─Example107-获取图标 ├─Example108-获取图标2 ├─Example109-写入读取2进制文件 ├─Example110-写入读取2进制文件2 ├─Example111-写入窗口大小位置 ├─Example112-文件ADD资料 ├─Example113-取驱动器名和信息 ├─Example114-查找文件 ├─Example115-注册表 ├─Example117-WindowText的信息传递 ├─Example118-查找窗口&信息传递 ├─Example119-信息拦截 ├─Example120-CD-ROM开关 ├─Example121-Word ├─Example122-得出(NetBIOS名,DNS主机名) ├─Example123 - IF操作系统 ├─Example124-重新启动 ├─Example125-热键 ├─Example126-系统时间修改(没事最好不要乱动) ├─Example127-注册表 ├─Example128-Detect(不知道是什么) ├─Example129-本地连接的IP ├─Example130-应用程序的超连接 ├─Example131-截取信息 ├─Example132-近文档信息 ├─Example133-Ctrl&V的应用 ├─Example134-鼠标(移动,左键,右键) ├─Example135-注册表&资源应用 ├─Example137-函数(Replace,Split,Join,StrReverse,InStrRev)的使用 ├─Example138-环境变量 ├─Example139-打开文件夹 ├─Example140-设置系统颜色 ├─Example141 - DSN建立 ├─Example142 - 字体 ├─Example143 - Time的计算 ├─Example145 ├─Example146-程序菜单的隐藏&显示 ├─Example147-自定义函数Function用法 ├─Example148-VB对Excel调用 ├─Example149-运行记事本 └─Example150-字符串长度
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值