在PB中用Enter键实现跳转的几种方法
来源:互联网 发布:python 大数据处理 编辑:程序博客网 时间:2024/05/17 04:17
在使用PowerBuilder开发的应用软件时,各控件及数据窗口列之间的转换基本上是使用Tab键或鼠标来实现的。而对于一些长期使用基于字符终端的用户来说,特别是对频繁、大量处理数据的用户来说,每输完一笔数据,必须通过Tab键或鼠标跳转到下一列中,非常不方便,而采用Enter(回车)键更便于数据的操作。这里,笔者介绍几种将Enter键用作Tab键的方法:
1.在数据窗口中进行列的跳转 在用户具体操作时,数据窗口中Enter键的使用频率最高。在设计时,先打开窗口对象,用鼠标点中要用Enter键实现跳转的数据窗口,选择菜单项“Declare|User Event”,为该数据窗口控制定义用户自定义事件。例如有一个窗口,窗口名为w_sales,内置数据窗口dw_sales,数据窗口有五个列,列名分别为column1~column5,定义用户自定义事件为“dw_sales_key”,对应PowerBuilder事件号为pbm_dwnkey。定义好事件后,用鼠标点数据窗口工具栏图标Script,在select event 中选取事件dw_sales_key进行编程,语句如下:
if keydown(keyenter!)then//判断按下的是否是Enter键
choose case lower(dw_sales.getcolumnname())
case "column1"
dw_sales.setcolumn("column2")
case "column2"
dw_sales.setcolumn("column3")
case "column3"
dw_sales.setcolumn("column4")
case "column4"
dw_sales.setcolumn("column5")
end choose
end if
编程完后,编译保存,再调用该窗口时,其数据窗口内的列可以用Enter键实现跳转。当然,定义Enter键时最好与Tab键的跳转次序一致。其中Tab键的跳转次序可以通过定义数据窗口菜单栏的“Design|Tab Order”项进行定义。当然,也可以不定义用户自定义事件,而直接在数据窗口的ItemChanged事件下写入如下语句:
int i
i=dw_sales.getcolumn()
if keydown(keyenter!) and i< 6 then
dw_sales.setcolumn(i+1)
end if
也可实现数据列之间的跳转。注意,以上均是基于数据插入状态而言的。而对数据查询就另当别论了,按上面的语句进行编程,在查询时,按回车键,光标会往下跳,而不是按行逐列查询,这主要是系统定义Tab键时,认定回车时列号不变,而行号递变,故用上面的方法会引起错位。若要完全替代Tab键功能,还必须做其它方面的工作。在上面的两种方法中,前者语句太长,而后者必须为当前列值有所改变时,按Enter键才能跳转。为此,可采取另一种方法:定义用户自定义事件,其中事件号为pbm_dwnprocessenter,该事件编程语句为:
int i
i=dw_sales.getcolumn()
dw_sales.setcolumn(i+1)
就可实现跳转功能,同时又避免出现以上问题。
2.窗口中各控件之间的跳转 在窗口中,由于各控件的类型不一样,设置跳转就相对复杂一些。读者可以通过按Enter键后焦点的移动来设置各控件的跳转。如果各控件是同类型的,情况就好办得多。这里,笔者举一个例子:窗口仍然为w_sales,上面有五个Commandbutton控件,分别为cb_1~cb_5,在窗口事件key中编写以下语句:
graphicobject i
int j=0
i=getfocus()
if keydown(keyenter!)then
if j=1 then
j=0
return
end if
post (handle(I),256,9,0)
j=1
end if
这样,在运行该窗口时,按下Enter键,就可以实现该五个控件之间的跳转。若要在数据窗口中录完最后一个列值,按Enter键跳转到控件上,可以在笔者举的第一个例子中增加以下语句:
case"column5"
setfocus(cb_1)
即可。
1.在数据窗口中进行列的跳转 在用户具体操作时,数据窗口中Enter键的使用频率最高。在设计时,先打开窗口对象,用鼠标点中要用Enter键实现跳转的数据窗口,选择菜单项“Declare|User Event”,为该数据窗口控制定义用户自定义事件。例如有一个窗口,窗口名为w_sales,内置数据窗口dw_sales,数据窗口有五个列,列名分别为column1~column5,定义用户自定义事件为“dw_sales_key”,对应PowerBuilder事件号为pbm_dwnkey。定义好事件后,用鼠标点数据窗口工具栏图标Script,在select event 中选取事件dw_sales_key进行编程,语句如下:
if keydown(keyenter!)then//判断按下的是否是Enter键
choose case lower(dw_sales.getcolumnname())
case "column1"
dw_sales.setcolumn("column2")
case "column2"
dw_sales.setcolumn("column3")
case "column3"
dw_sales.setcolumn("column4")
case "column4"
dw_sales.setcolumn("column5")
end choose
end if
编程完后,编译保存,再调用该窗口时,其数据窗口内的列可以用Enter键实现跳转。当然,定义Enter键时最好与Tab键的跳转次序一致。其中Tab键的跳转次序可以通过定义数据窗口菜单栏的“Design|Tab Order”项进行定义。当然,也可以不定义用户自定义事件,而直接在数据窗口的ItemChanged事件下写入如下语句:
int i
i=dw_sales.getcolumn()
if keydown(keyenter!) and i< 6 then
dw_sales.setcolumn(i+1)
end if
也可实现数据列之间的跳转。注意,以上均是基于数据插入状态而言的。而对数据查询就另当别论了,按上面的语句进行编程,在查询时,按回车键,光标会往下跳,而不是按行逐列查询,这主要是系统定义Tab键时,认定回车时列号不变,而行号递变,故用上面的方法会引起错位。若要完全替代Tab键功能,还必须做其它方面的工作。在上面的两种方法中,前者语句太长,而后者必须为当前列值有所改变时,按Enter键才能跳转。为此,可采取另一种方法:定义用户自定义事件,其中事件号为pbm_dwnprocessenter,该事件编程语句为:
int i
i=dw_sales.getcolumn()
dw_sales.setcolumn(i+1)
就可实现跳转功能,同时又避免出现以上问题。
2.窗口中各控件之间的跳转 在窗口中,由于各控件的类型不一样,设置跳转就相对复杂一些。读者可以通过按Enter键后焦点的移动来设置各控件的跳转。如果各控件是同类型的,情况就好办得多。这里,笔者举一个例子:窗口仍然为w_sales,上面有五个Commandbutton控件,分别为cb_1~cb_5,在窗口事件key中编写以下语句:
graphicobject i
int j=0
i=getfocus()
if keydown(keyenter!)then
if j=1 then
j=0
return
end if
post (handle(I),256,9,0)
j=1
end if
这样,在运行该窗口时,按下Enter键,就可以实现该五个控件之间的跳转。若要在数据窗口中录完最后一个列值,按Enter键跳转到控件上,可以在笔者举的第一个例子中增加以下语句:
case"column5"
setfocus(cb_1)
即可。
- 【PB】在PB中用Enter键实现跳转的几种方法
- 在PB中用Enter键实现跳转的几种方法
- 网站跳转的几种实现方法
- PB在数据窗口里实现Enter回车键代替Tab键转到下一行
- PB在数据窗口里实现Enter回车键代替Tab键转到下一行
- 在PB中实现热键的方法
- 在PB中实现热键的方法
- 页面自动跳转的几种实现方法
- 利用javascript实现页面跳转的几种方法
- 页面自动跳转的几种实现方法
- 页面自动跳转的几种实现方法 -- zz
- 利用javascript实现页面跳转的几种方法
- 利用javascript实现页面跳转的几种方法
- 页面自动跳转的几种实现方法
- 页面自动跳转的几种实现方法
- 利用javascript实现页面跳转的几种方法
- php页面跳转的几种实现方法
- JSP页面跳转的几种实现方法
- 静态链接库LIB和动态链接库DLL的区别
- MySQL 数据库性能优化之表结构优化(这是 MySQL数据库性能优化专题 系列的第二篇文章)
- Android 中级教程之------Android MediaPlayer播放mp3的实例!
- libpaxos分析
- VC中STL std::string类的使用
- 在PB中用Enter键实现跳转的几种方法
- effective C++笔记之条款12: 尽量使用初始化而不要在构造函数里赋值
- x64安装oracle 10.2.0.4无法启动em dbconsole问题解决
- MySQL 数据库性能优化之缓存参数优化(这是 MySQL数据库性能优化专题 系列的第一篇文章)
- java正则表达式判断email的是否有效
- 内存对齐
- jquery 获取各种屏幕的宽度和高度
- 我的博客http://www.cppblog.com/izualzhy
- Oracle 表空间与数据文件