- 浏览: 83756 次
- 性别:
- 来自: 珠海
-
文章分类
最新评论
-
kennyluo:
网页上发布的代码上缺少了"//",注意&q ...
apply a Texture Image to a Cube -
kyng:
图片放到目录下。。。修改对应名称 。。怎么还出错!!!
Ex ...
apply a Texture Image to a Cube
using System; using System.Data; using FastReport; using Szcx.GeneralDB; using System.Collections.Generic; namespace CxFastReport { //基类 public abstract class BasePlugin :IfrxUserDataSet, IfrxUserDataSetEvents, IfrxDataSet, IfrxPlugin { private int itemIndex; /// <summary> /// 报表行索引,包括报表头,尾和数据行 /// </summary> public int ItemIndex { get { return itemIndex; } set { itemIndex = value; } } private int columnCount; /// <summary> /// 列数 /// </summary> public int ColumnCount { get { return columnCount; } set { columnCount = value; } } int rowCount = 0; /// <summary> /// 数据项总行数 /// </summary> public int RowCount { get { return rowCount; } set { rowCount = value; } } #region IfrxUserDataSet 成员 string fields; /// <summary> /// 报表列集合,格式:('column1'/n'column1'/n........) /// </summary> public string Fields { get { return fields; } set { fields = value; } } string name; public string Name { get { return name; } set { name = value; } } #endregion #region IfrxUserDataSetEvents 成员 public void OnFirst() { ItemIndex = 0; } public void OnNext() { ItemIndex++; } public void OnPrior() { ItemIndex--; } public void OnCheckEOF(out bool IsEOF) { IsEOF = (ItemIndex >= rowCount); } /// <summary> /// 报表时获取数据 /// </summary> /// <param name="VarName">列名</param> /// <param name="Value">值</param> public abstract void OnGetValue(object columanName, out object Value); #endregion #region IfrxDataSet 成员 public int CurrentRecordNo { get { return ItemIndex; } } public void GoFirst() { ItemIndex = 0; } public void GoNext() { ItemIndex++; } public void GoPrior() { ItemIndex--; } public int FieldsCount { get { return ColumnCount; } } public int RecordsCount { get { return this.rowCount; } } public int RangeEndCount { get { // TODO: Add ReportDataTable.RangeEndCount getter implementation return 0; } set { // TODO: Add ReportDataTable.RangeEndCount setter implementation } } public FastReport.frxRangeBegin RangeBegin { get { // TODO: Add ReportDataTable.RangeBegin getter implementation return new FastReport.frxRangeBegin(); } set { // TODO: Add ReportDataTable.RangeBegin setter implementation } } public abstract object ValueOfField(string FieldName); string userName = ""; public string UserName { get { return userName; } set { userName = value; } } public FastReport.frxRangeEnd RangeEnd { get { // TODO: Add ReportDataTable.RangeEnd getter implementation return new FastReport.frxRangeEnd(); } set { // TODO: Add ReportDataTable.RangeEnd setter implementation } } #endregion #region IfrxPlugin 成员 public FastReport.frxPluginType PluginType { get { return FastReport.frxPluginType.ptDataSet; } } #endregion } } using System; using System.Data; using FastReport; using Szcx.GeneralDB; using System.Collections.Generic; using Szcx.Misc; namespace CxFastReport { //实现Table数据的转换 public class ReportDataTable : BasePlugin { private DataTable dataTable; /// <summary> /// 构造方法,构建列 /// </summary> /// <param name="table">数据表</param> /// <param name="dataSourceName">生成的数据源名称</param> public ReportDataTable(DataTable table,string dataSourceName) { dataTable = table; FeildMap.Clear(); //初始化 this.Name = dataSourceName; this.UserName = dataSourceName; this.RowCount = table.Rows.Count; this.Fields = null; this.ColumnCount = table.Columns.Count; //构建列 foreach (DataColumn col in dataTable.Columns) { FeildMap.Add(field.FLD_DESC, field); this.Fields += field.FLD_DESC + "/n"; } } /// <summary> /// 实现报表时获取数据 /// </summary> /// <param name="columnName">列名</param> /// <param name="Value">获取的值</param> public override void OnGetValue(object columnName, out object Value) { //报表时获取值 object value = dataTable.Rows[this.ItemIndex][columnName.ToString()]; //将Decimal数据类型装换为Int32,FastReport不能识别Decimal数据类型 if (Value is Decimal) { Value = Decimal.ToInt32((Decimal)Value); } } public override object ValueOfField(string FieldName) { throw new Exception("The method or operation is not implemented."); } } } using System; using System.Collections.Generic; using System.Text; using FastReport; using System.Data; namespace CxFastReport { //数据绑定类 public class ReportBinding { private List<BasePlugin> reportBasePlugins = new List<BasePlugin>(); public void BindToReport(List<BasePlugin> plugins, TfrxReportClass report) { reportBasePlugins.Clear(); foreach (BasePlugin plugin in plugins) { this.reportBasePlugins.Add(plugin); report.BindObject(plugin); report.SelectDataset(true, plugin); } } /// <summary> /// 卸载数据源 /// </summary> public void UnbindFromReport(TfrxReportClass report) { foreach (BasePlugin local_table in this.reportBasePlugins) { report.SelectDataset(false, local_table); } reportBasePlugins.Clear(); } } } //继承FastReporet的新类 using System; using System.Collections.Generic; using System.Text; using FastReport; using System.Data; using System.Windows.Forms; using System.Collections; namespace CxFastReport { public class FrxFastReport : TfrxReportClass { Form form; bool secondLang; public bool SecondLang { get { return secondLang; } set { secondLang = value; } } /// <summary> /// 绑定数据源对象的类 /// </summary> private ReportBinding reportBinding = null; /// <summary> /// 数据源插件对象:分别是由:ReportDataTable,ReportList实现的 /// </summary> List<BasePlugin> plugins = new List<BasePlugin>(); private IList list = null; public FrxFastReport(Form form, bool secondLang) { this.secondLang = secondLang; this.reportBinding = new ReportBinding(); this.form = form; } Dictionary<string, object> listDataSource = new Dictionary<string, object>(); /// <summary> /// 数据源和名称,键值对,object为数据源,string数据源名称, /// 如:ListDataSource.Add(new Dictionary<tableName,dataTable>); /// </summary> public Dictionary<string, object> ListDataSource { get { return listDataSource; } set { listDataSource = value; } } /// <summary> /// 绑定数据到报表 /// </summary> public void BindToReport() { IEnumerator ienumeratorKey = ListDataSource.Keys.GetEnumerator(); while (ienumeratorKey.MoveNext()) { string key = ienumeratorKey.Current.ToString(); object reportDataSource = this.ListDataSource[key]; if (reportDataSource is DataTable) { this.plugins.Add(new ReportDataTable((DataTable)reportDataSource, key)); continue; } if (reportDataSource is DataView) { DataTable tempTable = ((DataView)reportDataSource).Table; this.plugins.Add(new ReportDataTable(tempTable, key)); continue; } if (reportDataSource is IList) { this.list = (IList)reportDataSource; this.plugins.Add(new ReportList(this.list, key)); continue; } } this.reportBinding.BindToReport(this.plugins, this); } /// <summary> /// 卸载数据源 /// </summary> public void UnbindFromReport() { this.reportBinding.UnbindFromReport(this); } } } //掉用方法 //设置FastReport数据源 Dictionary<string, DataTable> listDataSource = new Dictionary<string, DataTable>(); /// <summary> /// 数据源和名称,键值对,object为数据源,string数据源名称, /// 如:ListDataSource.Add(new Dictionary<tableName,dataTable>); /// </summary> public Dictionary<string, DataTable> ListDataSource { get { return listDataSource; } set { listDataSource = value; } } /// <summary> /// 绑定数据到报表 /// </summary> public void BindToReport() { IEnumerator ienumeratorKey = ListDataSource.Keys.GetEnumerator(); while (ienumeratorKey.MoveNext()) { string key = ienumeratorKey.Current.ToString(); DataTable reportDataSource = this.ListDataSource[key]; this.plugins.Add(new ReportDataTable((DataTable)reportDataSource, key)); this.reportBinding.BindToReport(this.plugins, this); }
发表评论
-
FastReport问题整理
2012-06-09 19:58 3321部分来自网上,部分 ... -
FastReport studio 动态加载数据集 (zhuan)
2012-06-09 19:56 1348测试使用的FastReport S ... -
[转载]了解IL反编译工具Ildasm.exe
2012-05-29 22:06 0Ildasm.exe 的使用方法 示例: 在应用 ... -
从ipa提取图片资源,还原PNG文件
2012-05-14 15:44 5169iOS 开发过程中,在code和测试阶段结束后,你需要用xco ... -
PHP缓存技术:memcache函数详解之一
2012-02-14 04:59 1006Memcache函数库是在PECL( ... -
PHP缓存技术:memcache函数详解之二
2012-02-14 04:56 1329memcache::debug bool memcac ... -
PHP企业级应用之常见缓存技术篇
2012-02-14 04:50 1250php的缓冲器: 有eaccelerator, apc ... -
php缓存技术详解
2012-02-14 04:48 945一、缓存技术: 有些信息比方经常不变的,但是还是 ... -
PHP企业级应用之常见缓存技术篇
2012-02-14 04:47 867别每天OO,这个配置怎么改,这段代码哪错了,没劲,好的程 ... -
FreeFileSync 文件比较同步系统
2012-02-04 00:06 1260http://sourceforge.net/proj ... -
[图文]Openfiler应用篇(五)Accounts之AD认证
2012-02-03 20:16 1273一、Win2003服务器域控制器准备 首先 ... -
[图文]Openfiler应用篇(四) FTP和Quota
2012-02-03 20:14 2303本篇我们讨论openfiler FTP ... -
[图文]Openfiler应用篇(三) Accounts
2012-02-03 20:12 980openfiler帐户(Accounts)设置,是openfi ... -
[图文]Openfiler应用篇(二) SMB/CIFS server
2012-02-03 20:12 1366一、建立share-1逻辑卷 本篇我们讨论openfile ... -
[图文]Openfiler应用篇(一)iSCSI
2012-02-03 20:11 1338本文主要讲解Openfile iSCSI 设置和应用,首 ... -
手机产品交互设计样式
2012-01-28 15:51 863很多人都说,手机产品交互限制因素很多,过小的屏幕分辨率, ... -
Domain Locking SWFs
2011-08-12 14:05 839By domain locking (or site lock ... -
CentOS系统下如何打开端口
2011-07-21 10:48 1152在CentOS系统使用中,我们会遇到很多的问题。例如CentO ... -
基于角色管理的系统访问控制(2)
2010-02-21 11:24 1158方案设计 3.1. 安全保护 ... -
基于角色管理的系统访问控制(1)
2010-02-21 11:24 1065安全管理系统核心思想是在基于角色控制思想的基础上提取改进而来的 ...
相关推荐
FastReport是一款强大的报表工具,广泛应用于C#编程环境中,支持WinForm、WebForm以及MVC三种不同的应用程序架构。它的灵活性和易用性使得开发者能够快速创建复杂的数据报告,提高开发效率,同时也为用户提供友好的...
C# Winform .NET FastReport自定义报表模块源码是一个为企业级报表设计和打印提供解决方案的工具。它基于Visual Studio 2017 .NET框架构建,并整合了FastReport报告生成器、Devexpress控件库版本16.2.5以及SQL ...
在安装过程中,确保勾选“Add FastReport to Visual Studio”的选项,这样FastReport组件会自动集成到你的Visual Studio环境中。路径选择可以根据个人需求调整,最后点击“Finish”完成安装。 **二、FastReport的...
.Net是一款功能齐全的报表解决方案,使用该产品开发人员可以快速创建出独立的报表应用程序,同样的该产品也可以用作单独的报表设计工具,支持报表自定义,多种数据库连接,可用于WinForm,Asp.NET、MVC。支持...
功能介绍: 实现了新建报表编辑,添加列。编辑表头,放大缩小,打印预览等功能,用户可以自己编辑报表或集成一个打印控件,直接应用到每个系统中! 注意: 开发环境为Visual Studio 2008
1. **定义异步方法**:使用`async`关键字修饰方法,例如: ```csharp public async Task<int> GetDataAsync() ``` 2. **使用`await`等待异步操作**:在异步方法内部,使用`await`关键字等待异步任务完成,例如...
本程序使用到了功能强大的fastreport.net报表工具。对学习报表打印的朋友们很有帮助。 二、菜单功能 1、所有权页面展示 2、查询数据 3、打印预览 4、打印 5、退出 三、注意事项 1、开发环境为Visual Studio ...
本程序使用到了功能强大的fastreport.net报表工具。对学习报表打印的朋友们很有帮助。 二、菜单功能 1、所有权页面展示2、查询数据3、打印预览 4、打印5、退出 三、注意事项 1、开发环境为Visual Studio ...
2. **报表控件**:用于生成复杂报表,如FastReport、Crystal Reports或Syncfusion的Essential Studio,它们支持多种数据源,能创建多页布局,还提供预览和导出功能。 3. **数据网格控件**:如Infragistics的...
本程序使用到了功能强大的fastreport.net报表工具。对学习报表打印的朋友们很有帮助。 二、菜单功能 1、所有权页面展示2、查询数据3、打印预览 4、打印5、退出 三、注意事项 1、开发环境为Visual Studio 2010,...