[QuickReport]--如何在印之前計算每個group的總頁數 |
尚未結案
|
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
sl@cableplus.com.cn
高階會員 發表:168 回覆:359 積分:130 註冊:2004-03-26 發送簡訊給我 |
|
yachanga
資深會員 發表:24 回覆:335 積分:296 註冊:2003-09-27 發送簡訊給我 |
|
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
sl@cableplus.com.cn
高階會員 發表:168 回覆:359 積分:130 註冊:2004-03-26 發送簡訊給我 |
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi minibaby: 一個想法,概念來自 http://delphi.ktop.com.tw/topic.php?topic_id=42148 事實上,與 sl@cableplus.com.cn 大大的想法不謀而合
Sample 見以下連結 http://delphi.ktop.com.tw/loadfile.php?TOPICID=16305122&CC=364658 ----------------------------------
小弟才疏學淺,若有謬誤尚請不吝指教
----------------------------------
------
Fishman |
葡萄糖
一般會員 發表:5 回覆:18 積分:4 註冊:2003-11-20 發送簡訊給我 |
這個問題剛好我日前有遇到
我是這樣用的(運用每個定單不同)
Query2BDEDesigner.AsVariant 是group -> Expression 的值
Q2Pb : Integer ;
Q2Pa = Query2BDEDesigner.AsVariant procedure TFED02F.QuickRep3StartPage(Sender: TCustomQuickRep);
begin
if Q2Pa = Query2BDEDesigner.AsVariant then Q2Pb := Q2Pb 1 (一樣加1)
else
begin
Q2Pb := 1 ; (不同時已換一個訂單)
end ;
QRLabel1.Caption := Q2Pb ;
Q2Pa = Query2BDEDesigner.AsVariant (剛剛放錯)
end ; 好像複雜點..
不知其他大大有沒有更有的方法 發表人 - 葡萄糖 於 2004/06/23 12:50:05
|
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
jasonma168
一般會員 發表:39 回覆:33 積分:14 註冊:2002-05-24 發送簡訊給我 |
|
delphiwww
資深會員 發表:145 回覆:363 積分:368 註冊:2002-03-13 發送簡訊給我 |
你的問題我認為解法如下:(我也沒有try,不過應該沒錯)
1.設定一個全域的counter array
2.使用prepare,主要是因為,在prepare後,所有的資料及Event都會跑一便,
同時假如你資料尚未顯示的話,計算起來很快
3.設定一個boolean變數用來區分目前是prepare,還是preview or print
4.當為prepare時,將group計算的頁數填入counter array中
5.當preview or print時,將counter array中的資料顯示在qrlabel上面
引言: 到底要怎樣才能得到每個group正確的總頁數呢??我現在是先用query先找出每一類的資料筆數 某個欄位長度大於40(因為要折成兩行)的筆數,然後在除以detailband可印的筆數..但是這樣會跟報表自己印出來的有差距...detailband印的行數好像也沒那麼固定,有什麼好方法呢?? |
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
jumo
一般會員 發表:33 回覆:65 積分:24 註冊:2002-04-17 發送簡訊給我 |
|
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
|
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
Hi minibaby, 事實上用 ClientDataSet 與 Query 是大小異的,用 ClientDataSet 只是方便範例程式而已,你只要改成
procedure TForm1.Button2Click(Sender: TObject); begin Query1.Close; Query1.ParamByName('參數一').AsString := '參數值一'; Query1.ParamByName('參數二').AsString := '參數值二'; Query1.ParamByName('參數三').AsString := '參數值三'; Query1.Open; PageCount1.Clear; PageCount := 0; CurrentGroup := 0; PreviewFlag := False; QuickRep1.Prepare; PageCount := 0; CurrentGroup := 0; PageCount2.Assign(PageCount1); PreviewFlag := True; QuickRep1.Preview; end;即可 ---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman |
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
|
Fishman
尊榮會員 發表:120 回覆:1949 積分:2163 註冊:2006-10-28 發送簡訊給我 |
|
minibaby
一般會員 發表:2 回覆:15 積分:3 註冊:2004-06-08 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |