DevExpress.XtraReports.UI.XtraReport 动态报表
原文:DevExpress.XtraReports.UI.XtraReport 动态报表
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using DevExpress.XtraTab;
using DevExpress.XtraPrinting.Control;
using DevExpress.XtraReports.UI;
namespace WindowsFormsApplication6
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private List<XtraTabPage> tabpage = new List<XtraTabPage>();
private List<PrintControl> printcon = new List<PrintControl>();
private List<XtraReport> report = new List<XtraReport>();
private string path = string.Empty;
private void Form1_Load(object sender, EventArgs e)
{
path = AppDomain.CurrentDomain.BaseDirectory;
// TODO: 这行代码将数据加载到表“dataSet1.Orders1”中。您可以根据需要移动或删除它。
this.orders1TableAdapter.Fill(this.dataSet1.Orders1);
// TODO: 这行代码将数据加载到表“dataSet1.Orders”中。您可以根据需要移动或删除它。
this.ordersTableAdapter.Fill(this.dataSet1.Orders);
dataSet1.Tables["DataTable1"].Rows.Add("page0", "Orders", "XtraReport.repx");
dataSet1.Tables["DataTable1"].Rows.Add("page1", "Orders1", "XtraReport2.repx");
dataSet1.Tables["DataTable1"].Rows.Add("page2", "Orders", "XtraReport.repx");
dataSet1.Tables["DataTable1"].Rows.Add("page3", "Orders1", "XtraReport2.repx");
dataSet1.Tables["DataTable1"].Rows.Add("page4", "Orders1", "XtraReport2.repx");
foreach (DataRow dr in dataSet1.Tables["DataTable1"].Rows)
{
XtraTabPage page = new XtraTabPage();
XtraReport2 xrepot = new XtraReport2();
string pa = path + "\\" + dr["DataColumn3"].ToString();
xrepot.LoadLayout(pa);
xrepot.Name = dr["DataColumn1"].ToString();
page.Name = dr["DataColumn1"].ToString();
page.Text = dr["DataColumn1"].ToString();
page.TabPageWidth = 100;
PrintControl print = new PrintControl();
print.Name = dr["DataColumn1"].ToString();
print.Dock = System.Windows.Forms.DockStyle.Fill;
print.PrintingSystem = xrepot.PrintingSystem;
xrepot.DataSource = dataSet1.Tables[dr["DataColumn2"].ToString()];
xrepot.CreateDocument();
report.Add(xrepot);
printcon.Add(print);
page.Controls.Add(print);
tabpage.Add(page);
xtraTabControl1.TabPages.Add(page);
}
//dataSet1.Tables["DataTable1"].Rows.Add("page0", "Orders");
}
private void xtraTabControl1_SelectedPageChanged(object sender, TabPageChangedEventArgs e)
{
string selpage = xtraTabControl1.SelectedTabPage.Text.ToString();
foreach (XtraReport rp in report)
{
if (rp.Name == selpage)
{
/*
string dc = string.Empty;
foreach (DataRow r in dataSet1.Tables["DataTable1"].Rows)
{
if (r["DataColumn1"].ToString() == selpage)
dc = r["DataColumn2"].ToString();
}
rp.DataSource = dataSet1.Tables[dc];*/
rp.CreateDocument();
}
}
foreach (PrintControl prc in printcon)
{
if (prc.Name == selpage)
printBarManager1.PrintControl = prc;
}
}
private void barButtonItem2_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
dataSet1.Tables["Orders1"].Rows.Clear();
dataSet1.Tables["Orders"].Rows.Clear();
/*
foreach (XtraReport rp2 in report)
{
rp2.CreateDocument();
}*/
}
private void barButtonItem3_ItemClick(object sender, DevExpress.XtraBars.ItemClickEventArgs e)
{
this.orders1TableAdapter.Fill(this.dataSet1.Orders1);
// TODO: 这行代码将数据加载到表“dataSet1.Orders”中。您可以根据需要移动或删除它。
this.ordersTableAdapter.Fill(this.dataSet1.Orders);
}
}
}
DevExpress.XtraReports.UI.XtraReport 动态报表的更多相关文章
- C#打印模板设计,E店宝打印模板设置,winfrom打印模板设计,DevExpress.XtraReports.UI.XRTable 表格代码生成。
一.打印效果 二.代码编辑 1 .table1 : table控件的Name: 2.label33 :label控件 实现绑定[外部平台单号]的控件: 3.label32:绑定[E店宝订单编号](S开 ...
- Devexpress Xtrareports 创建多栏报表
根据官方回答:多列或多行(取决于当前的多栏设置)呈现数据的报表 这种报表是有用的,例如,当每个明细区都只显示少量数据.并且需要在一列的右侧打印下一个明细区时,这样就能充分利用整个页面的宽度,此外,当创 ...
- 动态传递参数到DevExpress.XtraReports的小结
原文:动态传递参数到DevExpress.XtraReports的小结 前两种方法和WinForm一样,可以传递参数.数组.实体对象.DataTable等1. 采用构造函数具体用法:在Report中p ...
- DevExpress XtraReports 入门五 创建交叉表报表
原文:DevExpress XtraReports 入门五 创建交叉表报表 本文只是为了帮助初次接触或是需要DevExpress XtraReports报表的人群使用的,为了帮助更多的人不会像我这样浪 ...
- DevExpress XtraReports 入门六 控件以程序方式创建一个 交叉表 报表
原文:DevExpress XtraReports 入门六 控件以程序方式创建一个 交叉表 报表 本文只是为了帮助初次接触或是需要DevExpress XtraReports报表的人群使用的,为了帮助 ...
- [原创]Devexpress XtraReports 系列 8 创建Drill-Through报表
哎,今天公司工作忙了一天,一直没有时间写写东西.所以只能昨天晚上加班写咯.苦逼啊...... 昨天发表了Devexpress XtraReports系列第七篇[原创]Devexpress XtraRe ...
- [原创]Devexpress XtraReports 系列 1 创建静态报表
在各种管理系统中,报表是必不可少的.报表是数据最直观体现的方式之一 以前,屌丝我是微软的忠实粉丝,所以报表工具就是微软自带的RDLC... 不可否认的是RDLC的功能是非常强大的.能够满足绝大多数的要 ...
- DevExpress XtraReport - 动态加载报表布局模板
XtraReport的报表模板文件是.repx,下面的代码演示动态加载报表布局模板. XtraReport mReport = new XtraReport(); mReport.LoadLayout ...
- [原创]Devexpress XtraReports 系列 3 创建主从报表
昨天写了系列的第二篇Devexpress XtraReports 系列 2 创建表格报表 . 今天我们来继续系列 3 创建主从报表 首先我们来看看最后实现的效果.Demo最后附上. 开始吧. 第一步, ...
随机推荐
- 【Python项目】配合爱漫画爬取漫画脚本而设计的GUI漫画阅读器 (一)
博客园的第一个坑,想想都有点小激动 =3= 首先是那个爬虫的地址: [原创]最近写的一个比较hack的小爬虫 选择工具: 以前用过Qt,那么选pyqt4也就是情理之中了. 明确需求: 0.首先,要读取 ...
- android最新的工具DateHelper
最新的工具DateHelper 实用程序类,.的天数来获得一个给定的月份.过了几天去习惯或.周.一个月.日期等.. 代码例如以下: import android.annotation.Suppress ...
- 我不知道你是在一个多线程out该--【ITOO】
仍向系统负载作出太慢.卡而发愁太?我不知道多线程,你们out该.最近花了大约两三天.多-threaded.通过团队的交流,多线程有更深入的思考.希望可以加入ITOO目里面,优化一下系统性能. 概念 线 ...
- Haskell 几乎无疼痛入门指南
当他重装Linux 机会虚拟机,安装 haskell 录制的过程中有什么.的方式来帮助那些谁在徘徊haskell进入外读者. 基本概念: Haskell : 是一门通用函数式语言.差点儿能够进行不论什 ...
- HDU 4915 Parenthese sequence _(:зゝ∠)_ 哈哈
哦,我没做 #include <cstdio> #include <cstring> #include <algorithm> const int N = 1000 ...
- 【iOS发展-61】更换plist经过资源,执行iOS一旦数据仍显示在模拟器的外观,如何解决?
(1)案例介绍 --我们首先导入plist文件做项目,模拟的观看效果. --删除plist,更换一个新的plist,CMD+R模拟执行,或者找到该程序界面上显示最后一个数据. (2)原因 是由于第一次 ...
- 用正交多项式作最小二乘拟合的java实现(转)
import java.util.Scanner; public class Least_square_fit { public static double Least_square_method(i ...
- 数据库 版本号是 661,打不开。此server支持 655 和更早的版本号。不支持降级路径
"数据库 的版本号为 661,无法打开.此server支持 655 版及更低版本号. 不支持降级路径" 出现这种问题,通常是由于数据库版本号不同造成的. 我们能够用以下的语句查询数 ...
- 红帽/CentOS ext4无法格式化大分区 补充ext4格式化方式
普通情况下,XFS出现丢数据的情况为海量小文件IO场景.在该场景下,inode占用教大. 通过上文的方式进行格式化,inode数量较小.通过大量測试,能够使用例如以下方法提升mkfs.ext4后文件系 ...
- MEF初体验之十:部件重组
一些应用程序被设计成在运行时可以动态改变.例如,一个新的扩展被下载,或者因为其它的多种多样的原因其它的扩展变得不可用.MEF处理这些多样的场景是依赖我们称作重组的功能来实现的,它可已在最初的组合后改变 ...