﻿<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/"><channel><title>C++博客-Thinking in C++-文章分类-Win32</title><link>http://www.cppblog.com/yishanhante/category/3731.html</link><description /><language>zh-cn</language><lastBuildDate>Fri, 23 May 2008 13:57:55 GMT</lastBuildDate><pubDate>Fri, 23 May 2008 13:57:55 GMT</pubDate><ttl>60</ttl><item><title>regsvr32.exe使用详解</title><link>http://www.cppblog.com/yishanhante/articles/19620.html</link><dc:creator>jay</dc:creator><author>jay</author><pubDate>Mon, 12 Mar 2007 04:17:00 GMT</pubDate><guid>http://www.cppblog.com/yishanhante/articles/19620.html</guid><wfw:comment>http://www.cppblog.com/yishanhante/comments/19620.html</wfw:comment><comments>http://www.cppblog.com/yishanhante/articles/19620.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/yishanhante/comments/commentRss/19620.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/yishanhante/services/trackbacks/19620.html</trackback:ping><description><![CDATA[
		<div>使用过activex的人都知道，activex不注册是不能够被系统识别和使用的，一般安装程序都会自动地把它所使用的activex控件注册，但如果你拿到的一个控件需要手动注册怎么办呢？如果修改注册表那就太麻烦了，在windows的system文件夹下有一个regsvr32.exe的程序，它就是windows自带的activex注册和反注册工具。<br /><br />2000系统的regsvr32.exe在winnt\system32文件夹下；<br />WInXP系统的regsvr32.exe在windows\system32文件夹下<br /><br />regsvr32的用法为：<br />"regsvr32 [/s] [/n] [/i(:cmdline)] dllname”。其中dllname为activex控件文件名，建议在安装前拷贝到system文件夹下。<br /><br />参数有如下意义：<br />/u——反注册控件<br />/s——不管注册成功与否，均不显示提示框<br />/c——控制台输出<br />/i——跳过控件的选项进行安装(与注册不同)<br />/n——不注册控件，此选项必须与/i选项一起使用<br /><br />执行该命令的方法：<br /><br />1、可以在“开始”--“运行”，调出运行的对话框，也可以使用Win+R热键，然后直接在输入栏输入即可<br />2、在开始--运行输入cmd，调出‘命令提示符’窗口，然后再执行regsvr32命令。<br /><br />二、Regsvr32错误消息的说明<br />当使用 Regsvr32.exe 时，它会尝试加载该组件并调用它的 DLLSelfRegister 函数。如果此尝试成功，Regsvr32.exe 会显示一个指示成功的对话框。如果此尝试失败，Regsvr32.exe 会返回一条错误消息，其中可能会包括一个 Win32 错误代码。<br /><br />以下列表介绍了 RegSvr32 错误消息和可能的原因。<br /><br />Unrecognized flag:/invalid_flag<br />键入的标志或开关组合无效（请参阅本文中的“Regsvr32.exe 的用法”一节）。<br />No DLL name specified.<br />未包括 .dll 文件名（请参阅本文中的“Regsvr32.exe 的用法”一节）。<br />Dllname was loaded, but the DllRegisterServer or DllUnregisterServer entry point was not found.<br />Dllname不是.dll 或.ocx 文件。例如，键入 regsvr32 wjview.exe 就会生成该错误消息。<br /><br />例如，键入regsvr32 icwdial.dll 后就会返回该错误消息，因为 Icwdial.dll 文件不能自行注册。如果您怀疑内存中有损坏的Dllname 版本，请尝试重新启动计算机，或重新提取该文件的原始版本。如果您运行的是 Windows NT，可能需要使用 Microsoft Windows NT Server 4.0 资源工具包中的 Kill 或 Pview 工具。有关其他信息，请单击以查看以下 Microsoft 知识库文章：197155 如何终止孤立进程OleInitialize failed (or OleUninitialize failed).<br /><br />Regsvr32 必须先初始化 COM 库，然后才能调用所需的 COM 库函数并在关闭时撤消对该库的初始化。<br /><br />一、轻松修复IE浏览器<br />regsvr32 Shdocvw.dll<br />regsvr32 Oleaut32.dll<br />regsvr32 Actxprxy.dll<br />regsvr32 Mshtml.dll<br />regsvr32 Urlmon.dll<br />regsvr32 browseui.dll<br /><br />作用：<br />1、同时运行以上命令不仅可以解决IE不能打开新的窗口，用鼠标点击超链接也没有任何反应的问题；<br />2、还能解决大大小小的其它IE问题，比如网页显示不完整，JAVA效果不出现，网页不自动跳转，打开某些网站时总提示‘无法显示该页’等。<br /></div>
<img src ="http://www.cppblog.com/yishanhante/aggbug/19620.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/yishanhante/" target="_blank">jay</a> 2007-03-12 12:17 <a href="http://www.cppblog.com/yishanhante/articles/19620.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>Windows API函数大全</title><link>http://www.cppblog.com/yishanhante/articles/19547.html</link><dc:creator>jay</dc:creator><author>jay</author><pubDate>Sat, 10 Mar 2007 09:57:00 GMT</pubDate><guid>http://www.cppblog.com/yishanhante/articles/19547.html</guid><wfw:comment>http://www.cppblog.com/yishanhante/comments/19547.html</wfw:comment><comments>http://www.cppblog.com/yishanhante/articles/19547.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/yishanhante/comments/commentRss/19547.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/yishanhante/services/trackbacks/19547.html</trackback:ping><description><![CDATA[
		<p>1. API之网络函数 <br />WNetAddConnection 创建同一个网络资源的永久性连接 <br />WNetAddConnection2 创建同一个网络资源的连接 <br />WNetAddConnection3 创建同一个网络资源的连接 <br />WNetCancelConnection 结束一个网络连接 <br />WNetCancelConnection2 结束一个网络连接 <br />WNetCloseEnum 结束一次枚举操作 <br />WNetConnectionDialog 启动一个标准对话框，以便建立同网络资源的连接 <br />WNetDisconnectDialog 启动一个标准对话框，以便断开同网络资源的连接 <br />WNetEnumResource 枚举网络资源 <br />WNetGetConnection 获取本地或已连接的一个资源的网络名称 <br />WNetGetLastError 获取网络错误的扩展错误信息 <br />WNetGetUniversalName 获取网络中一个文件的远程名称以及/或者UNC（统一命名规范）名称 <br />WNetGetUser 获取一个网络资源用以连接的名字 <br />WNetOpenEnum 启动对网络资源进行枚举的过程 </p>
		<p>2. API之消息函数 <br />BroadcastSystemMessage 将一条系统消息广播给系统中所有的顶级窗口 <br />GetMessagePos 取得消息队列中上一条消息处理完毕时的鼠标指针屏幕位置 <br />GetMessageTime 取得消息队列中上一条消息处理完毕时的时间 <br />PostMessage 将一条消息投递到指定窗口的消息队列 <br />PostThreadMessage 将一条消息投递给应用程序 <br />RegisterWindowMessage 获取分配给一个字串标识符的消息编号 <br />ReplyMessage 答复一个消息 <br />SendMessage 调用一个窗口的窗口函数，将一条消息发给那个窗口 <br />SendMessageCallback 将一条消息发给窗口 <br />SendMessageTimeout 向窗口发送一条消息 <br />SendNotifyMessage 向窗口发送一条消息 <br />3. API之文件处理函数 <br />CloseHandle 关闭一个内核对象。其中包括文件、文件映射、进程、线程、安全和同步对象等 <br />CompareFileTime 对比两个文件的时间 <br />CopyFile 复制文件 <br />CreateDirectory 创建一个新目录 <br />CreateFile 打开和创建文件、管道、邮槽、通信服务、设备以及控制台 <br />CreateFileMapping 创建一个新的文件映射对象 <br />DeleteFile 删除指定文件 <br />DeviceIoControl 对设备执行指定的操作 <br />DosDateTimeToFileTime 将DOS日期和时间值转换成一个 win32 FILETIME 值 <br />FileTimeToDosDateTime 将一个 win32 FILETIME 值转换成DOS日期和时间值 <br />FileTimeToLocalFileTime 将一个FILETIME结构转换成本地时间 <br />FileTimeToSystemTime 根据一个FILETIME结构的内容，装载一个SYSTEMTIME结构 <br />FindClose 关闭由FindFirstFile函数创建的一个搜索句柄 <br />FindFirstFile 根据文件名查找文件 <br />FindNextFile 根据调用FindFirstFile函数时指定的一个文件名查找下一个文件 <br />FlushFileBuffers 针对指定的文件句柄，刷新内部文件缓冲区 <br />FlushViewOfFile 将写入文件映射缓冲区的所有数据都刷新到磁盘 <br />GetBinaryType 判断文件是否可以执行 <br />GetCompressedFileSize 判断一个压缩文件在磁盘上实际占据的字节数 <br />GetCurrentDirectory 在一个缓冲区中装载当前目录 <br />GetDiskFreeSpace 获取与一个磁盘的组织有关的信息，以及了解剩余空间的容量 <br />GetDiskFreeSpaceEx 获取与一个磁盘的组织以及剩余空间容量有关的信息 <br />GetDriveType 判断一个磁盘驱动器的类型 <br />GetExpandedName 取得一个压缩文件的全名 <br />GetFileAttributes 判断指定文件的属性 <br />GetFileInformationByHandle 这个函数提供了获取文件信息的一种机制 <br />GetFileSize 判断文件长度 <br />GetFileTime 取得指定文件的时间信息 <br />GetFileType 在给出文件句柄的前提下，判断文件类型 <br />GetFileVersionInfo 从支持版本标记的一个模块里获取文件版本信息 <br />GetFileVersionInfoSize 针对包含了版本资源的一个文件，判断容纳文件版本信息需要一个多大的缓冲区 <br />GetFullPathName 获取指定文件的完整路径名 <br />GetLogicalDrives 判断系统中存在哪些逻辑驱动器字母 <br />GetLogicalDriveStrings 获取一个字串，其中包含了当前所有逻辑驱动器的根驱动器路径 <br />GetOverlappedResult 判断一个重叠操作当前的状态 <br />GetPrivateProfileInt 为初始化文件（.ini文件）中指定的条目获取一个整数值 <br />GetPrivateProfileSection 获取指定小节（在.ini文件中）所有项名和值的一个列表 <br />GetPrivateProfileString 为初始化文件中指定的条目取得字串 <br />GetProfileInt 取得win.ini初始化文件中指定条目的一个整数值 <br />GetProfileSection 获取指定小节（在win.ini文件中）所有项名和值的一个列表 <br />GetProfileString 为win.ini初始化文件中指定的条目取得字串 <br />GetShortPathName 获取指定文件的短路径名 <br />GetSystemDirectory 取得Windows系统目录（即System目录）的完整路径名 <br />GetTempFileName 这个函数包含了一个临时文件的名字，它可由应用程序使用 <br />GetTempPath 获取为临时文件指定的路径 <br />GetVolumeInformation 获取与一个磁盘卷有关的信息 <br />GetWindowsDirectory 获取Windows目录的完整路径名 <br />hread 参考lread <br />hwrite 参考lwrite函数 <br />lclose 关闭指定的文件 <br />lcreat 创建一个文件 <br />llseek 设置文件中进行读写的当前位置 <br />LockFile 锁定文件的某一部分，使其不与其他应用程序共享 <br />LockFileEx 与LockFile相似，只是它提供了更多的功能 <br />lopen 以二进制模式打开指定的文件 <br />lread 将文件中的数据读入内存缓冲区 <br />lwrite 将数据从内存缓冲区写入一个文件 <br />LZClose 关闭由LZOpenFile 或 LZInit函数打开的一个文件 <br />LZCopy 复制一个文件 <br />LZInit 这个函数用于初始化内部缓冲区 <br />LZOpenFile 该函数能执行大量不同的文件处理，而且兼容于压缩文件 <br />LZRead 将数据从文件读入内存缓冲区 <br />LZSeek 设置一个文件中进行读写的当前位置 <br />MapViewOfFile 将一个文件映射对象映射到当前应用程序的地址空间 <br />MoveFile 移动文件 <br />OpenFile 这个函数能执行大量不同的文件操作 <br />OpenFileMapping 打开一个现成的文件映射对象 <br />QueryDosDevice 在Windows NT中，DOS设备名会映射成NT系统设备名。该函数可判断当前的设备映射情况 <br />ReadFile 从文件中读出数据 <br />ReadFileEx 与ReadFile相似，只是它只能用于异步读操作，并包含了一个完整的回调 <br />RegCloseKey 关闭系统注册表中的一个项（或键） <br />RegConnectRegistry 访问远程系统的部分注册表 <br />RegCreateKey 在指定的项下创建或打开一个项 <br />RegCreateKeyEx 在指定项下创建新项的更复杂的方式。在Win32环境中建议使用这个函数 <br />RegDeleteKey 删除现有项下方一个指定的子项 <br />RegDeleteValue 删除指定项下方的一个值 <br />RegEnumKey 枚举指定项的子项。在Win32环境中应使用RegEnumKeyEx <br />RegEnumKeyEx 枚举指定项下方的子项 <br />RegEnumValue 枚举指定项的值 <br />RegFlushKey 将对项和它的子项作出的改动实际写入磁盘 <br />RegGetKeySecurity 获取与一个注册表项有关的安全信息 <br />RegLoadKey 从以前用RegSaveKey函数创建的一个文件里装载注册表信息 <br />RegNotifyChangeKeyValue 注册表项或它的任何一个子项发生变化时，用这个函数提供一种通知机制 <br />RegOpenKey 打开一个现有的注册表项 <br />RegOpenKeyEx 打开一个现有的项。在win32下推荐使用这个函数 <br />RegQueryInfoKey 获取与一个项有关的信息 <br />RegQueryValue 取得指定项或子项的默认（未命名）值 <br />RegQueryValueEx 获取一个项的设置值 <br />RegReplaceKey 用一个磁盘文件保存的信息替换注册表信息；并创建一个备份，在其中包含当前注册表信息 <br />RegRestoreKey 从一个磁盘文件恢复注册表信息 <br />RegSaveKey 将一个项以及它的所有子项都保存到一个磁盘文件 <br />RegSetKeySecurity 设置指定项的安全特性 <br />RegSetValue 设置指定项或子项的默认值 <br />RegSetValueEx 设置指定项的值 <br />RegUnLoadKey 卸载指定的项以及它的所有子项 <br />RemoveDirectory 删除指定目录 <br />SearchPath 查找指定文件 <br />SetCurrentDirectory 设置当前目录 <br />SetEndOfFile 针对一个打开的文件，将当前文件位置设为文件末尾 <br />SetFileAttributes 设置文件属性 <br />SetFilePointer 在一个文件中设置当前的读写位置 <br />SetFileTime 设置文件的创建、访问及上次修改时间 <br />SetHandleCount 这个函数不必在win32下使用；即使使用，也不会有任何效果 <br />SetVolumeLabel 设置一个磁盘的卷标（Label） <br />SystemTimeToFileTime 根据一个FILETIME结构的内容，载入一个SYSTEMTIME结构 <br />UnlockFile 解除对一个文件的锁定 <br />UnlockFileEx 解除对一个文件的锁定 <br />UnmapViewOfFile 在当前应用程序的内存地址空间解除对一个文件映射对象的映射 <br />VerFindFile 用这个函数决定一个文件应安装到哪里 <br />VerInstallFile 用这个函数安装一个文件 <br />VerLanguageName 这个函数能根据16位语言代码获取一种语言的名称 <br />VerQueryValue 这个函数用于从版本资源中获取信息 <br />WriteFile 将数据写入一个文件 <br />WriteFileEx 与WriteFile类似，只是它只能用于异步写操作，并包括了一个完整的回调 <br />WritePrivateProfileSection 为一个初始化文件（.ini）中指定的小节设置所有项名和值 <br />WritePrivateProfileString 在初始化文件指定小节内设置一个字串 <br />WriteProfileSection 为Win.ini初始化文件中一个指定的小节设置所有项名和值 <br />WriteProfileString 在Win.ini初始化文件指定小节内设置一个字串 <br />4. API之打印函数 <br />AbortDoc 取消一份文档的打印 <br />AbortPrinter 删除与一台打印机关联在一起的缓冲文件 <br />AddForm 为打印机的表单列表添加一个新表单 <br />AddJob 用于获取一个有效的路径名，以便用它为作业创建一个后台打印文件。它也会为作业分配一个作业编号 <br />AddMonitor 为系统添加一个打印机监视器 <br />AddPort 启动"添加端口"对话框，允许用户在系统可用端口列表中加入一个新端口 <br />AddPrinter 在系统中添加一台新打印机 <br />AddPrinterConnection 连接指定的打印机 <br />AddPrinterDriver 为指定的系统添加一个打印驱动程序 <br />AddPrintProcessor 为指定的系统添加一个打印处理器 <br />AddPrintProvidor 为系统添加一个打印供应商 <br />AdvancedDocumentProperties 启动打印机文档设置对话框 <br />ClosePrinter 关闭一个打开的打印机对象 <br />ConfigurePort 针对指定的端口，启动一个端口配置对话框 <br />ConnectToPrinterDlg 启动连接打印机对话框，用它同访问网络的打印机连接 <br />DeleteForm 从打印机可用表单列表中删除一个表单 <br />DeleteMonitor 删除指定的打印监视器 <br />DeletePort 启动"删除端口"对话框，允许用户从当前系统删除一个端口 <br />DeletePrinter 将指定的打印机标志为从系统中删除 <br />DeletePrinterConnection 删除与指定打印机的连接 <br />DeletePrinterDriver 从系统删除一个打印机驱动程序 <br />DeletePrintProcessor 从指定系统删除一个打印处理器 <br />DeletePrintProvidor 从系统中删除一个打印供应商 <br />DeviceCapabilities 利用这个函数可获得与一个设备的能力有关的信息 <br />DocumentProperties 打印机配置控制函数 <br />EndDocAPI 结束一个成功的打印作业 <br />EndDocPrinter 在后台打印程序的级别指定一个文档的结束 <br />EndPage 用这个函数完成一个页面的打印，并准备设备场景，以便打印下一个页 <br />EndPagePrinter 指定一个页在打印作业中的结尾 <br />EnumForms 枚举一台打印机可用的表单 <br />EnumJobs 枚举打印队列中的作业 <br />EnumMonitors 枚举可用的打印监视器 <br />EnumPorts 枚举一个系统可用的端口 <br />EnumPrinterDrivers 枚举指定系统中已安装的打印机驱动程序 <br />EnumPrinters 枚举系统中安装的打印机 <br />EnumPrintProcessorDatatypes 枚举由一个打印处理器支持的数据类型 <br />EnumPrintProcessors 枚举系统中可用的打印处理器 <br />Escape 设备控制函数 <br />FindClosePrinterChangeNotification 关闭用FindFirstPrinterChangeNotification函数获取的一个打印机通告对象 <br />FindFirstPrinterChangeNotification 创建一个新的改变通告对象，以便我们注意打印机状态的各种变化 <br />FindNextPrinterChangeNotification 用这个函数判断触发一次打印机改变通告信号的原因 <br />FreePrinterNotifyInfo 释放由FindNextPrinterChangeNotification函数分配的一个缓冲区 <br />GetForm 取得与指定表单有关的信息 <br />GetJob 获取与指定作业有关的信息 <br />GetPrinter 取得与指定打印机有关的信息 <br />GetPrinterData 为打印机设置注册表配置信息 <br />GetPrinterDriver 针对指定的打印机，获取与打印机驱动程序有关的信息 <br />GetPrinterDriverDirectory 判断指定系统中包含了打印机驱动程序的目录是什么 <br />GetPrintProcessorDirectory 判断指定系统中包含了打印机处理器驱动程序及文件的目录 <br />OpenPrinter 打开指定的打印机，并获取打印机的句柄 <br />PrinterMessageBox 在拥有指定打印作业的系统上显示一个打印机出错消息框 <br />PrinterProperties 启动打印机属性对话框，以便对打印机进行配置 <br />ReadPrinter 从打印机读入数据 <br />ResetDC 重设一个设备场景 <br />ResetPrinter 改变指定打印机的默认数据类型及文档设置 <br />ScheduleJob 提交一个要打印的作业 <br />SetAbortProc 为Windows指定取消函数的地址 <br />SetForm 为指定的表单设置信息 <br />SetJob 对一个打印作业的状态进行控制 <br />SetPrinter 对一台打印机的状态进行控制 <br />SetPrinterData 设置打印机的注册表配置信息 <br />StartDoc 开始一个打印作业 <br />StartDocPrinter 在后台打印的级别启动一个新文档 <br />StartPage 打印一个新页前要先调用这个函数 <br />StartPagePrinter 在打印作业中指定一个新页的开始 <br />WritePrinter 将发送目录中的数据写入打印机 <br />5. API之文本和字体函数 <br />AddFontResource 在Windows系统中添加一种字体资源 <br />CreateFont 用指定的属性创建一种逻辑字体 <br />CreateFontIndirect 用指定的属性创建一种逻辑字体 <br />CreateScalableFontResource 为一种TureType字体创建一个资源文件，以便能用API函数AddFontResource将其加入Windows系统 <br />DrawText 将文本描绘到指定的矩形中 <br />DrawTextEx 与DrawText相似，只是加入了更多的功能 <br />EnumFontFamilies 列举指定设备可用的字体 <br />EnumFontFamiliesEx 列举指定设备可用的字体 <br />EnumFonts 列举指定设备可用的字体 <br />ExtTextOut 经过扩展的文本描绘函数。也请参考SetTextAlign函数 <br />GetASPectRatioFilterEx 用SetMapperFlags要求Windows只选择与设备当前纵横比相符的光栅字体时，本函数可判断纵横比大小 <br />GetCharABCWidths 判断TureType字体中一个或多个字符的A-B-C大小 <br />GetCharABCWidthsFloat 查询一种字体中一个或多个字符的A-B-C尺寸 <br />GetCharacterPlacement 该函数用于了解如何用一个给定的字符显示一个字串 <br />GetCharWidth 调查字体中一个或多个字符的宽度 <br />GetFontData 接收一种可缩放字体文件的数据 <br />GetFontLanguageInfo 返回目前选入指定设备场景中的字体的信息 <br />GetGlyphOutline 取得TureType字体中构成一个字符的曲线信息 <br />GetKerningPairs 取得指定字体的字距信息 <br />GetOutlineTextMetrics 接收与TureType字体内部特征有关的详细信息 <br />GetRasterizerCaps 了解系统是否有能力支持可缩放的字体 <br />GetTabbedTextExtent 判断一个字串占据的范围，同时考虑制表站扩充的因素 <br />GetTextAlign 接收一个设备场景当前的文本对齐标志 <br />GetTextCharacterExtra 判断额外字符间距的当前值 <br />GetTextCharset 接收当前选入指定设备场景的字体的字符集标识符 <br />GetTextCharsetInfo 获取与当前选定字体的字符集有关的详细信息 <br />GetTextColor 判断当前字体颜色。通常也称为"前景色" <br />GetTextExtentExPoint 判断要填入指定区域的字符数量。也用一个数组装载每个字符的范围信息 <br />GetTextExtentPoint 判断一个字串的大小（范围） <br />GetTextFace 获取一种字体的字样名 <br />GetTextMetrics 获取与选入一种设备场景的物理字体有关的信息 <br />GrayString 描绘一个以灰色显示的字串。通常由Windows用于标识禁止状态 <br />PolyTextOut 描绘一系列字串 <br />RemoveFontResource 从Windows系统中删除一种字体资源 <br />SetMapperFlags Windows对字体进行映射时，可用该函数选择与目标设备的纵横比相符的光栅字体 <br />SetTextAlign 设置文本对齐方式，并指定在文本输出过程中使用设备场景的当前位置 <br />SetTextCharacterExtra 描绘文本的时候，指定要在字符间插入的额外间距 <br />SetTextColor 设置当前文本颜色。这种颜色也称为"前景色" <br />SetTextJustification 通过指定一个文本行应占据的额外空间，可用这个函数对文本进行两端对齐处理 <br />TabbedTextOut 支持制表站的一个文本描绘函数 <br />TextOut 文本绘图函数 <br />6. API之菜单函数 <br />AppendMenu 在指定的菜单里添加一个菜单项 <br />CheckMenuItem 复选或撤消复选指定的菜单条目 <br />CheckMenuRadioItem 指定一个菜单条目被复选成"单选"项目 <br />CreateMenu 创建新菜单 <br />CreatePopupMenu 创建一个空的弹出式菜单 <br />DeleteMenu 删除指定的菜单条目 <br />DestroyMenu 删除指定的菜单 <br />DrawMenuBar 为指定的窗口重画菜单 <br />EnableMenuItem 允许或禁止指定的菜单条目 <br />GetMenu 取得窗口中一个菜单的句柄 <br />GetMenuCheckMarkDimensions 返回一个菜单复选符的大小 <br />GetMenuContextHelpId 取得一个菜单的帮助场景ID <br />GetMenuDefaultItem 判断菜单中的哪个条目是默认条目 <br />GetMenuItemCount 返回菜单中条目（菜单项）的数量 <br />GetMenuItemID 返回位于菜单中指定位置处的条目的菜单ID <br />GetMenuItemInfo 取得（接收）与一个菜单条目有关的特定信息 <br />GetMenuItemRect 在一个矩形中装载指定菜单条目的屏幕坐标信息 <br />GetMenuState 取得与指定菜单条目状态有关的信息 <br />GetMenuString 取得指定菜单条目的字串 <br />GetSubMenu 取得一个弹出式菜单的句柄，它位于菜单中指定的位置 <br />GetSystemMenu 取得指定窗口的系统菜单的句柄 <br />HiliteMenuItem 控制顶级菜单条目的加亮显示状态 <br />InsertMenu 在菜单的指定位置处插入一个菜单条目，并根据需要将其他条目向下移动 <br />InsertMenuItem 插入一个新菜单条目 <br />IsMenu 判断指定的句柄是否为一个菜单的句柄 <br />LoadMenu 从指定的模块或应用程序实例中载入一个菜单 <br />LoadMenuIndirect 载入一个菜单 <br />MenuItemFromPoint 判断哪个菜单条目包含了屏幕上一个指定的点 <br />ModifyMenu 改变菜单条目 <br />RemoveMenu 删除指定的菜单条目 <br />SetMenu 设置窗口菜单 <br />SetMenuContextHelpId 设置一个菜单的帮助场景ID <br />SetMenuDefaultItem 将一个菜单条目设为默认条目 <br />SetMenuItemBitmaps 设置一幅特定位图，令其在指定的菜单条目中使用，代替标准的复选符号（√） <br />SetMenuItemInfo 为一个菜单条目设置指定的信息 <br />TrackPopupMenu 在屏幕的任意地方显示一个弹出式菜单 <br />TrackPopupMenuEx 与TrackPopupMenu相似，只是它提供了额外的功能 <br />7. API之位图、图标和光栅运算函数 <br />BitBlt 将一幅位图从一个设备场景复制到另一个 <br />CopyIcon 制作指定图标或鼠标指针的一个副本。这个副本从属于发出调用的应用程序 <br />CopyImage 复制位图、图标或指针，同时在复制过程中进行一些转换工作 <br />CreateBitmap 按照规定的格式创建一幅与设备有关位图 <br />CreateBitmapIndirect 创建一幅与设备有关位图 <br />CreateCompatibleBitmap 创建一幅与设备有关位图，它与指定的设备场景兼容 <br />CreateCursor 创建一个鼠标指针 <br />CreateDIBitmap 根据一幅与设备无关的位图创建一幅与设备有关的位图 <br />CreateDIBSection 创建一个DIBSection <br />CreateIcon 创建一个图标 <br />CreateIconIndirect 创建一个图标 <br />DestroyCursor 清除指定的鼠标指针，并释放它占用的所有系统资源 <br />DestroyIcon 清除图标 <br />DrawIcon 在指定的位置画一个图标 <br />DrawIconEx 描绘一个图标或鼠标指针。与DrawIcon相比，这个函数提供了更多的功能 <br />ExtractAssociatedIcon 判断一个可执行程序或DLL中是否存在图标，或是否有图标与系统注册表中指定的文件存在关联并提取之 <br />ExtractIcon 判断一个可执行文件或DLL中是否有图标存在，并将其提取出来 <br />GetBitmapBits 将来自位图的二进制位复制到一个缓冲区 <br />GetBitmapDimensionEx 取得一幅位图的宽度和高度 <br />GetDIBColorTable 从选入设备场景的DIBSection中取得颜色表信息 <br />GetDIBits 将来自一幅位图的二进制位复制到一幅与设备无关的位图里 <br />GetIconInfo 取得与图标有关的信息 <br />GetStretchBltMode 判断StretchBlt 和 StretchDIBits函数采用的伸缩模式 <br />LoadBitmap 从指定的模块或应用程序实例中载入一幅位图 <br />LoadCursor 从指定的模块或应用程序实例中载入一个鼠标指针 <br />LoadCursorFromFile 在一个指针文件或一个动画指针文件的基础上创建一个指针 <br />LoadIcon 从指定的模块或应用程序实例中载入一个图标 <br />LoadImage 载入一个位图、图标或指针 <br />MaskBlt 执行复杂的图象传输，同时进行掩模（MASK）处理 <br />PatBlt 在当前选定的刷子的基础上，用一个图案填充指定的设备场景 <br />PlgBlt 复制一幅位图，同时将其转换成一个平行四边形。利用它可对位图进行旋转处理 <br />SetBitmapBits 将来自缓冲区的二进制位复制到一幅位图 <br />SetBitmapDimensionEx 设置一幅位图的宽度。以一毫米的十分之一为单位 <br />SetDIBColorTable 设置选入设备场景的一个DIBSection的颜色表信息 <br />SetDIBits 将来自与设备无关位图的二进制位复制到一幅与设备有关的位图里 <br />SetDIBitsToDevice 将一幅与设备无关位图的全部或部分数据直接复制到一个设备 <br />SetStretchBltMode 指定StretchBlt 和 StretchDIBits函数的伸缩模式 <br />StretchBlt 将一幅位图从一个设备场景复制到另一个 <br />StretchDIBits 将一幅与设备无关位图的全部或部分数据直接复制到指定的设备场景 <br />8. API之绘图函数 <br />AbortPath 抛弃选入指定设备场景中的所有路径。也取消目前正在进行的任何路径的创建工作 <br />AngleArc 用一个连接弧画一条线 <br />Arc 画一个圆弧 <br />BeginPath 启动一个路径分支 <br />CancelDC 取消另一个线程里的长时间绘图操作 <br />Chord 画一个弦 <br />CloseEnhMetaFile 关闭指定的增强型图元文件设备场景，并将新建的图元文件返回一个句柄 <br />CloseFigure 描绘到一个路径时，关闭当前打开的图形 <br />CloseMetaFile 关闭指定的图元文件设备场景，并向新建的图元文件返回一个句柄 <br />CopyEnhMetaFile 制作指定增强型图元文件的一个副本（拷贝） <br />CopyMetaFile 制作指定（标准）图元文件的一个副本 <br />CreateBrushIndirect 在一个LOGBRUSH数据结构的基础上创建一个刷子 <br />CreateDIBPatternBrush 用一幅与设备无关的位图创建一个刷子，以便指定刷子样式（图案） <br />CreateEnhMetaFile 创建一个增强型的图元文件设备场景 <br />CreateHatchBrush 创建带有阴影图案的一个刷子 <br />CreateMetaFile 创建一个图元文件设备场景 <br />CreatePatternBrush 用指定了刷子图案的一幅位图创建一个刷子 <br />CreatePen 用指定的样式、宽度和颜色创建一个画笔 <br />CreatePenIndirect 根据指定的LOGPEN结构创建一个画笔 <br />CreateSolidBrush 用纯色创建一个刷子 <br />DeleteEnhMetaFile 删除指定的增强型图元文件 <br />DeleteMetaFile 删除指定的图元文件 <br />DeleteObject 删除GDI对象，对象使用的所有系统资源都会被释放 <br />DrawEdge 用指定的样式描绘一个矩形的边框 <br />DrawEscape 换码（Escape）函数将数据直接发至显示设备驱动程序 <br />DrawFocusRect 画一个焦点矩形 <br />DrawFrameControl 描绘一个标准控件 <br />DrawState 为一幅图象或绘图操作应用各式各样的效果 <br />Ellipse 描绘一个椭圆，由指定的矩形围绕 <br />EndPath 停止定义一个路径 <br />EnumEnhMetaFile 针对一个增强型图元文件，列举其中单独的图元文件记录 <br />EnumMetaFile 为一个标准的windows图元文件枚举单独的图元文件记录 <br />EnumObjects 枚举可随同指定设备场景使用的画笔和刷子 <br />ExtCreatePen 创建一个扩展画笔（装饰或几何） <br />ExtFloodFill 在指定的设备场景里，用当前选择的刷子填充一个区域 <br />FillPath 关闭路径中任何打开的图形，并用当前刷子填充 <br />FillRect 用指定的刷子填充一个矩形 <br />FlattenPath 将一个路径中的所有曲线都转换成线段 <br />FloodFill 用当前选定的刷子在指定的设备场景中填充一个区域 <br />FrameRect 用指定的刷子围绕一个矩形画一个边框 <br />GdiComment 为指定的增强型图元文件设备场景添加一条注释信息 <br />GdiFlush 执行任何未决的绘图操作 <br />GdiGetBatchLimit 判断有多少个GDI绘图命令位于队列中 <br />GdiSetBatchLimit 指定有多少个GDI绘图命令能够进入队列 <br />GetArcDirection 画圆弧的时候，判断当前采用的绘图方向 <br />GetBkColor 取得指定设备场景当前的背景颜色 <br />GetBkMode 针对指定的设备场景，取得当前的背景填充模式 <br />GetBrushOrgEx 判断指定设备场景中当前选定刷子起点 <br />GetCurrentObject 获得指定类型的当前选定对象 <br />GetCurrentPositionEx 在指定的设备场景中取得当前的画笔位置 <br />GetEnhMetaFile 取得磁盘文件中包含的一个增强型图元文件的图元文件句柄 <br />GetEnhMetaFileBits 将指定的增强型图元文件复制到一个内存缓冲区里 <br />GetEnhMetaFileDescription 返回对一个增强型图元文件的说明 <br />GetEnhMetaFileHeader 取得增强型图元文件的图元文件头 <br />GetEnhMetaFilePaletteEntries 取得增强型图元文件的全部或部分调色板 <br />GetMetaFile 取得包含在一个磁盘文件中的图元文件的图元文件句柄 <br />GetMetaFileBitsEx 将指定的图元文件复制到一个内存缓冲区 <br />GetMiterLimit 取得设备场景的斜率限制（Miter）设置 <br />GetNearestColor 根据设备的显示能力，取得与指定颜色最接近的一种纯色 <br />GetObjectAPI 取得对指定对象进行说明的一个结构 <br />GetObjectType 判断由指定句柄引用的GDI对象的类型 <br />GetPath 取得对当前路径进行定义的一系列数据 <br />GetPixel 在指定的设备场景中取得一个像素的RGB值 <br />GetPolyFillMode 针对指定的设备场景，获得多边形填充模式 <br />GetROP2 针对指定的设备场景，取得当前的绘图模式 <br />GetStockObject 取得一个固有对象（Stock） <br />GetSysColorBrush 为任何一种标准系统颜色取得一个刷子 <br />GetWinMetaFileBits 通过在一个缓冲区中填充用于标准图元文件的数据，将一个增强型图元文件转换成标准windows图元文件 <br />InvertRect 通过反转每个像素的值，从而反转一个设备场景中指定的矩形 <br />LineDDA 枚举指定线段中的所有点 <br />LineTo 用当前画笔画一条线，从当前位置连到一个指定的点 <br />MoveToEx 为指定的设备场景指定一个新的当前画笔位置 <br />PaintDesk 在指定的设备场景中描绘桌面墙纸图案 <br />PathToRegion 将当前选定的路径转换到一个区域里 <br />Pie 画一个饼图 <br />PlayEnhMetaFile 在指定的设备场景中画一个增强型图元文件 <br />PlayEnhMetaFileRecord 回放单独一条增强型图元文件记录 <br />PlayMetaFile 在指定的设备场景中回放一个图元文件 <br />PlayMetaFileRecord 回放来自图元文件的单条记录 <br />PolyBezier 描绘一条或多条贝塞尔（Bezier）曲线 <br />PolyDraw 描绘一条复杂的曲线，由线段及贝塞尔曲线组成 <br />Polygon 描绘一个多边形 <br />Polyline 用当前画笔描绘一系列线段 <br />PolyPolygon 用当前选定画笔描绘两个或多个多边形 <br />PolyPolyline 用当前选定画笔描绘两个或多个多边形 <br />Rectangle 用当前选定的画笔描绘矩形，并用当前选定的刷子填充 <br />RoundRect 用当前选定的画笔画一个圆角矩形，并用当前选定的刷子在其中填充 <br />SelectClipPath 将设备场景当前的路径合并到剪切区域里 <br />SelectObject 为当前设备场景选择图形对象 <br />SetArcDirection 设置圆弧的描绘方向 <br />SetBkColor 为指定的设备场景设置背景颜色 <br />SetBkMode 指定阴影刷子、虚线画笔以及字符中的空隙的填充方式 <br />SetBrushOrgEx 为指定的设备场景设置当前选定刷子的起点 <br />SetEnhMetaFileBits 用指定内存缓冲区内包含的数据创建一个增强型图元文件 <br />SetMetaFileBitsEx 用包含在指定内存缓冲区内的数据结构创建一个图元文件 <br />SetMiterLimit 设置设备场景当前的斜率限制 <br />SetPixel 在指定的设备场景中设置一个像素的RGB值 <br />SetPixelV 在指定的设备场景中设置一个像素的RGB值 <br />SetPolyFillMode 设置多边形的填充模式 <br />SetROP2 设置指定设备场景的绘图模式。与vb的DrawMode属性完全一致 <br />SetWinMetaFileBits 将一个标准Windows图元文件转换成增强型图元文件 <br />StrokeAndFillPath 针对指定的设备场景，关闭路径上打开的所有区域 <br />StrokePath 用当前画笔描绘一个路径的轮廓。打开的图形不会被这个函数关闭 <br />UnrealizeObject 将一个刷子对象选入设备场景之前，如刷子的起点准备用SetBrushOrgEx修改，则必须先调用本函数 <br />WidenPath 根据选定画笔的宽度，重新定义当前选定的路径 <br />9. API之设备场景函数 <br />CombineRgn 将两个区域组合为一个新区域 <br />CombineTransform 驱动世界转换。它相当于依顺序进行两次转换 <br />CreateCompatibleDC 创建一个与特定设备场景一致的内存设备场景 <br />CreateDC 为专门设备创建设备场景 <br />CreateEllipticRgn 创建一个椭圆 <br />CreateEllipticRgnIndirect 创建一个内切于特定矩形的椭圆区域 <br />CreateIC 为专用设备创建一个信息场景 <br />CreatePolygonRgn 创建一个由一系列点围成的区域 <br />CreatePolyPolygonRgn 创建由多个多边形构成的区域。每个多边形都应是封闭的 <br />CreateRectRgn 创建一个矩形区域 <br />CreateRectRgnIndirect 创建一个矩形区域 <br />CreateRoundRectRgn 创建一个圆角矩形 <br />DeleteDC 删除专用设备场景或信息场景，释放所有相关窗口资源 <br />DPtoLP 将点阵从设备坐标转换到专用设备场景逻辑坐标 <br />EqualRgn 确定两个区域是否相等 <br />ExcludeClipRect 从专用设备场景的剪裁区中去掉一个矩形区。矩形内不能进行绘图 <br />ExcludeUpdateRgn 从专用设备场景剪裁区去掉指定窗口的刷新区域 <br />ExtCreateRegion 根据世界转换修改区域 <br />ExtSelectClipRgn 将指定区域组合到设备场景的当前剪裁区 <br />FillRgn 用指定刷子填充指定区域 <br />FrameRgn 用指定刷子围绕指定区域画一个外框 <br />GetBoundsRect 获取指定设备场景的边界矩形 <br />GetClipBox 获取完全包含指定设备场景剪裁区的最小矩形 <br />GetClipRgn 获取设备场景当前剪裁区 <br />GetDC 获取指定窗口的设备场景 <br />GetDCEx 为指定窗口获取设备场景。相比GetDC，本函数提供了更多的选项 <br />GetDCOrgEx 获取指定设备场景起点位置（以屏幕坐标表示） <br />GetDeviceCaps 根据指定设备场景代表的设备的功能返回信息 <br />GetGraphicsMode 确定是否允许增强图形模式（世界转换） <br />GetMapMode 为特定设备场景调入映象模式 <br />GetRegionData 装入描述一个区域信息的RgnData结构或缓冲区 <br />GetRgnBox 获取完全包含指定区域的最小矩形 <br />GetUpdateRgn 确定指定窗口的刷新区域。该区域当前无效，需要刷新 <br />GetViewportExtEx 获取设备场景视口（viewport）范围 <br />GetViewportOrgEx 获取设备场景视口起点 <br />GetWindowDC 获取整个窗口（包括边框、滚动条、标题栏、菜单等）的设备场景 <br />GetWindowExtEx 获取指定设备场景的窗口范围 <br />GetWindowOrgEx 获取指定设备场景的逻辑窗口的起点 <br />GetWindowRgn 获取窗口区域 <br />GetWorldTransform 如果有世界转换，为设备场景获取当前世界转换 <br />IntersectClipRect 为指定设备定义一个新的剪裁区 <br />InvalidateRgn 使窗口指定区域不活动，并将它加入窗口刷新区，使之可随后被重画 <br />InvertRgn 通过颠倒每个像素值反转设备场景指定区域 <br />LPtoDP 将点阵从指定设备场景逻辑坐标转换为设备坐标 <br />ModifyWorldTransform 根据指定的模式修改世界转换 <br />OffsetClipRgn 按指定量平移设备场景剪裁区 <br />OffsetRgn 按指定偏移量平移指定区域 <br />OffsetViewportOrgEx 平移设备场景视口区域 <br />OffsetWindowOrgEx 平移指定设备场景窗口起点 <br />PaintRgn 用当前刷子背景色填充指定区域 <br />PtInRegion 确定点是否在指定区域内 <br />PtVisible 确定指定点是否可见（即，点是否在设备场景剪裁区内） <br />RectInRegion 确定矩形是否有部分在指定区域内 <br />RectVisible 确定指定矩形是否有部分可见（是否在设备场景剪裁区内） <br />ReleaseDC 释放由调用GetDC或GetWindowDC函数获取的指定设备场景 <br />RestoreDC 从设备场景堆栈恢复一个原先保存的设备场景 <br />SaveDC 将指定设备场景状态保存到Windows设备场景堆栈 <br />ScaleViewportExtEx 缩放设备场景视口的范围 <br />ScaleWindowExtEx 缩放指定设备场景窗口范围 <br />ScrollDC 在窗口（由设备场景代表）中水平和（或）垂直滚动矩形 <br />SelectClipRgn 为指定设备场景选择新的剪裁区 <br />SetBoundsRect 设置指定设备场景的边界矩形 <br />SetGraphicsMode 允许或禁止增强图形模式，以提供某些支持（包括世界转换） <br />SetMapMode 设置指定设备场景的映射模式 <br />SetRectRgn 设置区域为指定的矩形 <br />SetViewportExtEx 设置设备场景视口范围 <br />SetViewportOrgEx 设置设备场景视口起点 <br />SetWindowExtEx 设置指定设备场景窗口范围 <br />SetWindowOrgEx 设置指定设备场景窗口起点 <br />SetWindowRgn 设置窗口区域 <br />SetWorldTransform 设置世界转换 <br />ValidateRgn 激活窗口中指定区域，把它从刷新区移走 <br />WindowFromDC 取回与某一设备场景相关的窗口的句柄 <br />10. API之硬件与系统函数 <br />ActivateKeyboardLayout 激活一个新的键盘布局。键盘布局定义了按键在一种物理性键盘上的位置与含义 <br />Beep 用于生成简单的声音 <br />CharToOem 将一个字串从ANSI字符集转换到OEM字符集 <br />ClipCursor 将指针限制到指定区域 <br />ConvertDefaultLocale 将一个特殊的地方标识符转换成真实的地方ID <br />CreateCaret 根据指定的信息创建一个插入符（光标），并将它选定为指定窗口的默认插入符 <br />DestroyCaret 清除（破坏）一个插入符 <br />EnumCalendarInfo 枚举在指定"地方"环境中可用的日历信息 <br />EnumDateFormats 列举指定的"当地"设置中可用的长、短日期格式 <br />EnumSystemCodePages 枚举系统中已安装或支持的代码页 <br />EnumSystemLocales 枚举系统已经安装或提供支持的"地方"设置 <br />EnumTimeFormats 枚举一个指定的地方适用的时间格式 <br />ExitWindowsEx 退出windows，并用特定的选项重新启动 <br />ExpandEnvironmentStrings 扩充环境字串 <br />FreeEnvironmentStrings 翻译指定的环境字串块 <br />GetACP 判断目前正在生效的ANSI代码页 <br />GetAsyncKeyState 判断函数调用时指定虚拟键的状态 <br />GetCaretBlinkTime 判断插入符光标的闪烁频率 <br />GetCaretPos 判断插入符的当前位置 <br />GetClipCursor 取得一个矩形，用于描述目前为鼠标指针规定的剪切区域 <br />GetCommandLine 获得指向当前命令行缓冲区的一个指针 <br />GetComputerName 取得这台计算机的名称 <br />GetCPInfo 取得与指定代码页有关的信息 <br />GetCurrencyFormat 针对指定的"地方"设置，根据货币格式格式化一个数字 <br />GetCursor 获取目前选择的鼠标指针的句柄 <br />GetCursorPos 获取鼠标指针的当前位置 <br />GetDateFormat 针对指定的"当地"格式，对一个系统日期进行格式化 <br />GetDoubleClickTime 判断连续两次鼠标单击之间会被处理成双击事件的间隔时间 <br />GetEnvironmentStrings 为包含了当前环境字串设置的一个内存块分配和返回一个句柄 <br />GetEnvironmentVariable 取得一个环境变量的值 <br />GetInputState 判断是否存在任何待决（等待处理）的鼠标或键盘事件 <br />GetKBCodePage 由GetOEMCP取代，两者功能完全相同 <br />GetKeyboardLayout 取得一个句柄，描述指定应用程序的键盘布局 <br />GetKeyboardLayoutList 获得系统适用的所有键盘布局的一个列表 <br />GetKeyboardLayoutName 取得当前活动键盘布局的名称 <br />GetKeyboardState 取得键盘上每个虚拟键当前的状态 <br />GetKeyboardType 了解与正在使用的键盘有关的信息 <br />GetKeyNameText 在给出扫描码的前提下，判断键名 <br />GetKeyState 针对已处理过的按键，在最近一次输入信息时，判断指定虚拟键的状态 <br />GetLastError 针对之前调用的api函数，用这个函数取得扩展错误信息 <br />GetLocaleInfo 取得与指定"地方"有关的信息 <br />GetLocalTime 取得本地日期和时间 <br />GetNumberFormat 针对指定的"地方"，按特定的格式格式化一个数字 <br />GetOEMCP 判断在OEM和ANSI字符集间转换的windows代码页 <br />GetQueueStatus 判断应用程序消息队列中待决（等待处理）的消息类型 <br />GetSysColor 判断指定windows显示对象的颜色 <br />GetSystemDefaultLangID 取得系统的默认语言ID <br />GetSystemDefaultLCID 取得当前的默认系统"地方" <br />GetSystemInfo 取得与底层硬件平台有关的信息 <br />GetSystemMetrics 返回与windows环境有关的信息 <br />GetSystemPowerStatus 获得与当前系统电源状态有关的信息 <br />GetSystemTime 取得当前系统时间，这个时间采用的是"协同世界时间"（即UTC，也叫做GMT）格式 <br />GetSystemTimeAdjustment 使内部系统时钟与一个外部的时钟信号源同步 <br />GetThreadLocale 取得当前线程的地方ID <br />GetTickCount 用于获取自windows启动以来经历的时间长度（毫秒） <br />GetTimeFormat 针对当前指定的"地方"，按特定的格式格式化一个系统时间 <br />GetTimeZoneInformation 取得与系统时区设置有关的信息 <br />GetUserDefaultLangID 为当前用户取得默认语言ID <br />GetUserDefaultLCID 取得当前用户的默认"地方"设置 <br />GetUserName 取得当前用户的名字 <br />GetVersion 判断当前运行的Windows和DOS版本 <br />GetVersionEx 取得与平台和操作系统有关的版本信息 <br />HideCaret 在指定的窗口隐藏插入符（光标） <br />IsValidCodePage 判断一个代码页是否有效 <br />IsValidLocale 判断地方标识符是否有效 <br />keybd_event 这个函数模拟了键盘行动 <br />LoadKeyboardLayout 载入一个键盘布局 <br />MapVirtualKey 根据指定的映射类型，执行不同的扫描码和字符转换 <br />MapVirtualKeyEx 根据指定的映射类型，执行不同的扫描码和字符转换 <br />MessageBeep 播放一个系统声音。系统声音的分配方案是在控制面板里决定的 <br />mouse_event 模拟一次鼠标事件 <br />OemKeyScan 判断OEM字符集中的一个ASCII字符的扫描码和Shift键状态 <br />OemToChar 将OEM字符集的一个字串转换到ANSI字符集 <br />SetCaretBlinkTime 指定插入符（光标）的闪烁频率 <br />SetCaretPos 指定插入符的位置 <br />SetComputerName 设置新的计算机名 <br />SetCursor 将指定的鼠标指针设为当前指针 <br />SetCursorPos 设置指针的位置 <br />SetDoubleClickTime 设置连续两次鼠标单击之间能使系统认为是双击事件的间隔时间 <br />SetEnvironmentVariable 将一个环境变量设为指定的值 <br />SetKeyboardState 设置每个虚拟键当前在键盘上的状态 <br />SetLocaleInfo 改变用户"地方"设置信息 <br />SetLocalTime 设置当前地方时间 <br />SetSysColors 设置指定窗口显示对象的颜色 <br />SetSystemCursor 改变任何一个标准系统指针 <br />SetSystemTime 设置当前系统时间 <br />SetSystemTimeAdjustment 定时添加一个校准值使内部系统时钟与一个外部的时钟信号源同步 <br />SetThreadLocale 为当前线程设置地方 <br />SetTimeZoneInformation 设置系统时区信息 <br />ShowCaret 在指定的窗口里显示插入符（光标） <br />ShowCursor 控制鼠标指针的可视性 <br />SwapMouseButton 决定是否互换鼠标左右键的功能 <br />SystemParametersInfo 获取和设置数量众多的windows系统参数 <br />SystemTimeToTzSpecificLocalTime 将系统时间转换成地方时间 <br />ToAscii 根据当前的扫描码和键盘信息，将一个虚拟键转换成ASCII字符 <br />ToUnicode 根据当前的扫描码和键盘信息，将一个虚拟键转换成Unicode字符 <br />UnloadKeyboardLayout 卸载指定的键盘布局 <br />VkKeyScan 针对Windows字符集中一个ASCII字符，判断虚拟键码和Shift键的状态 <br />11. API之进程和线程函数 <br />CancelWaitableTimer 这个函数用于取消一个可以等待下去的计时器操作 <br />CallNamedPipe 这个函数由一个希望通过管道通信的一个客户进程调用 <br />ConnectNamedPipe 指示一台服务器等待下去，直至客户机同一个命名管道连接 <br />CreateEvent 创建一个事件对象 <br />CreateMailslot 创建一个邮路。返回的句柄由邮路服务器使用（收件人） <br />CreateMutex 创建一个互斥体（MUTEX） <br />CreateNamedPipe 创建一个命名管道。返回的句柄由管道的服务器端使用 <br />CreatePipe 创建一个匿名管道 <br />CreateProcess 创建一个新进程（比如执行一个程序） <br />CreateSemaphore 创建一个新的信号机 <br />CreateWaitableTimer 创建一个可等待的计时器对象 <br />DisconnectNamedPipe 断开一个客户与一个命名管道的连接 <br />DuplicateHandle 在指出一个现有系统对象当前句柄的情况下，为那个对象创建一个新句柄 <br />ExitProcess 中止一个进程 <br />FindCloseChangeNotification 关闭一个改动通知对象 <br />FindExecutable 查找与一个指定文件关联在一起的程序的文件名 <br />FindFirstChangeNotification 创建一个文件通知对象。该对象用于监视文件系统发生的变化 <br />FindNextChangeNotification 重设一个文件改变通知对象，令其继续监视下一次变化 <br />FreeLibrary 释放指定的动态链接库 <br />GetCurrentProcess 获取当前进程的一个伪句柄 <br />GetCurrentProcessId 获取当前进程一个唯一的标识符 <br />GetCurrentThread 获取当前线程的一个伪句柄 <br />GetCurrentThreadId 获取当前线程一个唯一的线程标识符 <br />GetExitCodeProces 获取一个已中断进程的退出代码 <br />GetExitCodeThread 获取一个已中止线程的退出代码 <br />GetHandleInformation 获取与一个系统对象句柄有关的信息 <br />GetMailslotInfo 获取与一个邮路有关的信息 <br />GetModuleFileName 获取一个已装载模板的完整路径名称 <br />GetModuleHandle 获取一个应用程序或动态链接库的模块句柄 <br />GetPriorityClass 获取特定进程的优先级别 <br />GetProcessShutdownParameters 调查系统关闭时一个指定的进程相对于其它进程的关闭早迟情况 <br />GetProcessTimes 获取与一个进程的经过时间有关的信息 <br />GetProcessWorkingSetSize 了解一个应用程序在运行过程中实际向它交付了多大容量的内存 <br />GetSartupInfo 获取一个进程的启动信息 <br />GetThreadPriority 获取特定线程的优先级别 <br />GetTheardTimes 获取与一个线程的经过时间有关的信息 <br />GetWindowThreadProcessId 获取与指定窗口关联在一起的一个进程和线程标识符 <br />LoadLibrary 载入指定的动态链接库，并将它映射到当前进程使用的地址空间 <br />LoadLibraryEx 装载指定的动态链接库，并为当前进程把它映射到地址空间 <br />LoadModule 载入一个Windows应用程序，并在指定的环境中运行 <br />MsgWaitForMultipleObjects 等侯单个对象或一系列对象发出信号。如返回条件已经满足，则立即返回 <br />SetPriorityClass 设置一个进程的优先级别 <br />SetProcessShutdownParameters 在系统关闭期间，为指定进程设置他相对于其它程序的关闭顺序 <br />SetProcessWorkingSetSize 设置操作系统实际划分给进程使用的内存容量 <br />SetThreadPriority 设定线程的优先级别 <br />ShellExecute 查找与指定文件关联在一起的程序的文件名 <br />TerminateProcess 结束一个进程 <br />WinExec 运行指定的程序 <br />12. API之控件与消息函数 <br />AdjustWindowRect 给定一种窗口样式，计算获得目标客户区矩形所需的窗口大小 <br />AnyPopup 判断屏幕上是否存在任何弹出式窗口 <br />ArrangeIconicWindows 排列一个父窗口的最小化子窗口 <br />AttachThreadInput 连接线程输入函数 <br />BeginDeferWindowPos 启动构建一系列新窗口位置的过程 <br />BringWindowToTop 将指定的窗口带至窗口列表顶部 <br />CascadeWindows 以层叠方式排列窗口 <br />ChildWindowFromPoint 返回父窗口中包含了指定点的第一个子窗口的句柄 <br />ClientToScreen 判断窗口内以客户区坐标表示的一个点的屏幕坐标 <br />CloseWindow 最小化指定的窗口 <br />CopyRect 矩形内容复制 <br />DeferWindowPos 该函数为特定的窗口指定一个新窗口位置 <br />DestroyWindow 清除指定的窗口以及它的所有子窗口 <br />DrawAnimatedRects 描绘一系列动态矩形 <br />EnableWindow 指定的窗口里允许或禁止所有鼠标及键盘输入 <br />EndDeferWindowPos 同时更新DeferWindowPos调用时指定的所有窗口的位置及状态 <br />EnumChildWindows 为指定的父窗口枚举子窗口 <br />EnumThreadWindows 枚举与指定任务相关的窗口 <br />EnumWindows 枚举窗口列表中的所有父窗口 <br />EqualRect 判断两个矩形结构是否相同 <br />FindWindow 寻找窗口列表中第一个符合指定条件的顶级窗口 <br />FindWindowEx 在窗口列表中寻找与指定条件相符的第一个子窗口 <br />FlashWindow 闪烁显示指定窗口 <br />GetActiveWindow 获得活动窗口的句柄 <br />GetCapture 获得一个窗口的句柄，这个窗口位于当前输入线程，且拥有鼠标捕获（鼠标活动由它接收） <br />GetClassInfo 取得WNDCLASS结构（或WNDCLASSEX结构）的一个副本，结构中包含了与指定类有关的信息 <br />GetClassLong 取得窗口类的一个Long变量条目 <br />GetClassName 为指定的窗口取得类名 <br />GetClassWord 为窗口类取得一个整数变量 <br />GetClientRect 返回指定窗口客户区矩形的大小 <br />GetDesktopWindow 获得代表整个屏幕的一个窗口（桌面窗口）句柄 <br />GetFocus 获得拥有输入焦点的窗口的句柄 <br />GetForegroundWindow 获得前台窗口的句柄 <br />GetLastActivePopup 获得在一个给定父窗口中最近激活过的弹出式窗口的句柄 <br />GetParent 判断指定窗口的父窗口 <br />GetTopWindow 搜索内部窗口列表，寻找隶属于指定窗口的头一个窗口的句柄 <br />GetUpdateRect 获得一个矩形，它描叙了指定窗口中需要更新的那一部分 <br />GetWindow 获得一个窗口的句柄，该窗口与某源窗口有特定的关系 <br />GetWindowContextHelpId 取得与窗口关联在一起的帮助场景ID <br />GetWindowLong 从指定窗口的结构中取得信息 <br />GetWindowPlacement 获得指定窗口的状态及位置信息 <br />GetWindowRect 获得整个窗口的范围矩形，窗口的边框、标题栏、滚动条及菜单等都在这个矩形内 <br />GetWindowText 取得一个窗体的标题（caption）文字，或者一个控件的内容 <br />GetWindowTextLength 调查窗口标题文字或控件内容的长短 <br />GetWindowWord 获得指定窗口结构的信息 <br />InflateRect 增大或减小一个矩形的大小 <br />IntersectRect 这个函数在lpDestRect里载入一个矩形，它是lpSrc1Rect与lpSrc2Rect两个矩形的交集 <br />InvalidateRect 屏蔽一个窗口客户区的全部或部分区域 <br />IsChild 判断一个窗口是否为另一窗口的子或隶属窗口 <br />IsIconic 判断窗口是否已最小化 <br />IsRectEmpty 判断一个矩形是否为空 <br />IsWindow 判断一个窗口句柄是否有效 <br />IsWindowEnabled 判断窗口是否处于活动状态 <br />IsWindowUnicode 判断一个窗口是否为Unicode窗口。这意味着窗口为所有基于文本的消息都接收Unicode文字 <br />IsWindowVisible 判断窗口是否可见 <br />IsZoomed 判断窗口是否最大化 <br />LockWindowUpdate 锁定指定窗口，禁止它更新 <br />MapWindowPoints 将一个窗口客户区坐标的点转换到另一窗口的客户区坐标系统 <br />MoveWindow 改变指定窗口的位置和大小 <br />OffsetRect 通过应用一个指定的偏移，从而让矩形移动起来 <br />OpenIcon 恢复一个最小化的程序，并将其激活 <br />PtInRect 判断指定的点是否位于矩形内部 <br />RedrawWindow 重画全部或部分窗口 <br />ReleaseCapture 为当前的应用程序释放鼠标捕获 <br />ScreenToClient 判断屏幕上一个指定点的客户区坐标 <br />ScrollWindow 滚动窗口客户区的全部或一部分 <br />ScrollWindowEx 根据附加的选项，滚动窗口客户区的全部或部分 <br />SetActiveWindow 激活指定的窗口 <br />SetCapture 将鼠标捕获设置到指定的窗口 <br />SetClassLong 为窗口类设置一个Long变量条目 <br />SetClassWord 为窗口类设置一个条目 <br />SetFocusAPI 将输入焦点设到指定的窗口。如有必要，会激活窗口 <br />SetForegroundWindow 将窗口设为系统的前台窗口 <br />SetParent 指定一个窗口的新父 <br />SetRect 设置指定矩形的内容 <br />SetRectEmpty 将矩形设为一个空矩形 <br />SetWindowContextHelpId 为指定的窗口设置帮助场景（上下文）ID <br />SetWindowLong 在窗口结构中为指定的窗口设置信息 <br />SetWindowPlacement 设置窗口状态和位置信息 <br />SetWindowPos 为窗口指定一个新位置和状态 <br />SetWindowText 设置窗口的标题文字或控件的内容 <br />SetWindowWord 在窗口结构中为指定的窗口设置信息 <br />ShowOwnedPopups 显示或隐藏由指定窗口所有的全部弹出式窗口 <br />ShowWindow 控制窗口的可见性 <br />ShowWindowAsync 与ShowWindow相似 <br />SubtractRect 装载矩形lprcDst，它是在矩形lprcSrc1中减去lprcSrc2得到的结果 <br />TileWindows 以平铺顺序排列窗口 <br />UnionRect 装载一个lpDestRect目标矩形，它是lpSrc1Rect和lpSrc2Rect联合起来的结果 <br />UpdateWindow 强制立即更新窗口 <br />ValidateRect 校验窗口的全部或部分客户区 <br />WindowFromPoint 返回包含了指定点的窗口的句柄。忽略屏蔽、隐藏以及透明窗口<br /></p>
<img src ="http://www.cppblog.com/yishanhante/aggbug/19547.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/yishanhante/" target="_blank">jay</a> 2007-03-10 17:57 <a href="http://www.cppblog.com/yishanhante/articles/19547.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item><item><title>INI文件的操作</title><link>http://www.cppblog.com/yishanhante/articles/19546.html</link><dc:creator>jay</dc:creator><author>jay</author><pubDate>Sat, 10 Mar 2007 09:56:00 GMT</pubDate><guid>http://www.cppblog.com/yishanhante/articles/19546.html</guid><wfw:comment>http://www.cppblog.com/yishanhante/comments/19546.html</wfw:comment><comments>http://www.cppblog.com/yishanhante/articles/19546.html#Feedback</comments><slash:comments>0</slash:comments><wfw:commentRss>http://www.cppblog.com/yishanhante/comments/commentRss/19546.html</wfw:commentRss><trackback:ping>http://www.cppblog.com/yishanhante/services/trackbacks/19546.html</trackback:ping><description><![CDATA[
		<p>概述</p>
		<p>   在程序中经常要用到设置或者其他少量数据的存盘，以便程序在下一次执行的时候可以使用，比如说保存本次程序执行时窗口的位置、大小、一些用户设置的数据等等，在 Dos 下编程的时候，我们一般自己产生一个文件，由自己把这些数据写到文件中，然后在下一次执行的时候再读出来使用。在 Win32 编程中当然你也可以这样干，但 Windows 已经为我们提供了两种方便的办法，那就是使用注册表或者 ini 文件（Profile）来保存少量数据。本文中先介绍一下 .ini 文件的使用。</p>
		<p>ini 文件是文本文件，中间的数据格式一般为：<br />[Section1 Name]<br />KeyName1=value1<br />KeyName2=value2<br />...</p>
		<p>[Section2 Name]<br />KeyName1=value1<br />KeyName2=value2</p>
		<p>   ini 文件可以分为几个 Section，每个 Section 的名称用 [] 括起来，在一个 Section 中，可以有很多的 Key，每一个 Key 可以有一个值并占用一行，格式是 Key=value，Win32 对 ini 文件操作的 api 中，有一部分是对 win.ini 操作的，有一部分是对用户自定义的 ini 文件操作的。Win.in 和 system.ini 是Windows的两个非常重要的初始化文件，Windows将用户所作的选择以及各种变化的系统信息记录在这两个文件中。System.ini 描述了系统硬件的当前状态，Win.ini 文件则包含了Windows 系统运行环境的当前配置。由于 Win.ini 文件的重要性和常用性，Win32 中有专门对 Win.ini 进行操作的 api，它们是：</p>
		<p>GetProfileInt - 从 Win.ini 文件的某个 Section 取得一个 key 的整数值，它的原形是：</p>
		<p>GetProfileInt(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpKeyName, // 指向包含 Key 名称的字符串地址<br />INT nDefault // 如果 Key 值没有找到，则返回缺省的值是多少<br />);</p>
		<p>   如果 Key 值没有找到的话，返回值是 nDefault 指定的缺省值，如果 Key 中的值是负数，则返回 0，如果 Key 指定的是数字和字符串的混合，则返回数字部分的值，比如说 x=1234abcd，则返回 1234</p>
		<p>
				<br />GetProfileString - 从 Win.ini 文件的某个 Section 取得一个 key 的字符串，它的原形是：</p>
		<p>GetProfileString(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpKeyName, // 指向包含 Key 名称的字符串地址<br />LPCTSTR lpDefault, // 如果 Key 值没有找到，则返回缺省的字符串的地址<br />LPTSTR lpReturnedString, // 返回字符串的缓冲区地址<br />DWORD nSize // 缓冲区的长度<br />);</p>
		<p>   返回的字符串在缓冲区内，返回的 eax 值是返回的字符串的长度（不包括尾部的0）</p>
		<p>
				<br />GetProfileSection - 从 Win.ini 文件中读出整个 Section 的内容，它的原形是：</p>
		<p>GetProfileSection(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPTSTR lpReturnedString, // 返回数据的缓冲区地址<br />DWORD nSize // 返回数据的缓冲区长度<br />);</p>
		<p>
				<br />WriteProfileSection - 将一个整个 Section 的值 写入 Win.ini 文件的指定 Section 中，它的原形是：</p>
		<p>WriteProfileSection(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpString // 要写入的数据的地址<br />);</p>
		<p>   如果 Win.ini 没有指定的 Section，API 会新建立一个并写入数据，如果已经存在，则先删除原来 Seciton 中所有的 Key 值然后写入新的。</p>
		<p>
				<br />WriteProfileString - 将一个 Key 值写入 Win.ini 文件的指定 Section 中，它的原形是：</p>
		<p>WriteProfileString(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpKeyName, // 指向包含 Key 名称的字符串地址<br />LPCTSTR lpString // 要写的字符串地址<br />);</p>
		<p>   如果 Win.ini 没有指定的 Section，API 会新建 Section，如果没有指定的 Key 则新建一个 Key 并写入数据，如果已经存在，则用字符串代替原来的值。<br />   以上的 Api 是对 Win.ini 操作的，当然对于我们来说，用的更多的是在程序运行的目录中建立自己的 ini 文件，如果需要对自己的 ini 文件操作，就要用到另一组 Api，这一组 api 和上面的很象，只要把上面一组的 Profile 换成 PrivateProfile（私有的）就可以了，参数中也相应的多了一个 ini 文件名的参数。例如 GetPrivateProfileInt、GetPrivateProfileSection、WritePrivateProfileString 等等， 下面分别介绍：</p>
		<p>GetPrivateProfileInt - 从 ini 文件的某个 Section 取得一个 key 的整数值，它的原形是：</p>
		<p>GetPrivateProfileInt(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpKeyName, // 指向包含 Key 名称的字符串地址<br />INT nDefault // 如果 Key 值没有找到，则返回缺省的值是多少<br />LPCTSTR lpFileName // ini 文件的文件名<br />);</p>
		<p>   中间参数和返回值的定义和 GetProfileInt 是一样的。</p>
		<p>
				<br />GetPrivateProfileString - 从 ini 文件的某个 Section 取得一个 key 的字符串，它的原形是：</p>
		<p>GetPrivateProfileString(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpKeyName, // 指向包含 Key 名称的字符串地址<br />LPCTSTR lpDefault, // 如果 Key 值没有找到，则返回缺省的字符串的地址<br />LPTSTR lpReturnedString, // 返回字符串的缓冲区地址<br />DWORD nSize // 缓冲区的长度<br />LPCTSTR lpFileName // ini 文件的文件名<br />);</p>
		<p>
				<br />GetPrivateProfileSection - 从 ini 文件中读出整个 Section 的内容，它的原形是：</p>
		<p>GetPrivateProfileSection(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPTSTR lpReturnedString, // 返回数据的缓冲区地址<br />DWORD nSize // 返回数据的缓冲区长度<br />LPCTSTR lpFileName // ini 文件的文件名<br />);</p>
		<p>   这个 api 可以读出整个 section 的内容，当你不知道 section 中有哪些 key 的时候，可以使用这个 api 将整个 section 读出后再处理。</p>
		<p>
				<br />GetPrivateProfileSectionNames - 从 ini 文件中获得 Section 的名称，它的原形是：</p>
		<p>GetPrivateProfileSectionNames(<br />LPTSTR lpszReturnBuffer, // 返回数据的缓冲区地址<br />DWORD nSize // 返回数据的缓冲区长度<br />LPCTSTR lpFileName // ini 文件的文件名<br />);</p>
		<p>如果 ini 中有两个 Section: [sec1] 和 [sec2]，则返回的是 'sec1',0,'sec2',0,0 ，当你不知道 ini 中有哪些 section 的时候可以用这个 api 来获取名称</p>
		<p>
				<br />WritePrivateProfileSection - 将一个整个 Section 的内容入 ini 文件的指定 Section 中，它的原形是：</p>
		<p>WritePrivateProfileSection(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpString // 要写入的数据的地址<br />LPCTSTR lpFileName // ini 文件的文件名<br />);</p>
		<p>
				<br />WritePrivateProfileString - 将一个 Key 值写入 ini 文件的指定 Section 中，它的原形是：</p>
		<p>WritePrivateProfileString(<br />LPCTSTR lpAppName, // 指向包含 Section 名称的字符串地址<br />LPCTSTR lpKeyName, // 指向包含 Key 名称的字符串地址<br />LPCTSTR lpString // 要写的字符串地址<br />LPCTSTR lpFileName // ini 文件的文件名<br />);</p>
		<p>   如果 ini 中没有指定的 Section，API 会新建 Section，如果没有指定的 Key 则新建一个 Key 并写入数据，如果已经存在，则用字符串代替原来的值。当指定的 ini 也不存在的时候，API 会自动建立一个新的文件，所以使用 ini 的好处是我们不必为了保存少量的数据涉及到文件操作，就连查找文件是否存在的操作都不必要。</p>
		<p>使用要点：</p>
		<p>   在我们实际使用的时候，用的最多的是 GetPrivateProfileString 和 WritePrivateProfileString，但在对自定义 ini 文件操作的时候要注意的是，如果 lpFileName 指定的文件没有路径的话，Api 会去 Windows 的安装目录去找而不会在当前目录找，但是每次用到 ini 函数要获取当前路径显然太麻烦了，这里有一个变通的办法，你只要在 ini 文件名前面加上 .\ 就可以了，比如说要对本目录下的 user.ini 操作，那么文件名就是 '.\user.ini' 这样显然比较方便。另外，当你要把一个 Key 清除的时候，可以使用把 lpString 指向一个空的字符串然后使用 WritePrivateProfileString。当你要把一个 section 的全部内容清空的时候，也不必把 key 一个个的清除，可以使用把 lpString 指向一个空的字符串然后使用 WritePrivateProfileSection。</p>
<img src ="http://www.cppblog.com/yishanhante/aggbug/19546.html" width = "1" height = "1" /><br><br><div align=right><a style="text-decoration:none;" href="http://www.cppblog.com/yishanhante/" target="_blank">jay</a> 2007-03-10 17:56 <a href="http://www.cppblog.com/yishanhante/articles/19546.html#Feedback" target="_blank" style="text-decoration:none;">发表评论</a></div>]]></description></item></channel></rss>