How to Change .NET C# Report Control Properties at Runtime
Quick Start Guide | |
---|---|
What You Will Need |
ActiveReports.NET Visual Studio 2017 - 2022 for Code-Based Section Reports |
Controls Referenced | |
Tutorial Concept | Learn how to dynamically adjust properties of .NET C# report controls in real-time. Explore efficient methods for modifying control properties to enhance the functionality and aesthetics of your reports effortlessly. |
When it comes to dynamically altering control properties at runtime in reports, the approach can vary depending on the type of report being used - whether it's a Section-based report or a Page/RDL-based report. In this article, we will look at the procedure for each of the following report types:
Ready to Get Started? Download ActiveReports.NET Today!
Page and RDL Reports
In a Page or RDL Report, you can change control properties at run time by adding code to expressions in the control properties. See examples below.
Note: You can set an expression in any property whose type is ExpressionInfo. However, you cannot change control properties like Location or Size. Since a Page report is designed to have a WYSIWYG output, we don't allow size and location settings to be changed at run time.
Change the Output Value
To change the output value, find the control's Value property in the Properties Window and click the drop-down arrow button to select <Expression...>. With the Expression Editor open, enter an expression like the following (replacing FieldName with the name of your field):
Conditional Formatting
To conditionally format specific values, for example, displaying all negative values in Italics, set the Font.FontStyle property to the following expression:
Show Only on the Specific Page
To set a field to show only on the report's final page, find the control's Value property in the Properties Window and click the drop-down arrow to select Expression.... With the Expression Editor open, enter an expression like the following:
For more information about expressions and examples of Page and RDL reports, visit the following topics in our User Guide: Expressions | Create Red Negatives Report | Create Green Bar Report | Expressions in Reports | Reports with Custom Code
Code-Based Section Reports
In a Section report, you can change control properties at run time by adding code to report events. For example, the following code changes the text property of a Label in C# and VB.NET:
C#:
VB.NET:
(**1) You cannot directly change members of the Location object (e.g., Location.X) that are returned from this property because Location property values are indicated in numeric type. To change the Location property at run time, you need to create a new instance of the System.Drawing.PointF class to match the data type of the Location property.
(**2) The values of the Font property are ReadOnly, so you cannot directly change the value of Font.Name. To change the Font property at run time, you must create a new instance of the Font object.
Important: You can change a control's properties only within the events for the section that contains the control (e.g., Detail_Format, PageHeader_BeforePrint, or GroupFooter_AfterPrint) or within the ReportStart event. You can also change properties at the report instance creation level in code outside the report with a private or public modifier. For more information, see the following topics in the ActiveReports help file: Section Report Events | Conditional Scenarios | Create Green Bar Report
XML-Based Section Reports
In an XML-Based Section report (and Section Reports in the End-User Designer), you can change control properties at run time by adding the script to report events in the script tab. For example, the following code changes the text property of a Label in C# and VB.NET:
C#:
VB.NET:
Conclusion
In summary, while both Section-based and Page/RDL-based reports offer ways to change control properties dynamically at runtime, the methods and techniques may vary depending on the underlying structure and features of the reporting tool being used. Understanding the capabilities and best practices for each type of report can help developers create more flexible and interactive reporting solutions.
There is a lot more to dynamic reporting with ActiveReports. Check out the latest version to test these features and more for yourself.
Ready to Get Started? Download ActiveReports.NET Today!