.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ù)庫連接
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();
}
}
}
}八、頁腳顯示打印時(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)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們隨著小編來一起學(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ā)生了變化,下面文章我們來看看具體的方法,需要的小伙伴可以參考一下2022-03-03
如此高效通用的分頁存儲(chǔ)過程是帶有sql注入漏洞的zt
通常大家都會(huì)認(rèn)為存儲(chǔ)過程可以避免sql注入的漏洞,這適用于一般的存儲(chǔ)過程,而對(duì)于通用分頁存儲(chǔ)過程是不適合的,請看下面的代碼和分析!2010-07-07
asp.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)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-10-10
ASP.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

