如何是dw中的字段自动折行?

wallis 2002-10-15 04:28:09
如何是dw中的字段自动折行?
...全文
101 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
wallis 2002-10-23
  • 打赏
  • 举报
回复
我用的是freeform效果不是很理想
jazz008 2002-10-15
  • 打赏
  • 举报
回复
TO : balloonman2002(革命的本钱-身体) 你的方法有点不太好,你所选的字段在运行时就不美观了!有的宽有的窄!!!
ice2water 2002-10-15
  • 打赏
  • 举报
回复
对不起,刚才发错了
详见www.sybase.com.cn
PB应用技巧
     ——数据窗口自动折行
开发者:张国群


  Powerbuilder是数据库开发最优秀的前端开发工具,强大的数据窗口功能令开发者无可置疑。然而,在应用开发过程中,有些特殊的中国式报表令开发者一筹莫展。这些特殊的报表时而不时的光临开发者。前不久,我又被它们惠顾过。那就是怎样在数据窗口中自动折行。

  这个话题也许上个世纪就提出了,但我查阅了所有资料,答案都不能解决实际问题,特别对于pb8(因为已支持汉字)以下版本。经过我多次设置和测试,在基本不写任何代码的情况下,终于大功告成。请看下面的实现步骤:

  第一步:建立并调整网格数据窗口对象。如下图:



  第二步:设置自动折行列edit页属性。如下图:

  

第三步:设置自动折行列position页属性。如下图:

  

说明:gzrw要自动折行列,64是自动折行列(gzrw)高度,除数60三十二个汉字的长度,因为我想把gzrw列三十二个汉字就自动换行。乘数60实际上就是64,这是为了当多行时,字行间的距离更美观些。乘数60和除数60两者毫无关系,这里只不过碰巧了。请看下图结果:





ice2water 2002-10-15
  • 打赏
  • 举报
回复
动态创建数据窗原理及实现

在实际应用中,经常需要根据用户需求来动态创建数据窗,一般方法是这样的。

在一个window中加入一个数据窗控件,如dw_new,但是该数据窗没有data object,(空白的)
就可以用以下语法来创建:
dw_new.create(ls_syntax,ls_error) // 创建语法,错误信息
ls_syntax可以用以下三种方法来形成:

一、动态由sql语法创建:

// 连接到pb的example数据库
string ls_sql,ls_syntax,ls_error
ls_syntax = 'select * from department'
ls_syntax = sqlca.SyntaxFromSQL(ls_sql,'style(type=grid)',ls_error)
if len(ls_error) >0 then
messagebox('Error','SyntaxFromSQL Error:~r'+ls_error)
else
dw_new.create(ls_syntax,ls_error)
if len(ls_error) >0 then
MessageBox("Error", "Create have these errors: ~r" + ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if
end if

二、由另一个数据窗的syntax来创建

string ls_syntax,ls_error
ls_syntax = dw_test.describe('datawindow.syntax')
dw_new.create(ls_syntax,ls_error)
if ls_error <> '' then
messagebox('Create Error',ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if

三、读取psr文件来创建

样例
string ls_syntax,ls_error,ls_ret
ls_ret = char(13)+char(10) //回车键
int li_fileNum
long li_length
li_FileNum = FileOpen("efef.psr",Streammode!, read!, shared!, Replace!)

// 以下是pb5的代码
if li_filenum >0 then
FileSeek(li_FileNum, 158, FromBeginning!)
li_length = fileRead(li_filenum,ls_syntax)
end if
fileclose(li_filenum)
if li_length = 0 then return
ls_syntax = "release 5;"+ls_ret+ls_syntax

//截掉ls_syntax中的数据部分,5.0以"sparse(names="dept_name?) "作为参考位置
//6.0以html(作为参考位置

long pos1,pos2
pos1 = pos(ls_syntax,'sparse(names="',1)
pos2 = pos(ls_syntax,'"',pos1 +16)
ls_syntax = left(ls_syntax,pos1) + mid(ls_syntax,pos1 +1,pos2 - pos1 +1)

dw_New.create(ls_syntax,ls_error)

if ls_error <> '' then
messagebox('Create Error',ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if

//pb6,pb7的代码可以参照pb5自己写,只是文件头和数据窗结束标记不同而已。


流方
2000/05/09

meteor_wyj 2002-10-15
  • 打赏
  • 举报
回复
有一个属性你设置一下即可
balloonman2002 2002-10-15
  • 打赏
  • 举报
回复
自动折行设置:
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。
wallis 2002-10-15
  • 打赏
  • 举报
回复
送分了
wallis 2002-10-15
  • 打赏
  • 举报
回复
送分了

1,108

社区成员

发帖
与我相关
我的任务
社区描述
PowerBuilder 相关问题讨论
社区管理员
  • 基础类社区
  • WorldMobile
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧