2022年API入门教程[归 .pdf
《2022年API入门教程[归 .pdf》由会员分享,可在线阅读,更多相关《2022年API入门教程[归 .pdf(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、API 入门教程作者:百度 VB 吧 吧主 DeaneKing 在网络上见的, 没有了作者, 至于出处更是到处都有啊,不过是篇不错的API 入门级别文章!推荐大家看看什么是 API 返回 首先,有必要向大家讲一讲,什么是API。所谓 API 本来是为C和 C+程序员写的。 API 说来说去,就是一种函数,他们包含在一个附加名为DLL的动态连接库文件中。用标准的定义来讲, API 就是 Windows的 32 位应用程序编程接口,是一系列很复杂的函数,消息和结构,它使编程人员可以用不同类型的编程语言编制出的运行在Windows95和 Windows NT操作系统上的应用程序。可以说,如果你曾经学
2、过VC ,那么 API 对你来说不是什么问题。但是如果你没有学过 VC ,或者你对Windows95的结构体系不熟悉,那么可以说,学习API 将是一件很辛苦的事情。如果你打开WINDOWS 的 SYSTEM 文件夹,你可以发现其中有很多附加名为DLL 的文件。一个DLL中包含的API 函数并不只是一个,数十个,甚至是数百个。我们能都掌握它嘛?回答是否定的不可能掌握。但实际上, 我们真的没必要都掌握,只要重点掌握Windos 系统本身自带的 API 函数就可以了。但,在其中还应当抛开掉同VB本身自有的函数重复的函数。如,VB 的 etAttr命令可以获得文件属性,SetAttr可以设置文件属性。
3、对 API 来讲也有对应的函数GetFileAttributes和 SetFileAttributes,性能都差不多。如此地一算,剩下来的也就5、600 个。是的,也不少。但,我可以敢跟你说,只要你熟悉地掌握100 个,那么你的编程水平比现在高出至少要两倍。尽管人们说VB和 WINDOWS具有密切的关系,但我认为,API 更接近WINDOWS。如果你学会了API,首要的收获便是对WINDOWS 体系结构的认识。这个收获是来自不易的。如果你不依靠API 会怎么样 ?我可以跟你说,绝大多是高级编程书本( 当然这不是书的名程叫高级而高级的, 而是在一开始的本书内容 中指明 本书的阅读对象是具有一定V
4、B基础的读者的那些书) ,首先提的问题一般大都是从API 开始。因此可以说,你不学API,你大概将停留在初级水平,无法往上攀登。唯一的途径也许就是向别人求救我快死了,快来救救我呀,这个怎么办,那个怎么办?烦不烦呢 ?当然,现在网上好人太多( 包括我在内,嘻嘻) ,但,你应当明白,通过此途径,你的手中出不了好的作品。这是因为缺乏这些知识你的脑子里根本行不成一种总体的设计构思。API 文本游览器 返回 很 多API函 数 都 是 很 长 很 长 的 。 想 看 什 么 样 子 吗 ? 如 下 就 是 作 为 例 子 的API DdeClientTransaction函数Declare Functi
5、on DdeClientTransaction Lib user32 (pData As Byte, ByVal cbData As Long, ByVal hConv As Long, ByVal hszItem As Long, ByVal wFmt As Long, ByVal wType 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 14 页 - - - - - - - - - As Long, ByVal dwTimeout As Long, pdwResul
6、t As Long) As Long 哇!这么长 ?如果你从来没有接触过API,我想你肯定被吓住了。你也许考虑,该不该继续学下去。不过不要担心, 幸运的是 Microsoft的设计家们为我们提供了有用的工具,这便是 API 文本查看器。通过 API 文本查看器,我们可以方便地查找程序所需要的函数声明、结构类型和常数,然后将它复制到剪贴板,最后再粘贴到VB程序的代码段中。在大多数情况下,只要我们确定了程序所需要的函数、结构和常数这三个方面后,就可以通过对API 文本游览器的以上操作将他们加入到程序段中,从而程序中可以使用这些函数了。这些是学习API 最基本的常识问题,它远远占不到API 的庞大的
7、体系内容。今后我们把精力浪费( 这绝不是浪费) 在哪里呢 ?那就是什么时候使用什么函数,什么时候使用什么结构类型,什么时候使用什么常数。API 函数声明 返回 让我们回想一下。在VB中,如何声明函数呢?我想,如果你正在看此文,那么你绝对能够回答得出这个问题。以下便是你应该很熟悉的函数声明Function SetFocus (ByVal hwnd As Long) As Long 即,这行代码定义了名为SetFocus 的函数 , 此函数具有一个Long 型数据类型的参数,并按值传递 (ByVal),函数执行后将返回一个Long 型数据。- 2 API 入门教程 API 函数的声明也很类似,如,
8、API 中的 SetFocus 函数是这样写的Declare Function SetFocus Lib user32 Alias SetFocus (ByVal hwnd As Long) As Long 有点复杂了一些。是的,是复杂了点。但我可以告诉你,除了这些多出来的部分,其他部分还是和你以前学到的东西是一样的。函数在程序中的调用也是一样。如: Dim dl As Long dl&=SetFoucs(Form1.Hwnd) 但,一点是清楚的。它不象你自己写的程序那样能够看到里面的运行机理,也不像VB 自带的函数那样,能够从VB的联机帮助中查到其用法。唯一的方法就是去学、查VB以外的资料。
9、Declare 语句用于在模块级别中声明对动态链接库 (DLL) 中外部过程的引用。对此,你只要记住任何API 函数声明都必须写这个语句就可以了。Iib 指明包含所声明过程或函数的动态链接库或代码资源。也就是说,它说明的是,函数或过程从何而来的问题。如在上例中,SetFocus Lib user32说明函数 SetFocus 来自 user32.dll文件。主要的dll动态连接库文件有user32.dll Windows管理。生成和管理应用程序的用户接口。GDI32.dll 图形设备接口。产生Windows 设备的图形输出名师资料总结 - - -精品资料欢迎下载 - - - - - - - -
10、 - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 14 页 - - - - - - - - - Kernel32.dll 系统服务。访问操作系统的计算机资源。注意,当DLL文件不在Windows或 System 文件夹中的时候,必须在函数中说明其出处( 路径 ) 。如, SetFocus Lib c:Mydlluser32 函数声明中的Alias 是可选的。表示将被调用的过程在动态链接库 (DLL) 中还有另外的名称( 别名 ) 。 如,Alias SetFocus ,说明 SetFocus 函数在 User32.dll中的另外一个名称是,Se
11、tFocus 。怎么两个名都一样呢?当然,也可以是不同的。在很多情况下,Alias说明的函数名,即别名最后一个字符经常是字符A,如 SetWindowsText 函数的另一个名称是SetWindowsTextA, 表示为Alias SetWindowsTextA。这个 A 只不过是设计家们的习惯的命名约定,表示函数属于ANSI版本。那么,别名究竟有什么用途呢?从理论上讲,别名提供了用另一个名子调用API 的函数方法。如果你指明了别名,那么尽管我们按Declare 语句后面的函数来调用该函数,但在函数的实际调用上是以别名作为首要选择的。如,以下两个函数 (Function,ABCD)声明都是有效
12、的,他们调用的是同一个 SetFocus函数Declare Function SetFocus Lib user32 SetFocus (ByVal hwnd As Long) As Long Declare ABCD SetFocus Lib user32 Alias SetFocus (ByVal hwnd As Long) As Long 需要注意的是,选用Alias的时候,应注意别名的大小写;如果不选用Alias 时的时候,函数名必须注意大小写,而且不能改动。当然,在很多情况下,由于函数声明是直接从API 文本游览器中拷贝过来的,所以这种错误的发生机会是很少的,但您有必要知道这一点。最
13、后提醒你一句,API声明 ( 包括结构、常数) 必须放在窗体或模块的 通用 (General Declarations)段。数据类型与 类型安全 返回 API 函数中使用的数据类型基本上和VB中的一样。但作为 WIN32的 API 函数中,不存在 Integer 数据类型。 另外一点是在API 函数中看不到Boolean 数据类型。 Variant数据类型在API 函数中是以Any 的形式出现,如Data As Any。尽管其含义是允许任意参数类型作为一个该API函数的参数传递,但这样做存在一定的缺点。其原因是,这将会使得对目标参数的所有类型检查都会被关闭。这自然会给各种类型的参数调用带来了产
14、生错误的机会。为了强制执行严格的类型检查,并避免上面提到的问题,一个办法是在函数里使用上面提到到 Alias技术。如对API 函数 GetDIBits 可进行另外一种声明方法。如下GetDIBits函数的原型Public Declare Function GetDIBits Lib gdi32 Alias GetDIBits (ByVal aHDC As Long, ByVal hBitmap As Long, ByVal nStartScan As Long, ByVal nNumScans As Long, lpBits As Any, lpBI As BITMAPINFO, ByVal
15、wUsage As Long) As Long - 3 API 入门教程 GetDIBits函数的改型Public Declare Function GetDIBitsLong Lib gdi32 Alias GetDIBits (ByVal aHDC As 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 14 页 - - - - - - - - - Long, ByVal hBitmap As Long, ByVal nStartScan As Long, ByVal
16、nNumScans As Long, lpBits As Long, lpBI As BITMAPINFO, ByVal wUsage As Long) As Long 通过本课程前面所学到的知识,我们已经可以得知原型 GetDIBits函数也好,改型GetDIBitsLong函数也好,实际将调用的都是Alias所指定的 GetDIBits原函数。但你应当看到,两者的区别在于,我们在改型的函数中强制指定lpBits参数为 Long 形。这样就会使得函数调用中发生的错误机率减少到了最小。这种方法叫做安全类型 声明。API 函数中经常看到的数据类型有Long,String,Byte,Any.(也就
17、这些吧。) 常 数 返回 对于 API 常数来讲,没有什么太特别的学问。请看VB中的以下代码Msg = MsgBox( 您好 , vbOKCancel) 我们知道, vbOKCancel 这个常数的值等于1。对上面的代码我们完全可以这样写,而不会影响代码的功能Msg = MsgBox( 您好 , 1) 但你大概不太愿意选择后一种,因为这会使得看懂代码费劲起来。这种方法也被API 采取了。只是 API 常数必须在事情之前做好初始化声明VB本身是看不懂的。其内容仍然来自与API 文本游览器。具体形式如下等等Public Const ABM_ACTIVATE = &H6 Public Const R
18、IGHT_CTRL_PRESSED = &H4 Public Const RPC_E_SERVER_DIED = &H80010007 Private Const RPC_S_CALL_FAILED_DNE = 1727& 在常数的初始化中,有些程序使用Global ,如 Global Const ABM_ACTIVATE = &H6 ,但我认为 Public完全可以代替它。过去我也用过Global ,但现在不大用了。一会儿用这个,一会儿用那个,各程序之间不能保持一致性了,起码看起来别扭。结 构 返回 结构是 C和 C+ 语言中的说法。在 VB中一般称为自定义数据类型。想必很多朋友都已经认识它
19、。在 API 领域里,我更喜欢把它叫做结构,因为API 各种结构类型根本不是我定义( 自定义 ) 的。在 VB中, API 结构同样由TYPE.END TYPE语句来定义。如,在API 中,点 (Point)结构的定义方法如下: Public Type POINTAPI X As Long 点在 X坐标 ( 横坐标 ) 上的坐标值Y As Long 点在 Y坐标 ( 纵坐标 ) 上的坐标值End Type 又如, API 中矩形 (Rect) 结构的定义如下Public Type RECT Left As Long 矩形左上角的X坐标Top As Long 矩形左上角的Y坐标名师资料总结 -
20、- -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 14 页 - - - - - - - - - Right As Long 矩形右下角的X坐标Bottom As Long 矩形右下角的Y坐标End Type 这些内容同样可以从API 文本游览器中拷贝过来。这些结构中的变量名可随意改动,而不会影响结构本身。也就是说,这些成员变量都是虚拟的。如,POINTAPI结构可改为如下Public Type POINTAPI MyX As Long 点在 X坐标 ( 横坐标 ) 上的坐标值MyY As L
21、ong 点在 Y坐标 ( 纵坐标 ) 上的坐标值End Type 不过,一般来讲,是没有这种必要的。结构本身是一种数据类型,因此,使用时必须声明具体变量为该结构型,才能在程序中真正使用到该结构。结构的声明方法和其他数据的声明方法一样,如,以下语句把变MyPoint 声明为 POINTAPI结构类型MyPoint As POINTAPI 引用结构中的成员变量也十分简单,在结构名后面加上一个, 然后紧接着写要引用的成员变量即可。这很象 VB中的引用一个对象的某个属性。如, 假如我们把上面已经声明的MyPoint结构中的X变量的值赋给变量Temp& 则代码如下Temp&=MyPoint.X 但,特别
22、注意的是,你千万不要认为上例中的MyPoint 是一个值。它不是值,而是地址( 指针 ) 。值和地址是完全不同的概念。结构要求按引用传递给WINDOWS函数,即所有API 函数中,结构都是按ByRef 传递的 ( 在 Declare语句 中 ByRef 是默认型 ) 。对于结构的传递,你不要试图采用ByVal ,你将一无所获。由于结构名实际上就是指向这个结构的指针( 这个结构的首地址 ) ,所以,你也就传送特定的结构名就可以了( 参见小结,我用红色字体来突出了这种传递方式)。- 4 API 入门教程由于结构传送的是指针,所以函数将直接对结构进行读写操作。这种特性很适合于把函数执行的结果装载在结
23、构之中。小 结 返回 以下的程序是为了总结本课中学到的内容而给出的。启动VB ,新建一个项目,添加一个命令按钮,并把下面的代码拷贝到代码段中,运行它。Private Declare Function GetCursorPos Lib user32 (lpPoint As POINTAPI) As Long Private Type POINTAPI 定义点 (Point)结构X As Long 点在 X坐标 ( 横坐标 ) 上的坐标值Y As Long 点在 Y坐标 ( 纵坐标 ) 上的坐标值End Type 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - -
24、 - - - - - - - 名师精心整理 - - - - - - - 第 5 页,共 14 页 - - - - - - - - - Sub PrintCursorPos( ) Dim dl AS Long Dim MyPoint As POINTAPI dl&= GetCursorPos(MyPoint) 调用函数,获取屏幕鼠标坐标Debug.Print X= & Str(MyPoint.X) & and & Y= & Str(MyPoint.Y) End Sub Private Sub Command1_Click() PrintCursorPos End Sub 输出结果为 ( 每次运行
25、都可能得到不同的结果,这得由函数调用时鼠标指针在屏幕中所处的位置而决定 ) X= 240 and Y= 151 程序中, GetCursorPos 函数用来获取鼠标指针在屏幕上的位置。以上例子中,你可以发现,以参数传递的MyPpint 结构的内容在函数调用后发生了实质性变化。这是由于结构是按ByRef 传递的原因。一些 API 函数集 返回 Windows API 1. 控件与消息函数AdjustWindowRect 给定一种窗口样式,计算获得目标客户区矩形所需的窗口大小AnyPopup 判断屏幕上是否存在任何弹出式窗口ArrangeIconicWindows 排列一个父窗口的最小化子窗口At
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年API入门教程归 2022 API 入门教程
限制150内