SPREAD for Windows Forms 10.0J サンプルコード集
階層表示時に子階層部を取得/印刷する

SheetViewクラスのGetChildViewメソッド呼び出しにより、指定した親行に関連付けられている子階層シートビューを取得することで印刷可能となります。但し、それぞれの子階層が展開されたイメージのまま印刷することはできません。 (アクティブシートを指定したPrintSheetメソッド呼び出しによる印刷では親階層のみ出力されます)

【実行例】

印刷シート

印刷プレビュー

印刷プレビュー

  • SPREAD for Windows Formsにおける印刷処理は製品独自のものではなく、.NET Frameworkによって提供されている各印刷処理を用いてその機能を実現しています。
  • 出力結果はご利用のプリンタドライバに依存します。(実際の印刷/印刷プレビュー画面における出力結果の相違や、異なるプリンタ間における出力結果の相違を吸収するような機能はありません)

 private void Form1_Load(object sender, System.EventArgs e)
 {

   DataSet ds = new DataSet();
   DataTable fpParent = new DataTable();
   DataTable fpChild1 = new DataTable();

   fpParent = ds.Tables.Add("SAMPLE");
   fpParent.Columns.AddRange(new DataColumn[] {new DataColumn("Column1", Type.GetType("System.String")), new DataColumn("Column2", Type.GetType("System.Int32"))});
   fpParent.Rows.Add(new object[] {"親1", 0});
   fpParent.Rows.Add(new object[] {"親2", 1});

   fpChild1 = ds.Tables.Add("Child1");
   fpChild1.Columns.AddRange(new DataColumn[] {new DataColumn("Column1", Type.GetType("System.String")), new DataColumn("Column2", Type.GetType("System.Int32"))});
   fpChild1.Rows.Add(new object[] {"子1-1", 0});
   fpChild1.Rows.Add(new object[] {"印刷する子階層シート", 1});

   ds.Relations.Add("Relation1", fpParent.Columns["Column2"], fpChild1.Columns["Column2"]);

   fpSpread1.ActiveSheet.DataSource = ds;

   //全ての階層を展開します
   fpSpread1.ActiveSheet.ExpandRow(0, true);
   fpSpread1.ActiveSheet.ExpandRow(1, true);

 }

 private void button1_Click(object sender, System.EventArgs e)
 {

   //2行目に関連付けられている子階層シートビューを取得します
   FarPoint.Win.Spread.SheetView csv = fpSpread1.ActiveSheet.GetChildView(1, 0);

   if (csv != null)
   {
      //印刷プレビュー画面を表示します
      csv.PrintInfo.Preview = true;

      //取得した子階層シートビューを印刷します
      fpSpread1.PrintSheet(csv);
   }

 }

 private void fpSpread1_PrintPreviewShowing(object sender, FarPoint.Win.Spread.PrintPreviewShowingEventArgs e)
 {

   //表示倍率150%で印刷プレビュー画面を表示します
   e.PreviewControl.Zoom = 1.5;

 }
 Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles MyBase.Load

   Dim ds As New DataSet
   Dim fpParent As DataTable
   Dim fpChild1 As DataTable

   fpParent = ds.Tables.Add("SAMPLE")
   fpParent.Columns.AddRange(New DataColumn() {New DataColumn("Column1", Type.GetType("System.String")), New DataColumn("Column2", Type.GetType("System.Int32"))})
   fpParent.Rows.Add(New Object() {"親1", 0})
   fpParent.Rows.Add(New Object() {"親2", 1})

   fpChild1 = ds.Tables.Add("Child1")
   fpChild1.Columns.AddRange(New DataColumn() {New DataColumn("Column1", Type.GetType("System.String")), New DataColumn("Column2", Type.GetType("System.Int32"))})
   fpChild1.Rows.Add(New Object() {"子1-1", 0})
   fpChild1.Rows.Add(New Object() {"印刷する子階層シート", 1})

   ds.Relations.Add("Relation1", fpParent.Columns("Column2"), fpChild1.Columns("Column2"))

   FpSpread1.ActiveSheet.DataSource = ds

   '全ての階層を展開します
   FpSpread1.ActiveSheet.ExpandRow(0, True)
   FpSpread1.ActiveSheet.ExpandRow(1, True)

 End Sub

 Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click

   '2行目に関連付けられている子階層シートビューを取得します
   Dim csv As FarPoint.Win.Spread.SheetView = FpSpread1.ActiveSheet.GetChildView(1, 0)

   If Not (csv Is Nothing) Then

      '印刷プレビュー画面を表示します
      csv.PrintInfo.Preview = True

      '取得した子階層シートビューを印刷します
      FpSpread1.PrintSheet(csv)

   End If

 End Sub

 Private Sub FpSpread1_PrintPreviewShowing(ByVal sender As Object, ByVal e As FarPoint.Win.Spread.PrintPreviewShowingEventArgs) Handles FpSpread1.PrintPreviewShowing

   '表示倍率150%で印刷プレビュー画面を表示します
   e.PreviewControl.Zoom = 1.5

 End Sub

 

 


© 2004-2017, GrapeCity inc. All rights reserved.