采用pb11.5 + pbni + vs2015 + rapidjson的开源库,生成解析json,支持datawindow快速导入导出字段名有大写字母的json,支持dw导入出json时对指定字段进行des加密,并在导入到dw时时进行des解密,修改了pbvm115.dll(内存修改方法的文件,请看n_datastore的api定义), ********2024904更新,of_get_sql_json、of_get_datawindow_json、of_get_datastore_json 中ls_key参数,增加多节点支持,例如:datalist:1:list1,意思sql生成json数据写入到数据datalist的第1行,字段名为list1,可轻松生成数组嵌套;of_import_datawindow_json、of_import_datastore_json增加对多节点支持,可以将任意位置的json数组导入到dw
2025-05-31 20:44:53 78.15MB json sql pbni
1
一个可以批量从PBL文件导出为srd,srw文件的小工具。 操作: 选择PBL文件所在文件夹,选择导出目标路径,点击Export按钮,PBL文件夹中所有的PBL文件中的SRW和SRD可迅速导出。修正版没有导出源码文件最大32k的限制。
2025-04-27 19:41:06 2.63MB pb源码导出
1
标题中的"PB中实现椭圆窗口按钮等"指的是在PowerBuilder(PB)环境中创建具有椭圆形外观的窗口按钮。在Windows编程中,通常使用API(应用程序接口)函数来实现非标准形状的控件,比如椭圆或圆形的窗口。PowerBuilder是一种强大的Windows应用开发工具,它允许开发者通过调用底层的API函数来扩展其内置功能。 描述提到"采用API函数来实现",这表明我们需要使用特定的Windows API函数来绘制和操作椭圆窗口按钮。在PowerBuilder中,可以使用`WinAPI`函数或者`DLL`调用来调用这些API。常见的API函数可能包括`CreateRoundRectRgn`用于创建一个矩形区域,然后通过`SetWindowRgn`设置窗口的区域为这个椭圆形状,以实现椭圆窗口。同时,可能还需要处理WM_PAINT消息,使用`BeginPaint`、`EndPaint`和`Ellipse`函数来绘制椭圆形状的按钮。 标签"PB Button Window"进一步确认了讨论的主题,即在PowerBuilder中处理按钮(Button)和窗口(Window)的定制。 从压缩包中的文件名"Button"来看,这可能是一个包含示例代码的文件,如PowerScript源代码或者是一个PB工程文件。这个文件很可能会展示如何定义和使用API函数来创建椭圆窗口按钮,并且已经过测试,可以在PowerBuilder 10版本下正常运行。 在实际编写代码时,首先需要声明API函数,例如: ```pb Long STDCALL CreateRoundRectRgn( Long x1, Long y1, Long x2, Long y2, Long w, Long h ) Long STDCALL SetWindowRgn( Long hWnd, Long hRgn, Long bRedraw ) ``` 接着,你需要在窗口的`Open`事件中创建椭圆区域并设置窗口区域: ```pb Long hRgn = CreateRoundRectRgn(0, 0, this.width, this.height, 边框宽度, 边框高度) SetWindowRgn(this.hwnd, hRgn, TRUE) ``` 在`Paint`事件中,绘制椭圆形状: ```pb HPAINTBUFFER hPB = BeginPaint(this.hwnd) Graphics g = GetGraphicsFromHPBUFFER(hPB) g.Ellipse(0, 0, this.width, this.height) EndPaint(hPB) ``` 可能还需要处理鼠标消息,比如`WM_LBUTTONDOWN`、`WM_LBUTTONUP`等,以便响应用户的点击行为。 以上就是关于在PowerBuilder中实现椭圆窗口按钮的基本过程。具体的实现细节可能因需求和设计而有所不同,但基本思路是利用API函数对窗口的形状进行自定义。如果你需要更深入的代码示例或详细的步骤,请参考相关的PowerBuilder编程教程或者查阅更详细的API文档。
2025-04-08 14:57:28 35KB Button Window
1
在IT行业中,PowerBuilder(简称PB)是一款历史悠久的可视化编程工具,主要用于开发企业级的桌面应用程序。它以其独特的DataWindow控件和强大的数据库交互能力而闻名。本篇将详细讲解"pb 托盘冒泡提示程序"的相关知识点,以及如何进行程序的移植。 **一、PowerBuilder简介** PowerBuilder是由Sybase公司(现已被SAP收购)开发的一种集成开发环境(IDE),主要面向企业应用,支持多种数据库系统,如Oracle、SQL Server、MySQL等。它采用事件驱动的编程模型,提供面向对象的编程语言PBL(PowerBuilder Language),使得开发者能够快速构建用户界面和后台逻辑。 **二、托盘图标与冒泡提示** 在Windows操作系统中,很多应用程序会在任务栏的右下角显示一个托盘图标,这就是所谓的系统托盘区。托盘图标通常用于提供一种不干扰用户主界面的隐藏式操作方式。当用户鼠标悬停在托盘图标上时,程序可以弹出一个小型窗口,显示一些信息,这种现象称为“冒泡提示”。 在PowerBuilder中,实现托盘图标和冒泡提示功能,主要涉及到以下几个步骤: 1. **创建托盘图标对象**:首先需要创建一个TrayIcon对象,并设置其图标和提示文本。 2. **添加事件处理**:为TrayIcon对象添加鼠标事件,如MouseEnter、MouseLeave等,以便在鼠标进入或离开托盘图标时触发相应操作。 3. **显示冒泡提示**:在MouseEnter事件中,调用TrayIcon对象的ShowTip方法,传入要显示的提示信息。 4. **隐藏冒泡提示**:在MouseLeave事件中,调用HideTip方法关闭提示。 **三、程序移植** “移植简单”意味着这个程序设计得具有较好的平台适应性,可以方便地在不同的环境中运行。在PowerBuilder中,通常需要注意以下几点来确保程序的可移植性: 1. **数据库适配器**:确保使用了数据库独立接口(DBI),这样可以在不同数据库系统之间轻松切换。 2. **编码规范**:遵循良好的编程习惯,使代码结构清晰,便于理解和维护。 3. **资源文件管理**:将图标、字符串等资源文件分离管理,便于根据不同平台进行调整。 4. **兼容性测试**:在目标平台上进行充分的兼容性测试,确保所有功能都能正常运行。 "pb 托盘冒泡提示程序"是一个利用PowerBuilder实现的系统托盘功能示例,通过简单的事件处理和API调用来实现冒泡提示效果。它的移植性良好,意味着可以在多个环境下轻松部署和运行。如果你已经下载了名为"Windows托盘冒泡消息提示(源码)"的压缩包,那么你可以直接运行源码,学习并理解其中的实现机制,这对于提升你在PowerBuilder中的技能是非常有帮助的。
2025-04-08 13:06:53 22KB
1
PB,全称PowerBuilder,是一种历史悠久的面向对象的编程环境,特别适合开发企业级的应用程序。在本场景中,"PB实现中文语音朗读"是一个关于如何利用PowerBuilder开发具有中文语音合成功能的项目的主题。这通常涉及到将文本转换为语音输出,以便计算机能够读出文本内容,例如在叫号系统中,可以自动播报号码。 实现这个功能,我们需要以下关键技术: 1. **语音合成技术(TTS,Text To Speech)**:TTS是将文本数据转化为可听的语音输出的技术。在PB中,我们可以集成第三方的TTS引擎,如Microsoft的SAPI(Speech API)或Nuance的TTS引擎,它们能支持中文发音。开发者需要编写代码来调用这些API,传递要朗读的文本,并控制音调、速度和音量。 2. **PowerBuilder接口开发**:PB提供了丰富的.NET和OLE接口,允许我们与外部库或组件进行交互。我们需要创建一个或多个函数或事件,通过这些接口调用TTS引擎的API,实现文本到语音的转换。 3. **数据窗口控件**:PB的数据窗口是其特色之一,用于处理数据库操作。在这个项目中,如果需要从数据库中获取待朗读的文本,可以通过数据窗口控件来实现。 4. **事件驱动编程**:PB采用事件驱动模型,当某个事件(如按钮点击)发生时,触发相应的处理函数。在设计用户界面时,需要添加按钮或控件,使得用户点击后能触发语音朗读。 5. **音频播放**:完成TTS后的语音数据通常是以WAV或其他音频格式存储的。PB需要有能力播放这些音频文件,可能需要集成Windows Media Player控件或其他音频播放库。 6. **多线程**:为了保证用户体验,语音朗读可能需要在一个独立的线程中运行,以免阻塞主应用程序。PB支持多线程编程,可以通过创建线程来实现后台朗读。 7. **错误处理**:在实际开发中,必须考虑到可能出现的各种异常情况,如TTS引擎未安装、网络问题等,因此需要编写适当的错误处理代码。 8. **兼容性测试**:由于不同的操作系统和硬件环境可能对TTS的支持程度不同,所以在开发过程中,需要进行广泛的兼容性测试,确保在多种环境下都能正常工作。 "PB实现中文语音朗读"是一个涉及软件工程多个方面的任务,包括接口开发、事件处理、数据库操作、多媒体处理和错误处理等。通过合理地整合和利用PB提供的工具和特性,我们可以构建出高效、稳定的中文语音朗读系统。对于需要类似功能的项目,这个解决方案可以提供有价值的参考。
2025-01-05 13:23:15 499KB PB中文语音
1
标题中的“pb利用datawindow倒计时”指的是在PowerBuilder(简称PB)环境中,通过DataWindow控件实现倒计时功能。PowerBuilder是一款强大的客户端/服务器应用开发工具,而DataWindow是PB中用于数据展示和操作的核心组件。在这个场景中,开发者想要在用户界面上创建一个倒计时计时器,用户可以自定义倒计时的总秒数。 描述中提到“仅利用数据窗口进行倒计时显示”,意味着开发者计划不依赖额外的控件或编程逻辑,而是直接在DataWindow中处理倒计时的逻辑和显示。这可能涉及到在DataWindow中创建一个计算字段,该字段的值动态更新以反映剩余的倒计时时间。同时,“在开始按钮中自己设置倒计时时间(以秒为单位)”意味着有一个启动倒计时的按钮,用户点击后输入倒计时的总秒数,然后倒计时开始并在DataWindow中显示。 标签中的“pb”、“datawindow”和“倒计时”进一步强调了这个话题的重点。在PowerBuilder中,倒计时通常涉及使用定时器对象(如PB的Timer控件),每隔一定时间间隔更新DataWindow的显示。开发者可能需要使用事件处理函数,例如Timer的"Timer"事件,来触发对倒计时的更新,并确保在达到零时停止倒计时。 从提供的压缩包文件名称“extime.pbl”和“extime.pbt”来看,这里可能包含了项目的源代码和项目文件。`.pbl`是PowerBuilder的库文件,里面包含了应用程序的源代码、对象和资源。`.pbt`是项目文件,保存了关于项目的信息,如源代码的位置、编译选项等。通过打开这些文件,我们可以看到具体的代码实现,包括DataWindow的定义、事件处理函数以及如何启动和更新倒计时的逻辑。 在实现这个功能时,开发者可能需要关注以下几点: 1. 创建一个DataWindow,包含一个表示倒计时的计算字段。 2. 在启动按钮的Click事件中,读取用户输入的倒计时秒数并初始化倒计时。 3. 添加一个Timer控件,设置合适的间隔时间(比如1秒),并关联一个事件处理函数。 4. 在Timer事件处理函数中,更新DataWindow中倒计时字段的值,直到达到零。 5. 当倒计时结束时,可能需要清除或重置DataWindow的状态,或者显示一个提示信息。 这个例子展示了如何在PowerBuilder中利用DataWindow的灵活性和事件驱动的编程模型,创建一个用户交互式的倒计时功能,为用户提供了一种直观的方式来追踪和管理时间。对于初学者和有经验的PB开发者来说,这是一个很好的学习和实践案例。
2025-01-01 22:28:40 7KB datawindow
1
Facenet 训练LFW数据的权重文件
2024-11-28 18:13:06 88.68MB Facenet 训练LFW数据的
1
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中操作打印机。
2024-11-22 10:02:28 8KB 11.5
1
pb截取屏幕的功能,类微信截屏功能 适合PB开发人员。 导入sru文件 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能 pb截取屏幕的功能,类微信截屏功能
2024-11-05 15:29:47 4KB powerbuilder
1
PB API屏幕抓图是PowerBuilder(PB)编程中的一种技术,用于捕获应用程序窗口或屏幕上的图像。在PB9和PB10版本中,开发者可以利用内置的API函数或者第三方库来实现这一功能。下面将详细讲解如何在PowerBuilder中进行屏幕抓图。 在PowerBuilder中,通常有两种方法实现屏幕抓图: 1. **使用Windows API函数**: Windows操作系统提供了几个关键的API函数,如`BitBlt()`和`GetDC()`,可用于获取屏幕或特定窗口的位图。需要声明这些API函数,然后在PowerBuilder的事件处理程序中调用它们。`GetDC()`函数用于获取设备上下文(Device Context, DC),它是Windows图形设备接口(GDI)中用于表示图形设备的对象。然后,可以使用`BitBlt()`函数将设备上下文中的图像复制到内存位图,从而完成屏幕抓取。 2. **使用PowerBuilder的Graphics对象**: PowerBuilder的Graphics对象提供了许多绘图和图像处理功能。可以通过创建Graphics对象,然后调用其`CopyArea()`或`DrawImage()`方法来实现屏幕抓取。这种方法相对简单,但可能不如直接使用Windows API灵活。 具体步骤如下: 1. **初始化**:创建一个Graphics对象,如`gr`,并设置必要的属性,如画布大小、颜色模式等。 2. **获取屏幕信息**:如果是抓取整个屏幕,可以使用`GetDesktopWindow()` API函数获取桌面窗口的句柄,然后通过`GetDC()`获取桌面的设备上下文。 3. **创建内存位图**:使用`CreateCompatibleBitmap()` API函数创建与目标设备上下文兼容的位图,以便存储屏幕图像。 4. **选择位图到设备上下文**:使用`SelectObject()` API函数将创建的位图选入到设备上下文,这样接下来的绘图操作会发生在位图上。 5. **执行抓图**:调用`BitBlt()`或`CopyArea()`,传入正确的源和目标设备上下文,以及要抓取的区域坐标,将屏幕内容复制到内存位图。 6. **保存图像**:使用`SavePicture()`或自定义的图像保存函数,将内存位图保存为图片文件,如BMP、JPEG或PNG格式。 7. **清理**:释放资源,包括设备上下文和位图,以防止内存泄漏。 在实际应用中,可能还需要考虑异步操作,例如在某个事件触发时进行抓图,或者定时抓取。此外,为了实现对特定窗口的抓图,可能需要额外获取窗口的句柄,并调整`BitBlt()`的参数。 对于PB9和PB10,虽然这两个版本相对较旧,但它们仍然支持上述技术。开发者可以根据项目的具体需求选择合适的方法,利用PowerBuilder提供的工具和API,实现高效且灵活的屏幕抓图功能。在处理过程中,注意兼容性和性能优化,确保代码的稳定性和效率。
2024-11-05 15:10:02 51KB
1