zoukankan      html  css  js  c++  java
  • 水晶报表参数构建和数据传入显示函数

      #region 参数构建
            private ParameterFields GetParameterFields(Dictionary<string,string > dicValue)
            {
                ParameterFields fields = new ParameterFields();

                foreach (string key in dicValue.Keys)
                {
                    fields.Add(this.CreateParameterField(key, dicValue[key]));
                }
                return fields;
            }
            private ParameterField CreateParameterField(string FieldName, object FieldValue)
            {
                ParameterField field = new ParameterField();
                ParameterDiscreteValue pvalue = new ParameterDiscreteValue();


                pvalue.Value = FieldValue;
                field.Name = FieldName;
                field.CurrentValues.Add(pvalue);
                field.AllowCustomValues = false;

                //返回参数字段
                return field;
            }
            #endregion
            #region 显示报表
            /// <summary>
            /// 显示报表
            /// </summary>
            /// <param name="formularFieldsValue">显示字段离散值</param>
            /// <param name="dicValue">参数键值对</param>
            /// <param name="reportData">报表数据</param>
            /// <param name="reportFile">报表文件</param>
            /// <param name="reportView">报表控件</param>
            public void ShowReport(string[] formularFieldsValue, Dictionary<string, string> dicValue, DataSet reportData, string reportFile, CrystalReportViewer reportView)
            {
                //使用报表对象加载报表
                ReportDocument myReport = new ReportDocument();        
                myReport.Load(reportFile);
                DataDefinition dataDefinition = myReport.DataDefinition;
                //获取数据对象中的公式字段集合
                string[] Text4formularFields = formularFieldsValue;           
                FormulaFieldDefinitions formularFields = dataDefinition.FormulaFields;
                for (int i = 0; i < formularFieldsValue.Length; i++)
                {
                    formularFields[i].Text = formularFieldsValue[i];
                }
                myReport.SetDataSource(reportData);
                reportView.ParameterFieldInfo = GetParameterFields(dicValue);
                reportView.ReportSource = myReport;

            }
            public void ShowReport(string[] formularFieldsValue, Dictionary<string, string> dicValue, DataTable reportData, string reportFile, CrystalReportViewer reportView)
            {
                //使用报表对象加载报表
                ReportDocument myReport = new ReportDocument();
                myReport.Load(reportFile);
                DataDefinition dataDefinition = myReport.DataDefinition;
                //获取数据对象中的公式字段集合
                string[] Text4formularFields = formularFieldsValue;
                FormulaFieldDefinitions formularFields = dataDefinition.FormulaFields;
                for (int i = 0; i < formularFieldsValue.Length; i++)
                {
                    formularFields[i].Text = formularFieldsValue[i];
                }
                myReport.SetDataSource(reportData);
                reportView.ParameterFieldInfo = GetParameterFields(dicValue);
                reportView.ReportSource = myReport;

            }
            public void ShowReport <T>(string[] formularFieldsValue, Dictionary<string, string> dicValue, List<T> reportData, string reportFile, CrystalReportViewer reportView)
            {
                //使用报表对象加载报表
                ReportDocument myReport = new ReportDocument();
                myReport.Load(reportFile);
                DataDefinition dataDefinition = myReport.DataDefinition;
                //获取数据对象中的公式字段集合
                string[] Text4formularFields = formularFieldsValue;
                FormulaFieldDefinitions formularFields = dataDefinition.FormulaFields;
                for (int i = 0; i < formularFieldsValue.Length; i++)
                {
                    formularFields[i].Text = formularFieldsValue[i];
                }
                myReport.SetDataSource(reportData);
                reportView.ParameterFieldInfo = GetParameterFields(dicValue);
                reportView.ReportSource = myReport;

            }
            #endregion

  • 相关阅读:
    Tomcat启动提示At least one JAR was scanned for TLDs yet contained no TLDs
    elasticsearch 相关操作
    ES下载与安装
    分词器
    Go语言中import导入包时:点. 、下划线_ 、别名的用法
    删除某库中所有表
    yum 安装mysql
    chromedriver下载及配置
    前端库在Core Web项目中的引入和使用
    The database provider attempted to register an implementation of the 'IRelationalTypeMappingSource' service.
  • 原文地址:https://www.cnblogs.com/wanyuan8/p/2217467.html
Copyright © 2011-2022 走看看