赤い線が表示される
プレビュー時の赤い線は、指定された用紙の幅を示します。指定された用紙の幅よりも、レポート全体の幅が大きい場合に、プレビュー時に赤い線が表示されます。
この赤い線を消すには、レポートの幅(ActiveReportオブジェクトのPrintWidthプロパティ)と左右のマージン(PageSettingsオブジェクトのMargins.Left,Margins.Rightプロパティ)および、とじしろ(PageSettingsオブジェクトのGutterプロパティ)を足した値が、用紙の幅(PrinterオブジェクトのPaperWidthプロパティまたはPaperHeightプロパティ)を超えないようにする必要があります。
つまり、「PageSettings.Margins.Left + PageSettings.Margins.Right + PageSettings.Gutter + PrintWidth <= Document.Printer.PaperWidth(Document.Printer.PaperHeight)」の関係を守る必要があります。
下記の何れかの方法で指定してください。
以下のサンプルコードでは、レポートの幅(PrintWidthプロパティ)を、用紙の向きやマージンおよびとじしろに合わせて調整しています。
Visual Basic
| Visual Basicコード | 
                                コードのコピー
                             | 
|---|---|
| 
Private Sub SectionReport1_ReportStart(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.ReportStart
    If Me.PageSettings.Orientation = PageOrientation.Landscape Then
       ' 用紙が横方向の場合
        Me.PrintWidth = Me.Document.Printer.PaperHeight _
            - (Me.PageSettings.Margins.Left + Me.PageSettings.Margins.Right + Me.PageSettings.Gutter)
    Else
       ' 用紙が縦方向の場合
        Me.PrintWidth = Me.Document.Printer.PaperWidth _
            - (Me.PageSettings.Margins.Left + Me.PageSettings.Margins.Right + Me.PageSettings.Gutter)
    End If
End Sub
 | |
C#
| C#コード | 
                                コードのコピー
                             | 
|---|---|
| 
private void SectionReport1_ReportStart(object sender, EventArgs e)
{
    if (this.PageSettings.Orientation == PageOrientation.Landscape)
    {
        // 用紙が横方向の場合
        this.PrintWidth = this.Document.Printer.PaperHeight
            - (this.PageSettings.Margins.Left + this.PageSettings.Margins.Right + this.PageSettings.Gutter);
    }
    else
    {
        // 用紙が縦方向の場合
        this.PrintWidth = this.Document.Printer.PaperWidth 
            - (this.PageSettings.Margins.Left + this.PageSettings.Margins.Right + this.PageSettings.Gutter);
    }
}
 | |
レポートを生成しながらプレビューする
ViewerのDocumentプロパティにレポートのDocumentインスタンスを設定した上で、Run(True)を実行すると、生成されたページから順次プレビューすることが可能です。
Visual Basic
| Visual Basicコード | 
                                コードのコピー
                             | 
|---|---|
| 
Dim rpt As New SectionReport1
Viewer1.Document = rpt.Document
rpt.Run(True)
                                        
 | |
C#
| C#コード | 
                                コードのコピー
                             | 
|---|---|
| 
SectionReport1 rpt = new SectionReport1();
this.viewer1.Document = rpt.Document;
rpt.Run(true);
                                                
 | |
ただし、生成されたページから順次プレビューする処理を、FormのLoadイベントで実装する場合は注意が必要です。LoadイベントがRunメソッドの完了まで継続し、この間の画面表示が更新されません。このため、Run(True)を実行しても、ビューワに順次レポートが表示されることはありません。
FormのLoadイベントを利用する場合、以下のような方法が考えられます。
Visual Basic
| Visual Basicコード | 
                                        コードのコピー
                                     | 
|---|---|
| Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load Dim thread As New System.Threading.Thread( _ New System.Threading.ThreadStart(AddressOf Thread1)) thread.IsBackground = True thread.SetApartmentState(Threading.ApartmentState.STA) thread.Start() End Sub Delegate Sub CreateReportDelegate() Private Sub CreateReport() Dim rpt As New SectionReport1 Viewer1.Document = rpt.Document rpt.Run(True) End Sub Private Sub Thread1() Me.Viewer1.Invoke(New CreateReportDelegate(AddressOf CreateReport)) End Sub | |
C#
| C#コード | 
                                        コードのコピー
                                     | 
|---|---|
| 
private void Form1_Load(object sender, System.EventArgs e)
{
   System.Threading.Thread thread =
     new System.Threading.Thread(new System.Threading.ThreadStart(Thread1));
   thread.IsBackground = true;
   thread.SetApartmentState(System.Threading.ApartmentState.STA);
   thread.Start();
}
delegate void CreateReportDelegate();
private void CreateReport()
{
  SectionReport1 rpt = new SectionReport1();
  this.viewer1.Document = rpt.Document;
  rpt.Run(true);
}
void Thread1()
{
  this.viewer1.Invoke(new CreateReportDelegate(CreateReport));
}
 | |
Visual Basic
| Visual Basicコード | 
                                        コードのコピー
                                     | 
|---|---|
| 
Private timer As New Timer()
Private Sub Form1_Load(ByVal sender As Object, ByVal e As EventArgs) Handles MyBase.Load
    ' タイマ・メソッドの作成します。
    AddHandler timer.Tick, New EventHandler(AddressOf CreateReport)
    timer.Interval = 100
    ' Loadイベントが終了してから0.1秒後にレポートを生成します。
    timer.Enabled = True
End Sub
Private Sub CreateReport(ByVal sender As Object, ByVal e As EventArgs)
     ' タイマ・メソッドが今後発生しないようにします。
     timer.Enabled = False
     ' レポート生成処理。
     Dim rpt As New SectionReport1()
     Me.viewer1.Document = rpt.Document
     rpt.Run(True)
End Sub
                                                                
 | |
C#
| C#コード | 
                                        コードのコピー
                                     | 
|---|---|
| 
private Timer timer = new Timer();
private void Form1_Load(object sender, System.EventArgs e)
{
  // タイマ・メソッドの作成します。
   timer.Tick += new EventHandler(CreateReport);
                                 timer.Interval = 100;
   // Loadイベントが終了してから0.1秒後にレポートを生成します。 | |
.NET Coreデスクトップアプリにおいて、Windowsフォーム用ビューワまたはWPFビューワでスクリプトを含むセクションレポートをプレビューする時、System.NotSupportedException例外が発生する
.NET Coreデスクトップアプリでは、Windowsフォーム用ビューワまたはWPFビューワを使用してスクリプトを含むセクションレポートをプレビューする時、「System.NotSupportedException:1252のエンコードに使用できるデータはありません。」例外が発生します。カスタムエンコーディングを定義する方法については、Encoding.RegisterProviderメソッドを参照してください。
これは、Windowsフォーム用ビューワ、WPFビューワ、およびデザイナを組み込んだ.NET Coreアプリケーションを使用する前に、エンコーディングを登録しないことに関連して発生します。
この事象を回避するには、以下の設定を行ってください。
| 
                                    コードのコピー
                                 | |
|---|---|
| static void Main() { System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); Application.Run(new DesignerForm()); } | |
セクションレポート(コード)をプレビューする時、「同じID 'System.ValueTupple'のアセンブリが既にインポートされています。」エラーが発生します。
Visual Studio 2013でセクションレポート(コード)をプレビューする場合、「同じID 'System.ValueTupple'のアセンブリが既にインポートされています。重複している参照の一方を削除してください。」例外が発生します。
これは、Visual Studio 2013で、プロジェクトのターゲットが.NET Framework 4.6.2より新しいバージョンの場合、System.ValueTupleが2回追加されるために発生しています。
この事象を回避するには、ターゲットのバージョンを4.6.2に変更して、重複する参照の一方を削除してください。なお、その後、レポートをプレビューすると、「<ファイル>をコピーできませんでした」というエラーが表示される場合があります。これを解決するには、Visual Studioを再起動する必要があります。