.NET使用報(bào)表工具FastReport實(shí)現(xiàn)打印功能
FastReport是功能非常強(qiáng)大的報(bào)表工具,在本篇文章中講解如何使用FastReport實(shí)現(xiàn)打印功能。
一、新建一個(gè)窗體程序,窗體上面有設(shè)計(jì)界面和預(yù)覽界面兩個(gè)按鈕,分別對(duì)應(yīng)FastReport的設(shè)計(jì)和預(yù)覽功能,其實(shí)現(xiàn)代碼如下:
using FastReport; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Data.SqlClient; using System.Drawing; using System.IO; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using Dapper; namespace FastReportDemo { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void btn_Design_Click(object sender, EventArgs e) { // 顯示設(shè)計(jì)界面 CreateReport(true); } private void CreateReport(bool tfDesigin) { // 獲得當(dāng)前程序的運(yùn)行路徑 string path = Application.StartupPath; // 定義報(bào)表 Report report = new Report(); string strDirectory = path + "\\ReportFiles"; // 判斷文件路徑是否存在,不存在則創(chuàng)建文件夾 if (!Directory.Exists(strDirectory)) { // 不存在就創(chuàng)建目錄 Directory.CreateDirectory(strDirectory); } // 判斷文件是否存在 if (!File.Exists(strDirectory + "\\產(chǎn)品明細(xì).frx")) { report.FileName = strDirectory + "\\產(chǎn)品明細(xì).frx"; } else { report.Load(strDirectory + "\\產(chǎn)品明細(xì).frx"); } // 創(chuàng)建報(bào)表文件的數(shù)據(jù)源 DataSet ds = new DataSet(); DataTable dt = GetDataSource(); DataTable dtSource = dt.Copy(); dtSource.TableName = "ProductDetail"; ds.Tables.Add(dtSource); report.RegisterData(ds); if (tfDesigin) { // 打開設(shè)計(jì)界面 report.Design(); } else { // 打開預(yù)覽界面 report.Show(); } } private DataTable GetDataSource() { DataTable dt = new DataTable(); // 數(shù)據(jù)庫(kù)連接 string strCon = @"Initial Catalog=StudentSystem; Integrated Security=False;User Id=sa;Password=1qaz@WSX;Data Source=127.0.0.1;Failover Partner=127.0.0.1;Application Name=TransForCCT"; SqlConnection conn = new SqlConnection(strCon); string strSql = @"SELECT p.ProductId,p.ProductName,p.Price,c.CategoryName FROM ProductDetail p INNER JOIN Category c ON p.CategoryId=c.CategoryId"; // 使用Dapper獲取數(shù)據(jù) IDataReader reader = conn.ExecuteReader(strSql); dt.Load(reader); return dt; } private void btn_Show_Click(object sender, EventArgs e) { // 顯示預(yù)覽界面 CreateReport(false); } } }
二、運(yùn)行程序,點(diǎn)擊設(shè)計(jì)界面,打開FastReport的設(shè)計(jì)界面:
三、選擇數(shù)據(jù)源
在設(shè)計(jì)之前要先選擇數(shù)據(jù)源,只有選擇了數(shù)據(jù)源,報(bào)表文件才會(huì)有數(shù)據(jù)。
1、在Data文件夾下面選擇“Choose Report Data”選項(xiàng):
2、在Choose Report Data界面選擇程序中要用到的數(shù)據(jù)源:
3、點(diǎn)擊“OK”按鈕以后,在設(shè)計(jì)界面的右側(cè)會(huì)顯示選擇的數(shù)據(jù)源:
四、報(bào)表的整體結(jié)構(gòu):
五、設(shè)計(jì)報(bào)表標(biāo)題
1、設(shè)計(jì)報(bào)表標(biāo)題要使用到“A”控件:
2、將左側(cè)的"A"控件拖拽到報(bào)表標(biāo)題區(qū)域:
3、設(shè)置標(biāo)題:
雙擊報(bào)表標(biāo)題區(qū)域的A控件,即可打開輸入標(biāo)題的界面:
4、輸入報(bào)表標(biāo)題,點(diǎn)擊“OK”按鈕:
報(bào)表標(biāo)題區(qū)域就會(huì)顯示設(shè)計(jì)的標(biāo)題,并可以設(shè)置標(biāo)題的對(duì)齊方式。
六:設(shè)計(jì)報(bào)表數(shù)據(jù)區(qū)域
1、設(shè)計(jì)報(bào)表數(shù)據(jù),要使用到表格控件,表格控件如下圖所示:
2、將表格拖拽到數(shù)據(jù)區(qū)域,設(shè)計(jì)表格要顯示的行數(shù)和列數(shù):
3、表格顯示的內(nèi)容:
4、表格界面:
七、設(shè)置表格事件
給表格添加數(shù)據(jù)綁定事件:
設(shè)置了事件以后,雙擊事件即可進(jìn)入代碼編輯界面,綁定事件的代碼如下:
using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Windows.Forms; using System.Drawing; using System.Data; using FastReport; using FastReport.Data; using FastReport.Dialog; using FastReport.Barcode; using FastReport.Table; using FastReport.Utils; namespace FastReport { public class ReportScript { private void Table1_ManualBuild(object sender, EventArgs e) { // 設(shè)置數(shù)據(jù)源 DataSourceBase rowData = Report.GetDataSource("ProductDetail"); rowData.Init(); Table1.PrintRow(0); Table1.PrintColumns(); bool tfvar = false; while (rowData.HasMoreRows) { tfvar = true; Table1.PrintRow(1); Table1.PrintColumns(); rowData.Next(); } if (!tfvar) { Table1.PrintRow(2); Table1.PrintColumns(); } } } }
八、頁(yè)腳顯示打印時(shí)間:
九、保存報(bào)表格式
設(shè)計(jì)完報(bào)表格式以后,一定要記得保存:
十、效果
因?yàn)榻缑嫣?,所以分了兩個(gè)截圖顯示:
到此這篇關(guān)于.NET使用報(bào)表工具FastReport實(shí)現(xiàn)打印功能的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
EntityFramework 6.x學(xué)習(xí)之多個(gè)上下文遷移實(shí)現(xiàn)分布式事務(wù)詳解
這篇文章主要給大家介紹了關(guān)于EntityFramework 6.x學(xué)習(xí)之多個(gè)上下文遷移實(shí)現(xiàn)分布式事務(wù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10基于?.NET?6?的ASP.NET?Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序
這篇文章主要介紹了ASP.NET?Core啟動(dòng)地址配置方法及優(yōu)先級(jí)順序,?.NET?6?使用了最小?WEB?API,?配置方式已經(jīng)部分發(fā)生了變化,下面文章我們來(lái)看看具體的方法,需要的小伙伴可以參考一下2022-03-03如此高效通用的分頁(yè)存儲(chǔ)過(guò)程是帶有sql注入漏洞的zt
通常大家都會(huì)認(rèn)為存儲(chǔ)過(guò)程可以避免sql注入的漏洞,這適用于一般的存儲(chǔ)過(guò)程,而對(duì)于通用分頁(yè)存儲(chǔ)過(guò)程是不適合的,請(qǐng)看下面的代碼和分析!2010-07-07asp.net+ajax+sqlserver自動(dòng)補(bǔ)全功能實(shí)現(xiàn)解析
這篇文章主要介紹了asp.net + ajax + sqlserver 自動(dòng)補(bǔ)全功能,需要的朋友可以參考下2014-03-03如何使用pm2守護(hù)你的.NET Core應(yīng)用程序詳解
pm2是nodejs的一個(gè)帶有負(fù)載均衡功能的應(yīng)用進(jìn)程管理器的模塊,下面這篇文章主要給大家介紹了關(guān)于如何使用pm2守護(hù)你的.NET Core應(yīng)用程序的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-10-10ASP.NET?Core?6框架揭秘實(shí)例演示之如何承載你的后臺(tái)服務(wù)
這篇文章主要介紹了ASP.NET?Core?6框架揭秘實(shí)例演示之如何承載你的后臺(tái)服務(wù),主要包括利用承載服務(wù)收集性能指標(biāo)、依賴注入的應(yīng)用、配置選項(xiàng)的應(yīng)用等知識(shí)點(diǎn),本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03