FastReport.Net

来源:https://www.cnblogs.com/geovindu/archive/2018/05/25/9088311.html
-Advertisement-
Play Games

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.... ...


using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using FastReport;
using FastReport.Data;
using FastReport.Editor;
using FastReport.Design;
using FastReport.Data.ConnectionEditors;
using FastReport.Forms;
using FastReport.Utils;
using FastReport.Table;
using System.Data.SqlClient;

namespace DataFromArray
{
    /// <summary>
    /// 
    /// </summary>
  public partial class Form1 : Form
  {



    private int[] FArray;

    TableObject Table1 = new TableObject();
    Report report = new Report();
      /// <summary>
      /// 
      /// </summary>
      /// <returns></returns>
      DataSet  bindDB()
     {
         DataSet ds = new DataSet();
        DataTable dt = new DataTable();
        dt.TableName = "Db";
        dt.Columns.Add("id", typeof(int));
        dt.Columns.Add("cnname", typeof(string));
        dt.Columns.Add("bithdate", typeof(DateTime));
        dt.Columns.Add("age", typeof(int));

        dt.Rows.Add(1, "geovindu", "2001-12-03",12);
        dt.Rows.Add(2, "sibodu", "2001-12-03",13);
        dt.Rows.Add(3, "ginhongzhao", "2001-12-03",15);
        ds.Tables.Add(dt);
        return ds;
     }
    



    
      /// <summary>
      /// 
      /// </summary>
    public Form1()
    {
      InitializeComponent();
      Table1.ManualBuild += new System.EventHandler(Table1_ManualBuild);
      CreateArray();
    }
    /// <summary>
    /// 
    /// </summary>
    private void CreateArray()
    {
      FArray = new int[10];
      for (int i = 0; i < 10; i++)
      {
        FArray[i] = i + 1;
      }
    }
    /// <summary>
    /// 
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private void btnCreateNew_Click(object sender, EventArgs e)
    {
      // create report instance
      Report report = new Report();

      // register the array
      report.RegisterData(FArray, "Array");

      // design the report
      report.Design();

      // free resources used by report
      report.Dispose();
    }
    /// <summary>
    /// 
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private void btnRunExisting_Click(object sender, EventArgs e)
    {
      // create report instance
      Report report = new Report();



      string fileurl = @"..\..\report.frx";
      // load the existing report
      report.Load(fileurl);

      // register the array
      //report.RegisterData(FArray, "Array");
      report.RegisterData(FArray, "Db");
       
      // run the report
      report.Show();

      // free resources used by report
      report.Dispose();
    }

    private void Form1_Load(object sender, EventArgs e)
    {

    }
    /// <summary>
    /// 
    /// 自定義
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private void button1_Click(object sender, EventArgs e)
    {
        try 
        {

            
            //DataTable dd = bindDB().Tables["Db"];
            report.RegisterData(bindDB().Tables["Db"], "Db");
            report.GetDataSource("Db").Enabled = true;

            ReportPage page1 = new ReportPage();
            page1.Name = "page1";
            report.Pages.Add(page1);

            page1.ReportTitle = new ReportTitleBand();
            page1.ReportTitle.Name = "ReportTitle1";
            page1.ReportTitle.Height = Units.Centimeters*1.5f;


            ReportPage page2 = new ReportPage();
            page2.Name = "page2";
            page2.ReportTitle = new ReportTitleBand();
            page2.ReportTitle.Name = "ReportTitle2";
            page2.ReportTitle.Height = Units.Centimeters * 1.5f;
            report.Pages.Add(page2);


            GroupHeaderBand group1 = new GroupHeaderBand();
            group1.Height = Units.Centimeters * 1;
            group1.Name = "GroupHeader1";
            group1.Condition = "[Db.cnname]"; //表.欄位名       
            page1.Bands.Add(group1);

            group1.GroupFooter = new GroupFooterBand();
            group1.GroupFooter.Name = "GroupFooter1";
            group1.GroupFooter.Height = Units.Centimeters * 1;

            //create databand
            DataBand data1 = new DataBand();
            data1.Name = "Data1";
            data1.Height = Units.Centimeters * 0.5f;
            data1.DataSource = report.GetDataSource("Db");
            group1.Data = data1;
      
              //
            TextObject txt1 = new TextObject();
            txt1.Name = "txt1";
            txt1.Bounds = new RectangleF(0, 0, Units.Centimeters * 19, Units.Centimeters * 1);
            txt1.HorzAlign = HorzAlign.Center;
            txt1.Font = new Font("宋體", 14, FontStyle.Bold);
            txt1.Text = "DB 數據";
            page1.ReportTitle.Objects.Add(txt1);

             //group
            TextObject txt2 = new TextObject();
            txt2.Name = "txt2";
            txt2.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            txt2.HorzAlign = HorzAlign.Center;
            txt2.Font = new Font("宋體", 8, FontStyle.Bold);//Tahoma
            txt2.Text = "[Db.cnname]";
            group1.Objects.Add(txt2);

            //data band
            TextObject txt3 = new TextObject();
            txt3.Name = "txt3";
            txt3.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            txt3.HorzAlign = HorzAlign.Center;
            txt3.Font = new Font("宋體", 8, FontStyle.Bold);
            txt3.Text = "[Db.cnname]";
            data1.Objects.Add(txt3);
            TextObject txt4 = new TextObject();
            txt4.Name = "txt4";
            txt4.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            txt4.HorzAlign = HorzAlign.Center;
            txt4.Font = new Font("宋體", 8, FontStyle.Bold);
            txt4.Text = "[Db.age]";
            group1.GroupFooter.Objects.Add(txt4);



            
            DataSourceBase masterData = report.GetDataSource("Db");
            masterData.Init();


            //TableColumn cm = new TableColumn();
            //cm.Name = "";
            //TableColumn column = new TableColumn();
            //column.Name = "column";
            //column.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            //column.Height = Units.Centimeters * 2.5f;          
            //Table1.Columns.Add(column);


            //TableColumn column2 = new TableColumn();
            //column2.Name = "Cell2";

            //column2.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            //column2.Height = Units.Centimeters * 2.5f;
            //Table1.Columns.Add(column2);

            //Table1.Border.RightLine = BorderLines.Right;
            Table1.ColumnCount = 2;
            Table1.Border.LeftLine.Color = Color.Black;

            Table1.Border.Lines = BorderLines.None;
            Table1.Border.TopLine.Color = Color.Black;
            Table1.Border.TopLine.Width = 1;

            Table1.Border.ShadowWidth = 4;
            Table1.Border.RightLine.Style = FastReport.LineStyle.Solid;// 

            TableCell cell = new TableCell();
            cell.Name = "Cell1";
            cell.Text = "Name";
            cell.Font = new Font("宋體", 8, FontStyle.Bold);
            cell.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            cell.Height = Units.Centimeters * 2.5f;
            Table1.Columns.Add(cell);

            TableCell cell2 = new TableCell();
            cell2.Name = "Cell2";
            cell2.Text = "Id";
            cell2.Font = new Font("宋體", 8, FontStyle.Bold);
            cell2.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            cell2.Height = Units.Centimeters * 2.5f;
            Table1.Columns.Add(cell2);

            TableCell cell3 = new TableCell();
            cell3.Name = "cell3";
            cell3.Text = "[Db.cnname]";
            cell3.Font = new Font("宋體", 8, FontStyle.Bold);
            cell3.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            cell3.Height = Units.Centimeters * 2.5f;
            Table1.Rows.Add(cell3);

            TableCell cell4 = new TableCell();
            cell4.Name = "cell4";
            cell4.Text = "[Db.id]";
            cell4.Font = new Font("宋體", 8, FontStyle.Bold);
            cell4.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            cell4.Height = Units.Centimeters * 2.5f;
            Table1.Rows.Add(cell4);



            //TableRow rw = new TableRow();



            //while (masterData.HasMoreRows)
            //{
            //    TableCell cell = new TableCell();
            //    cell.Name = "Cell1";
            //    cell.Text = "[Db.cnname]";
            //    cell.Font = new Font("宋體", 8, FontStyle.Bold);
            //    cell.Bounds = new RectangleF(0, 0, Units.Centimeters * 2, Units.Centimeters * 1);
            //    cell.Height = Units.Centimeters * 2.5f;
            //    Table1.Rows.Add(cell);
 
            //    masterData.Next();
            //}

            //page2.Bands.Add(Table1);
            page2.ChildObjects.Add(Table1);

   

            report.Show();

        }
        catch(Exception ex)
        {
            ex.Message.ToString();
        }

    }
    /// <summary>
    /// 
    /// </summary>
    /// <param name="sender"></param>
    /// <param name="e"></param>
    private void Table1_ManualBuild(object sender, EventArgs e)
    {

        DataSourceBase data1 = report.GetDataSource("Db"); // 獲取DataSet中表名為Table1的數據源
        data1.Init(); // 初始化
        Table1.PrintRow(0); // 控制項Table1列印第0行
        Table1.PrintColumns(); // 每列印一行,都要調用 PrintColumn或PrintColumns
        while (data1.HasMoreRows) // 列印重覆迴圈的行
        {
            Table1.PrintRow(1);
            Table1.PrintColumns();
            data1.Next(); // 讀取下一行
        }
    }
/// <summary>
/// 
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
    private void button2_Click(object sender, EventArgs e)
    {
        Report report = new Report();

        string sql = "select top 2 * from Employee";
        DataTable dt = null;

        dt = DBHelper.GetTable(sql, CommandType.Text, null);

        string fileurl = @"..\..\report2.frx";
        // load the existing report
        report.Load(fileurl);
       // report.Design();
        report.RegisterData(dt, "Employee");

        // run the report   
        report.Show();

        // free resources used by report
        //report.Dispose();
    }

  }
}

  


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 現有一份血壓數據,樣本記錄500條數據,包括三個值:血壓、是否抽煙、體重過重級別。 數據樣例: 血壓數據的可視化和分析(1)—— 利用 Excel 查看數據概況 在 Excel 中,利用散點圖首先對這三列數據進行可視化,瞭解數據分佈的概況。 可見收縮壓數據在250左右有一個明顯的分界,之前的數據都在 ...
  • 今天和大家分享的是自定義配置信息的讀取;近期有寫博客這樣的計劃,分別交叉來寫springboot方面和springcloud方面的文章,因為springboot預計的篇章很多,這樣cloud的文章就需要等到很後面才能寫了;分享這兩種文章的原因主要是為了方便自己查找資料使用和對將要使用的朋友起到便捷作 ...
  • maven作為一個項目構建工具,在開發的過程中很受歡迎,可以幫助管理項目中的bao依賴問題,另外它的很多功能都極大的減少了開發的難度,下麵來介紹maven的安裝及與eclipse的集成。 maven的官網地址為:http://maven.apache.org/ 下載步驟如下: 進入官網,點擊下載 進 ...
  • PHP匿名函數和閉包 匿名函數[官方文檔][2] 本篇文章的代碼測試使用的是[php線上測試工具][1]5.6 匿名函數 匿名函數就是沒有定義函數名的函數,php從5.3版本開始支持匿名函數 php ...
  • #coding:utf-8import random,stringdef GetPassword(length): # 隨機生成數字個數 Ofnum=random.randint(1,length) Ofletter=length-Ofnum # 選中ofnum個數字 slcNum=[random. ...
  • 隱藏圖不是什麼新鮮的東西,具體表現在大部分社交軟體中,預覽圖看到的是一張圖,而點開後看到的又是另一張圖。雖然很早就看到過這類圖片,但是一直沒有仔細研究過它的原理,今天思考了一下,發現挺有趣的,所以自己也寫了個簡單的演算法把兩張圖片合成為一張隱藏圖。 比如下麵這張圖。 當背景顏色為白色時,通常也就是在預 ...
  • 準備工作: 建立.NET Core Web Api項目 新建一個用於Api請求的UserInfo類 2、建立.NET Core Web項目 一、使用jQuery Ajax訪問 (一)、表單 [FromForm] 數據類型:Object ContenyType類型:application/x-www- ...
  • 這是一個ASP.NET Core2.0專題文章列表 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...