请教一下各位高手,在用Qreport做报表时,QRDbText怎样才可以换行呀!数据库字段类型是VARCHAR类的!

解决方案 »

  1.   

    尽可能在VARCHAR的字段的内容加上#10#13
      

  2.   

    你可以参考
    http://expert.csdn.net/Expert/topic/1314/1314396.xml?temp=.6958734
    http://expert.csdn.net/Expert/topic/1351/1351063.xml?temp=.9529535
    http://expert.csdn.net/Expert/topic/1265/1265250.xml?temp=.2919428
    http://expert.csdn.net/Expert/topic/1302/1302834.xml?temp=.9411737
    http://expert.csdn.net/Expert/topic/1282/1282681.xml?temp=.8808863不过,我自己试过TQRDBText(已经修改了里面QRCtrls单元中的AddWord过程)、QRmemo都不能解决自动换行的问题。
    我自己的解决方法如下:
    1.在需要显示换行的字段的地方用TQRMemo替代TQRDBText,并调整好TQRMemo的长度和宽度(显示字段的最大范围);
    2.在报表所在的Form上放一个TMemo控件,由它来负责解决换行问题,在TQRMemo所在的band的BeforePrint事件中写代码,具体如下
    var
      i: integer;
    begin
      memo1.lines.clear;
      TQRMemo.lines.clear;
      memo1.width:= TQRMemo.Width;
     memo1.lines.text:= ADODataSet1.FieldByName('字段名').AsString;
      for i:= 0 to memo1.lines.Count - 1 do
        QRMemo.lines.Add(memo1.lines.strings[i]);
    end;
    只要在需要的地方依上面的方法处理就行。
      

  3.   

    楼上的,修改QRCTRLS当然可以换行,我就已经修改成功,并且在我们公司的软件中有了很大的应用。。具体帖子的位置已经在楼上所列出的帖子
      

  4.   

    if length(qrdbtext1.Caption) > 10 then
      qrdbtext1.Caption:=copy(qrdbtext1.Caption,1,10)+' '+copy(qrdbtext1.Caption,11,length(qrdbtext1.Caption)-10);