PB操作技巧
PB系列简易操作手册

PB简易操作手册辉泉机电设备(上海)有限公司沈阳分公司B 系列简易操作手册※ 运行开机状态:可以喷印※ 清洗停机荧屏熄灭关机※ 变更喷印内容1状态:输入模式2、 可以喷印 执行 字符输入 状态:可以喷印 执行※ 紧急停机约1分钟控制 快速停机 墨线停止 状态:停止(无清洗停机)※ 打开墨线约1分钟运行 打开墨线 状态:待机(墨线喷出,但未加高压) ※ 可以喷印控制 可以喷印 执行 状态:可以喷印※ 待机控制 待机 喷印中断 状态:待机※ 调用设定内容※登录设定内容※变更字宽,字高,延迟等喷印设置※警报/异常讯息排除确认警报/参照技术手册(异常/警容及可能发生的原因告)的简易排除故障如尚未排除请尽快联络维修工程师前往维修※印字中,变更设定内容移动光标至需要修改处输入※印字中,变更字宽,字高,延迟等喷印设置※印字中,调用设定内容选择所需条款状态:可以喷印※印字中,登录设定内容可以喷印※印字中,变更行数设定※行数设定※ 一般故障处理1. 开机故障墨水从喷嘴喷出,如果开机过程中出现异常屏幕,轻按触摸屏右上角“控制”,屏幕提示再按“快速停机”。
一般情况墨线喷出瞬间会散布一些墨点,设备不会提示警告,但如果操作开始时设备提示警告或异常(喷头内有污垢、无法充电、墨线未进回收管),执行以下措施:1) 将设备转为“停止”状态2) 旋松喷头罩锁紧螺丝,卸下喷头罩3)4) 安装喷头罩,轻按 屏幕提示再按5) 确认墨线喷射在回收管中心(垂直方向,水平方向)6) 安装喷头罩,如果设备提示“喷头罩未装”警告,轻按“删除信息”7) 设备转为“待机”状态,进而转为“可以喷印”状态2.运行中故障喷印过程中出现“无法充电”“充电量过高”“充电量过低”“无法充电”的异常警报,执行以下措施:1) 检查墨线是否射在回收管中央,采取的措施:● 检查喷头是否受到撞击,导致螺丝松动产生的墨线偏,若是就参照说明书调整墨线 ● 检查是否是喷嘴赌塞,堵塞就执行喷嘴逆清洗、添加溶剂清洗的程序(执行程序不能超过三次)● 若偏转不多可以先调整墨线,维持使用,待有超声波清洗器将喷嘴片拆下清洗 打开墨线2)检查喷头内是否有污垢或潮湿,采取的措施:用洗壶将喷头内墨水冲洗干净,再用吹球吹干,重新启动就可以3)墨点分离不良,采取的措施:●进入保养操作●调整减压阀,将压力调小(标注压力0.245)看压力表。
PB操作手册

PB 操作手册创建连接1.正常安装即可2.打开PB,点击database按钮3.在左侧选择ODB ODBC,右单击,选择New profile,弹出如下对话框4. 在profile name输入要创建的库名5. 在data source下选择要连接的ODBC连接6. 在user ID和password分别输入要连接的数据库的用户名和密码7. 在Driver-Specific parameters中输入驱动的路径,如下图8.创建ODBC连接,控制面板-管理工具-数据源-添加9.根据数据库,选择匹配的驱动程序,如连接SQL2005,请选择SQL Server,点击完成10. 选择数据库的服务器,点击下一步,选择“使用用户输入登录ID和密码的SQL Server 验证”;勾选”连接SQL Server以获得其他配置选项的默认设置”;分别输入连接数据库的用户名和密码点击下一步、下一步点击测试数据源,如果测试成功,则表明连接成功11. 在Database profile setup-ODBC框内,选择“preview”,点击test connection,如果提示连接成功,则可以对库进行操作对库进行操作1.选择一个已创建的库,右单击,选择connect2.选择一张表,右单击,选择edit data-grid,即可查看数据3.选择一条数据,右单击,选择delete/insert row,可以进行删除/添加数据,修改后需要保存4.选择ISQL session,可以编写、执行SQL5.选择一条数据,右单击,选择save row as,可以将所选数据存为指定格式的数据,如CSV,TXT等6.选择一张表,使其处于grid状态,在菜单栏,选择rows-import,可以选择数据源,将数据导入表内,导入后需要保存。
PB使用小技巧

PB使用小技巧1. 如何使PB窗口总在最上层通过SetWindowPos函数把窗口的显示层次修改为HWND_TOPMOST,就可以使指定窗口永远不会被其他窗口覆盖,该函数声明为:Function Long SetWindowPos(Long hwnd, Long ord, Long x, Long y, Long dx, Long dy, Long uflag) Library “user32.dll”参数1为要顶层显示的窗口句柄,参数2指定显示的层次,参数7为附加选项,其余参数指定窗口位置和大小,均可忽略。
在窗口的Open或Activate事件中加入如下函数调用:SetWindowPos(Handle(This),-1,0,0,0,0,3)参数2取-1表示在最顶层显示窗口,取1表示在最底层显示;最后一个参数若取1,表示窗口大小保持不变,取2表示保持位置不变,因此,取3(=1+2)表示大小和位置均保持不变,取0表示将窗口的大小和位置改变为指定值。
2. 在PB中如何获得光盘盘符通过GetDriveType函数可以获取驱动器(如:软驱、硬盘、光驱、网络映射驱动器等)的信息,该函数声明为:Function Unit GetDriveTypeA(String drive) Library “kernel32.dll”参数为一个盘符(如“C:”),返回值:1表示未知,2表示软驱,3表示本地硬盘,4表示网络驱动器,5表示光驱。
因此如下代码可以获得光盘的盘符:For I=Asc(‘D’) to Asc(‘Z’)//列举所有可能的CDROM的驱动器If GetDriveTypeA(Char(i)+”:”) = 5 Then//若找到CDROMMessagebox(“CDROM”,Char(i)+”:”)//显示光盘盘符Exit //退出循环End ifNext3. 在PB中如何获取目录信息(1)获取当前目录。
通过GetCurrentDirectory函数可以获取当前目录,该函数声明为:Function Ulong GetCurrentDirectory(Ulong buflen,ref String dir)Library “kernel32.dll”参数2为接受当前目录的字符缓冲区,前面必须加ref表示地址引用;参数1用来指定字符缓冲区的长度。
PB数据窗口绝对技巧

PB数据窗口绝对技巧PB数据窗口绝对技巧是指通过使用PowerBuilder开发环境的数据窗口对象实现高效数据处理的技巧。
数据窗口是PowerBuilder中最重要和最常用的对象之一,它可以用于显示和操作数据库中的数据。
下面将介绍一些PB数据窗口的绝对技巧。
1.使用绑定数据窗口:绑定数据窗口是将数据窗口与数据库表绑定在一起,这样可以方便地进行数据的读取、修改和保存操作。
使用绑定数据窗口可以避免手动编写SQL语句或存储过程,大大提高了开发效率。
2.优化数据窗口的性能:数据窗口的性能优化是开发过程中非常重要的一环。
可以通过以下方法来提高数据窗口的性能:-只选择需要的列:只选择需要的列可以减少网络传输的数据量,提高数据检索的速度。
-使用约束和过滤器:可以在数据窗口中使用约束和过滤器来限制返回结果集的大小,进一步提高性能。
-使用预检索:可以在打开数据窗口之前使用预检索功能,先将数据加载到缓存中,减少后续操作对数据库的访问次数。
3.自定义数据窗口的样式:可以通过数据窗口的属性和事件来自定义数据窗口的样式。
例如,可以设置列的显示格式、颜色和字体等属性,还可以通过事件来实现数据窗口的验证和计算逻辑。
4.使用数据窗口的分组功能:数据窗口的分组功能可以将数据按照指定的列进行分组,并对每个分组进行汇总计算。
这样可以方便地进行数据的统计和报表生成。
5.使用数据窗口的嵌套功能:数据窗口可以嵌套在其他数据窗口中,形成复杂的数据结构。
通过使用数据窗口的嵌套功能,可以实现多层次的数据展示和操作,提高用户体验和数据处理的灵活性。
6.使用数据窗口的插入和更新语句:数据窗口可以使用自动生成的插入和更新SQL语句来实现数据的插入和修改操作。
这样可以避免手动编写大量的SQL语句,简化开发过程。
7.使用数据窗口的事务处理:数据窗口的事务处理功能可以保证一系列的操作要么全部成功,要么全部失败。
可以通过使用数据窗口的事务处理功能来实现数据的批量插入和更新,提高数据处理的效率和数据的一致性。
PB 数据窗口高级( DataWindow)应用37个技巧

PB 数据窗口高级( DataWindow) 37个技巧1. 使DataWindow列只能追加不能修改如何使DataWindow中的数据只能追加新记录而不能修改,利用Column 的Protect 属性可以很方便的做到这一点,方法如下:将每一列的Protect 属性设置为:If( IsRowNew(), 0, 1) )在PowerScript 中可以动态修改Protect 属性:dw_1.Modify("column_name_here.Protect='1~tIf(IsRowNew(),0,1)'")这样,DataWindow 中只有新追加的记录可修改,而其他记录是只读的。
2 .如何在DataWindow中实现列的自动折行我们在PowerBuilder应用程序的开发过程中, 使用DataWindow时, 经常会遇到某列的数据太长, 不能同时全部显示的情况. 若采用自动水平滚动, 操作起来又不够简便. 下面介绍一种方法, 实现列数据多行显示, 即实现列数据的自动折行.具体步骤如下:1) 在DataWindow Painter中打开此DataWindow.2) 在需设定自动折行的列上双击鼠标, 弹开此列的属性窗口.3) 选择Position标签, 选中Autosize Height 多选框.4) 选择Edit标签, 不选中Auto Horz Scroll多选框.5) 单击OK按钮, 保存所做的修改.6) 点中Detail Band (即写有Detail的灰色长带), 单击鼠标右键, 选择Properties... 菜单项.7) 选中Autosize Height多选框.8) 单击OK按钮, 保存所做的修改.9) 保存此DataWindow.注意:连在一起的汉字(中间没有标点或空格分隔), 系统将认为是一个单词, 不会自动进行折行.3. 在数据窗口中实现动画要实现动画,必须要有定时器,在数据窗口中已经有了一个定时器,双击数据窗口将弹出的对话框,在Timer Interval中定义大于零的值就有定时器(可以精确到毫秒),有了这个定时器就可以实现动画了。
pb手势操作

手势 3:关闭已缩小的程序
手势 4:在任意程序调出虚拟键盘
如图,从左下角向右上划动
手势 5:任意程序中,调出 pb 设置栏
除了主屏幕,在任何软件运行中,在右上角或者左上角斜向下滑动,可以调出主屏幕中上边条。
手势 6:调出程序的设置栏
上边框向下划动
手势 7:安卓中的返回操作
斜向上的箭头方向,离底框近一点,就行了
手势 8:多个程序间切换
手势 9:基本的放大、缩小
PB的小技巧

PB的小技巧1.如何使DataWindow中的数据只能追加新记录而不能修改。
利用Column 的Protect 属性可以很方便的做到这一点,方法如下:将每一列的Protect 属性设置为:If( IsRowNew(), 0, 1) )在PowerScript 中可以动态修改Protect 属性:dw_1.Modify("column_name_here.Protect='1~tIf(IsRowNew(),0,1)'")2. 允许从空的非字符字段跳离string ss = this.dwDescribe(this.GetColumnName()+".coltype")//s = this.dwDescribe("#"+String(this.GetColumn())+".coltype")CHOOSE CASE sCASE "number"IF Trim(this.GetText()) = "" THENint null_numSetNull(null_num)this.SetItem(this.GetRow(),this.GetColumn(),null_num)this.SetActionCode(3)END IFCASE "date"IF Trim(this.GetText()) = "" THENdate null_dateSetNull(null_date)this.SetItem(this.GetRow(),this.GetColumn(),null_date)this.SetActionCode(3)END IFCASE "time"IF Trim(this.GetText()) = "" THENtime null_timeSetNull(null_time)this.SetItem(this.GetRow(),this.GetColumn(),null_time)this.SetActionCode(3)END IFCASE "datetime"IF Trim(this.GetText()) = "" THENdate null_datetimeSetNull(null_datetime)this.SetItem(this.GetRow(),this.GetColumn(),null_datetime)this.SetActionCode(3)END IFEND CHOOSE3. 当我们为Datawindow的每一行显示行号时可以简单的放一个表达式为GetRow() -- 计算列。
pb的ddlb技巧

pb的ddlb技巧在数据库管理中,DDL(数据定义语言)用于定义数据库的结构,其中包括创建、修改和删除数据库对象。
而PB(PowerBuilder)是一种集成开发环境,用于构建企业级应用程序。
在PB中操作数据库时,可以使用DDL语句来创建、修改和删除数据库对象。
以下是一些PB中使用DDL的技巧:1. 创建表:在PB中,可以使用CREATE TABLE语句来创建数据库表。
可以指定表的名称、列的数据类型、约束等信息。
例如:CREATE TABLE employee (。
emp_id INT PRIMARY KEY,。
emp_name VARCHAR(50),。
emp_salary DECIMAL(10,2)。
);2. 修改表:如果需要修改已存在的表结构,可以使用ALTER TABLE语句。
例如,添加新的列或修改列的数据类型:ALTER TABLE employee.ADD emp_department VARCHAR(50);3. 删除表:如果需要删除已存在的表,可以使用DROP TABLE 语句。
例如:DROP TABLE employee;4. 创建索引:在PB中,可以使用CREATE INDEX语句来创建索引,以提高查询性能。
例如:CREATE INDEX idx_emp_name ON employee (emp_name);5. 删除索引:如果不再需要某个索引,可以使用DROP INDEX 语句来删除它。
例如:DROP INDEX idx_emp_name ON employee;6. 使用事务,在执行DDL语句时,建议使用事务来确保数据的一致性。
可以使用BEGIN TRANSACTION和COMMIT TRANSACTION语句来控制事务的范围。
7. 错误处理,在执行DDL语句时,需要考虑可能出现的错误情况。
可以使用TRY...CATCH块来捕获并处理异常情况,以确保程序的稳定性。
总之,在PB中使用DDL语句需要谨慎对待,确保在操作数据库结构时不会造成数据丢失或不一致。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
窗口与控件窗口与控件专题所涉及的范围比较广,如特殊功能控件的实现,友好漂亮界面的制作,这些都是PB程序员比较感兴趣的话题。
在PowerBuilder中,如果善于运用数据窗口与API技术,开发出的应用定将与众不同。
本章结合实例介绍如下专题:制作Splash窗口制作美观的状态条系统热键的实现创建图标栏应用MDI窗口显示背景图片定制有特色的图标按钮导航图界面的制作制作图文并茂的菜单窗口内控件大小与窗口大小同步动态创建控件控件融合技术窗口中控件显示ToolTips第章1PowerBuilder 8.0进阶篇·2·owerBuilder 编程离不开窗口与控件,从某种程度上可以说,现在的可视化编程无非就是将各种控件垒加到窗口中,再加上编写的一些代码,就构成了一个应用程序。
因此可以这么理解:窗口与控件是可视化编程的基础。
PowerBuilder 8.0提供了类型丰富的窗口及控件,灵活使用它们可以为应用开发提供极大的方便。
很多人认为,PowerBuilder 在界面制作方面功能不是很强,很难制作出Delphi 那样的漂亮界面。
其实只要肯思考,善于利用数据窗口及API 等技术,PowerBuilder 一样可以制作出美观、友好的用户界面。
本章将结合实例介绍在PowerBuilder 中如何制作Splash 启动窗口、美观的状态条、图文并茂的菜单以及如何使用系统热键、创建图标栏、用MDI 窗口显示背景图片、定制按钮、制作导航图界面、使窗口内控件大小与窗口大小同步、动态创建控件、使用控件融合、用窗口中控件显示ToolTips 等实用技术。
1.1 制作Splash 窗口现在很多商业软件如PowerBuilder 、Word 、金山词霸等都会在程序启动时呈现一个Splash 窗口,窗口上有软件名称、版本、图标等相关信息或“正在加载,请稍候…”等提示信息,该窗口显示一段时间后会自动关闭。
如果在自己开发的系统中启动时也加上一个Splash 窗口,虽然不会改善程序性能,但会使应用程序添色不少。
下面介绍在PowerBuilder 中如何实现启动时的Splash 窗口。
实例创建步骤如下:(1) 创建Splash 窗口。
选择工具栏中的New 图标,弹出New 对话框,选择PB Object 标签页,再选择Window 新建一个窗口。
(2) 设置Splash 窗口的属性。
其中窗口类型设为Popup!,Visible 属性、Enabled 属性和Center (居中)属性设为True ,其他属性都设为False 。
属性设置如图1-1所示。
(3)在Splash 窗口放置相关控件以显示信息如图标、软件名称、版本和公司名称等,可根据软件需要加以选择。
最后以“w_Splash ”名称保存该窗口。
P图1-1 Splash 窗口属性设置=====================================================================窗口在5秒钟后接收到Timer事件,关闭w_Splash窗口。
在w_Splash的Timer 事件中加入:Close(this)//关闭窗口在窗口的Close事件中关闭Timer事件:Timer(0,this)(5) 为了测试,另外创建一个菜单m_main和一个mdihelp!类型的窗口w_main,并将菜单m_main关联至w_main窗口。
w_main作为系统的主窗口。
(6) 调用Splash窗口。
程序启动时调用Splash窗口,并连接数据库,最后打开系统主窗口。
在Application的Open事件加入如下脚本:===================================================================== //调用Splash窗口Open(w_splash)//连接数据库// Profile EAS Demo DB V4SQLCA.DBMS = "ODBC"SQLCA.AutoCommit = FalseSQLCA.DBParm = "ConnectString='DSN=EAS Demo DB V4;UID=dba;PWD=sql'"Connect;If sqlca.sqlcode <> 0 thenMessagebox('连接数据库失败',sqlca.sqlerrtext)HaltElse//打开系统主窗口Open(w_main)End If=====================================================================1.2 制作美观的状态条一个程序的微帮助状态栏常用于显示该系统的一些重要信息或帮助信息,其重要性是PowerBuilder 8.0进阶篇·4·不言而喻的。
但PowerBuilder中的微帮助状态栏一直不尽如人意,单一并且不能定制,甚至连字体属性都不能修改,因此有必要自己创建状态栏,使之更加美观、漂亮。
下面通过实例给出两种定制状态条的方法。
1.2.1 利用Popup窗口这种方法的原理是利用一个Popup!类型的窗口来放置状态栏的有关信息,如操作员、系统时间等,并将此窗口显示在MDI窗口状态栏合适的位置。
这里给出一个在MDI窗口右下角实时显示系统时间的简单例子,运行效果如图1-2所示。
图1-2 状态栏右边显示系统时间实例创建步骤如下:(1) 创建一个Popup!类型的窗口w_popup_time,并将其Visible属性、Enabled属性设置为True,其他属性都设为False。
窗口大小、位置设置:X:0,Y:0,Width:230,Height:52。
(2) 在w_popup_time中放置两个控件:sle_time:单行编辑器,用于显示系统时间。
将Border的属性设为False,BorderStyle 设为StyleBox!。
st_1:静态文本框,用于分隔状态栏。
将Border的属性设为True,BorderStyle设为StyleRaised!。
(3) 在w_pouup_time窗口的如下事件中编写脚本。
Open事件===================================================================== //显示时间sle_time.text = string(now(),"hh:mm:ss")Timer (1)//设置分隔文本的大小、位置st_1.Move (5, 0)st_1.Resize (16, this.Height)========================================================================================================================================== //声明窗口w_Popup_Time iw_Popup_Time=====================================================================(5) 在w_main窗口的如下事件中编写脚本:Open事件===================================================================== long ll_wx,ll_wy,ll_wh,ll_wwll_wx = this.workspacex ( )ll_wy = this.workspacey ( )ll_wh = this.workspaceheight ( )ll_ww = this.workspacewidth ( )open(iw_popup_time)//设定位置iw_popup_time.move(ll_wx + ll_ww - iw_popup_time.width - 100 , &ll_wy + ll_wh - iw_popup_time.height - 6)===================================================================== Resize事件===================================================================== integer ll_wx ,ll_wy ,ll_wh ,ll_wwll_wx =this.workspacex ( )ll_wy =this.workspacey ( )ll_wh =this.workspaceheight ( )ll_ww =this.workspacewidth ( )//MDI窗口改变大小时,iw_popup_time的位置要随之改变if IsValid (iw_popup_time) theniw_popup_time.move(ll_wx +ll_ww - iw_popup_time.width - 100,&ll_wy +ll_wh - iw_popup_time.height - 6 ) end if=====================================================================PowerBuilder 8.0进阶篇·6·Ue_move事件(用户自定义事件,Event ID:pbm_move)MDI窗口移动时,iw_popup_time的位置要随之改变,并保持与MDI窗口的相对位置不变。
脚本同Resize事件。
1.2.2 利用窗口内控件利用窗口内控件制作状态条的原理很简单,就是在运行过程中保持该控件与窗口的相对位置不变,并把相关信息显示在该控件中。
本例利用数据窗口控件来显示状态栏信息。
(1) 创建一个Tabular风格,数据源为External的数据窗口d_status_bar。
各列定义参见表1-1。
表1-1 d_status_bar 定义(2) 为数据窗口对象d_status_bar增加位图及线条等控件,如图1-3所示。
这样做的目的是使定制的状态条更加美观。
图1-3 设计数据窗口d_status_bar其中,在sysdate字段的后面增加一个计算域week,用来根据日期显示星期。
计算域的表达式为:===================================================================== case( daynumber(sysdate ) when 1 then '星期天' when 2 then '星期一' when 3 then '星期二' when 4 then '星期三' when 5 then '星期四' when 6 then '星期五' when 7 then '星期六' else '')===================================================================== 计算域的文本字体(Text Color)设置为:case (daynumber(sysdate) when 1 then 255 when 7 then 255 else 0)Open事件===================================================================== //显示状态栏信息dw_status_bar.Insertrow(0)dw_status_bar.Setitem(1,'department', '部门:PowerBuilder编程俱乐部')dw_status_bar.Setitem(1, 'user',' 柜员:柯建勋' )dw_status_bar.Setitem(1, 'sysdate',now())//dw_status_bar.Setitem(1, 'other',' 其他信息' )dw_status_bar.Object.DataWindow.ReadOnly = True===================================================================== Resize事件===================================================================== integer li_height,li_width//状态栏li_height = this.workspaceHeight()li_width = this.workspaceWidth()mdi_1.x = this.workspacex()mdi_1.y = this.workspacey() - 4mdi_1.height = li_height - dw_status_bar.height + 8mdi_1.width = li_width//定位dw_status_bar.x = this.workspacex() - 4dw_status_bar.y = mdi_1.y + mdi_1.heightdw_status_bar.width = li_width + 4=====================================================================(6) 此状态条的运行效果如图1-4所示。