So-net無料ブログ作成
検索選択

ActiveReportsのページフッタにページ番号を印字する [ActiveReports]

----------------------------------------------------------
(開発・実行環境)

Microsoft Visual Studio 2005 Tools for Applications

Microsoft Visual Basic 2005

ActiveReports 2.0J Standard

----------------------------------------------------------

 

 作成したレポートのページフッタに、「現在ページ/総ページ」を尋常に出力する場合は、以下のコードをレポートの作成する最初(ReportStartイベントとか)に宣言し、TextBoxに適用すればいいらしい。

(今回はやってないから知らんけど)

    'カレントページ数
    Me.txtPage.SummaryRunning = SummaryRunning.All
    Me.txtPage.SummaryType = SummaryType.PageCount
    '総ページ数
    Me.txtPages.SummaryRunning = SummaryRunning.None
    Me.txtPages.SummaryType = SummaryType.PageCount
 

 

今回やろうとしたのは、作成するレポートの中でも、キー項目が変更されたら改ページして、ページ番号を1にリセットする、というもの。

つまり、レポートで出力するページ数が10ページあっても、毎ページキー項目が変更になったら、全てのページ番号が1となるし、10ページ全て同じキー項目であれば、1~10を振る、ということ。

総ページの出力はしなかった。

 

ActiveReportsに出力するデータを格納した配列の、各レコードにページ番号も持たせ、DataInitializeイベントでアンバウンドフィールド(バウンドフィールド? ごめんなさい、よく言葉を知らない。。)を作ってレポート上のTextBoxと紐付け。

FetchDataイベントで配列の値をバウンドフィールドに当てるという、データの出力方法と同様に、ページ番号もページフッタに出力しようと試みた。

 

・・・が、配列のデータは正しく作れているのに、ページ番号がズレて表示される。。。

 

どうもページヘッダ・フッタには、変化するデータの値を使ってはいけないらしい。。。

http://www.atmarkit.co.jp/bbs/phpBB/viewtopic.php?topic=37912&forum=7

https://www.grapecity.com/Japan/Support/Search/FaqContent.asp?id=13371

 

Detailやグループヘッダ・フッタと違って、ページヘッダは配列がまわる度に値を入れてくれないらしい。。

グループフッタにすると、1ページ目と2ページ目以降で出力位置がビミョーに変わるからそこに置きたくなく。。。 (レイアウトが変わるので)

 

あまりきれいな方法じゃないんだろうけど、DetailFormatイベントで、新しいページに変わるときに(If文による制御)、ページ番号のTextBoxのTextプロパティに、配列の値を入れていくことにした。

 

でも今回これで完成でもないし、どうなることやら。。

 他にいい方法知ってる方いたら教えてください。

(その前に拙い文章ですいません。。)

 

ActiveReports・・・

クリレポと全然違うし、難しいな~。。


nice!(0)  コメント(0)  トラックバック(0) 

nice! 0

コメント 0

コメントを書く

お名前:
URL:
コメント:
画像認証:
下の画像に表示されている文字を入力してください。

トラックバック 0

この広告は前回の更新から一定期間経過したブログに表示されています。更新すると自動で解除されます。

×

この広告は1年以上新しい記事の更新がないブログに表示されております。