pb 11.5 获取打印机列表

上传者: r00_a2lbur | 上传时间: 2024-11-22 10:02:28 | 文件大小: 8KB | 文件类型: RAR
PB 11.5,全称PowerBuilder 11.5,是一款由Sybase公司(现为SAP的一部分)开发的面向对象的编程环境,主要用于构建企业级的应用程序。在这个环境中,开发人员可以利用其强大的数据窗口功能以及易用的图形用户界面来创建桌面和Web应用程序。在"pb 11.5 获取打印机列表"这个主题中,我们将深入探讨如何在PowerBuilder 11.5中获取本地或网络上的可用打印机列表。 我们需要理解的是,获取打印机列表涉及到操作系统级别的API调用,因为PowerBuilder本身并不直接提供这样的功能。在Windows操作系统中,我们可以使用Windows API函数`EnumPrinters`来列举所有的打印机。为了在PowerBuilder中使用这个API,我们需要进行以下步骤: 1. **声明API函数**:在PowerBuilder的源代码中,我们需要声明`EnumPrinters`函数。这个函数定义如下: ```pbl long EnumPrinters(string pPrinterName, long Level, string pPrinterInfo, long cbBuf, long pcbNeeded, long pcReturned) ``` 这个函数的参数包括打印机名、信息级别、打印机信息缓冲区、缓冲区大小、实际需要的缓冲区大小和返回的打印机数量。 2. **创建缓冲区**:由于我们需要接收打印机信息,我们需要创建一个足够大的缓冲区来存储这些信息。这通常可以通过动态分配内存来实现。 3. **调用API函数**:使用`External`关键字调用`EnumPrinters`函数,并传递必要的参数。例如,我们可以先设置`Level`为2,因为这样可以获取到打印机的详细信息(`PRINTER_INFO_2`结构体)。 4. **解析返回信息**:`EnumPrinters`函数成功执行后,返回的信息需要解析。在PowerBuilder中,可以使用`Struct`对象来解析这些信息。你需要定义与`PRINTER_INFO_2`结构体相对应的结构,然后用`Struct`对象填充返回的数据。 5. **处理结果**:遍历解析后的结构体数组,提取打印机的名称、状态等信息,可以将它们显示在列表框或者数据窗口中。 示例代码可能会如下所示: ```pbl // 声明API函数 long EnumPrinters(long Level, string pPrinterInfo, long cbBuf, long pcbNeeded, long pcReturned) External "kernel32.dll" Function EnumPrinters Lib "user32" Alias "EnumPrintersA" (ByVal pPrinterName As Any, ByVal Level As Any, ByVal pPrinterInfo As Any, ByVal cbBuf As Any, pcbNeeded As Any, pcReturned As Any) As Long // 创建缓冲区 long lBufferSize = 0 string sPrinterBuffer[1000] // 假设最大1000个打印机 long lReturnedCount // 调用API获取打印机列表 EnumPrinters(2, sPrinterBuffer, SizeOf(sPrinterBuffer), lBufferSize, lReturnedCount) // 如果获取成功,解析信息 if lReturnedCount > 0 Then Struct stPrinterInfo2 stPrinterInfo2.pName = "" stPrinterInfo2.pServerName = "" stPrinterInfo2.pDriverName = "" stPrinterInfo2.pComment = "" stPrinterInfo2.pLocation = "" stPrinterInfo2.pDatatype = "" stPrinterInfo2.pDevMode = "" stPrinterInfo2.pPortName = "" stPrinterInfo2.pSeparatorFile = "" stPrinterInfo2.pPrintProcessor = "" stPrinterInfo2.pParameters = "" stPrinterInfo2.pSecurityDescriptor = "" stPrinterInfo2.pAttributes = 0 stPrinterInfo2.pPriority = 0 stPrinterInfo2.pDefaultPriority = 0 stPrinterInfo2.pStartTime = 0 stPrinterInfo2.pUntilTime = 0 stPrinterInfo2.cJobs = 0 stPrinterInfo2平均作业时间 = 0 stPrinterInfo2.pStatus = 0 stPrinterInfo2.pComment = "" stPrinterInfo2.pLocation = "" for i = 1 to lReturnedCount // 解析每个打印机的信息 stPrinterInfo2 = Struct(sPrinterBuffer[i]) // 在这里,你可以访问stPrinterInfo2的各种属性,如stPrinterInfo2.pName获取打印机名称 Display stPrinterInfo2.pName next end if ``` 以上代码只是一个简化的示例,实际使用时可能需要根据API文档调整结构体的定义,并处理可能的错误情况。在PowerBuilder中,通过这样的方式,你可以获取到系统中的打印机列表,并进一步实现打印功能或其他与打印相关的操作。 在这个压缩包文件`getprinter`中,可能包含了一个完整的示例项目,包含了上述步骤的实现,包括API的声明、缓冲区的创建、调用API以及解析和显示打印机列表的代码。通过研究这个项目,你可以更深入地了解如何在PowerBuilder 11.5中操作打印机。

文件下载

资源详情

[{"title":"( 4 个子文件 8KB ) pb 11.5 获取打印机列表","children":[{"title":"getprinter","children":[{"title":"getprinter.usr.opt <span style='color:#111;'> 602B </span>","children":null,"spread":false},{"title":"getprinter.pbw <span style='color:#111;'> 170B </span>","children":null,"spread":false},{"title":"getprinter.pbt <span style='color:#111;'> 116B </span>","children":null,"spread":false},{"title":"getprinter.pbl <span style='color:#111;'> 41.50KB </span>","children":null,"spread":false}],"spread":true}],"spread":true}]

评论信息

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明