📄 default.aspx.cs
字号:
using System;
using System.Data;
using System.Collections;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.Shared;
public partial class _Default : System.Web.UI.Page
{
/// download from www.51aspx.com(51aspx.com)
private ReportDocument customersByCityReport;
private const string PARAMETER_FIELD_NAME = "City";
private const string SUBREPORT_PARAMETER_FIELD_NAME = "OrderDateRange";
private const string SUBREPORT_NAME = "CustomerOrders";
protected void Page_Load(object sender, EventArgs e)
{
}
private void Page_Init(object sender, EventArgs e)
{
ConfigureCrystalReports();
}
private void ConfigureCrystalReports()
{
customersByCityReport = new ReportDocument();
string reportPath = Server.MapPath("CustomersByCity.rpt");
customersByCityReport.Load(reportPath);
ArrayList arrayList = new ArrayList();
string startDate;
string endDate;
if (!IsPostBack)
{
defaultParameterValuesList.DataSource = GetDefaultValuesFromParameterField(customersByCityReport);
defaultParameterValuesList.DataBind();
arrayList.Add("Paris");
arrayList.Add("Tokyo");
startDate = "8/1/1997";
endDate = "8/31/1997";
Session["arrayList"] = arrayList;
Session["startDate"] = startDate;
Session["endDate"] = endDate;
}
else
{
arrayList = (ArrayList)Session["arrayList"];
startDate = Session["startDate"].ToString();
endDate = Session["endDate"].ToString();
}
SetCurrentValuesForParameterField(customersByCityReport, arrayList);
SetDateRangeForOrders(customersByCityReport, startDate, endDate);
crystalReportViewer.ReportSource = customersByCityReport;
}
private void SetCurrentValuesForParameterField(ReportDocument reportDocument, ArrayList arrayList)
{
ParameterValues currentParameterValues = new ParameterValues();
foreach (object submittedValue in arrayList)
{
ParameterDiscreteValue parameterDiscreteValue = new ParameterDiscreteValue();
parameterDiscreteValue.Value = submittedValue.ToString();
currentParameterValues.Add(parameterDiscreteValue);
}
ParameterFieldDefinitions parameterFieldDefinitions = reportDocument.DataDefinition.ParameterFields;
ParameterFieldDefinition parameterFieldDefinition = parameterFieldDefinitions[PARAMETER_FIELD_NAME];
parameterFieldDefinition.ApplyCurrentValues(currentParameterValues);
}
private ArrayList GetDefaultValuesFromParameterField(ReportDocument reportDocument)
{
ParameterFieldDefinitions parameterFieldDefinitions = reportDocument.DataDefinition.ParameterFields;
ParameterFieldDefinition parameterFieldDefinition = parameterFieldDefinitions[PARAMETER_FIELD_NAME];
ParameterValues defaultParameterValues = parameterFieldDefinition.DefaultValues;
ArrayList arrayList = new ArrayList();
foreach (ParameterValue parameterValue in defaultParameterValues)
{
if (!parameterValue.IsRange)
{
ParameterDiscreteValue parameterDiscreteValue = (ParameterDiscreteValue)parameterValue;
arrayList.Add(parameterDiscreteValue.Value.ToString());
}
}
return arrayList;
}
private void SetDateRangeForOrders(ReportDocument reportDocument, string startDate, string endDate)
{
ParameterRangeValue parameterRangeValue = new ParameterRangeValue();
parameterRangeValue.StartValue = startDate;
parameterRangeValue.EndValue = endDate;
parameterRangeValue.LowerBoundType = RangeBoundType.BoundInclusive;
parameterRangeValue.UpperBoundType = RangeBoundType.BoundInclusive;
ParameterFieldDefinitions parameterFieldDefinitions = reportDocument.DataDefinition.ParameterFields;
ParameterFieldDefinition parameterFieldDefinition = parameterFieldDefinitions[SUBREPORT_PARAMETER_FIELD_NAME, SUBREPORT_NAME];
parameterFieldDefinition.CurrentValues.Clear();
parameterFieldDefinition.CurrentValues.Add(parameterRangeValue);
parameterFieldDefinition.ApplyCurrentValues(parameterFieldDefinition.CurrentValues);
}
protected void redisplay_Click(object sender, EventArgs e)
{
ArrayList arrayList = new ArrayList();
foreach (ListItem item in defaultParameterValuesList.Items)
{
if (item.Selected)
{
arrayList.Add(item.Value);
}
}
Session["arrayList"] = arrayList;
Session["startDate"] = orderStartDate.Text;
Session["endDate"] = orderEndDate.Text;
ConfigureCrystalReports();
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -