📚
Siticone Docs
HomePricing PlansSuggest a FeatureMy LicenseChangelogDownloads
  • Dear Developer!
  • Quick Start Guide
    • Install Siticone UI Library
    • Register for 1 month free trial
    • Register for Premium License
  • Net Framework | Net Core UI
    • Input Controls
      • Siticone TextBox
        • Appearance and Styling
        • Text and Placeholder Config.
        • Input, Validation and Read-Only Behavior
        • User Interaction & Shortcuts
        • System Theme Integration
        • Events and Callbacks
      • Siticone TextArea
        • Always Multiline
        • Custom Font
        • Vertical Scrollbars
        • Border-less Design
        • Dynamic Resizing
        • Margin Spacing
      • Siticone CheckBox
        • Visual Style
        • State Management
        • Interaction Effects
        • Container Layout
        • Container Style
        • Container States
        • State Colors
        • Border Configuration
        • Layout
        • Focus Appearance
        • Text Property
        • Trigger Feedback
      • Siticone RadialButton
        • Appearance
        • Behavior
        • Layout Management
        • User Assistance
        • Animation Timing
        • Events and Callbacks
      • Siticone ToggleButton
        • Toggle Functionality
        • Appearance and Text
        • Border Settings
        • Corner Radius
        • Animation Settings
        • Ripple & Interaction Effects
        • Read-only and Feedback
        • Sizing and Layout
        • Context Menu Integration
        • State Persistence
        • Accessibility
        • Events and Callback
      • Siticone ToggleSwitch
        • Core Toggle Functionality
        • Appearance and Theming
        • Logging and Diagnostics
        • Interactive Effects
        • Labels and Icons
        • Audio Feedback
        • Thumb Customization
        • Animation Settings
        • Context Menu Integration
        • Tool-tip Capabilities
        • Events and Callbacks
      • Siticone UpDown
        • Behavior and Data Config
        • Appearance Customization
        • Feedback and Animation
        • Events and Callbacks
      • Siticone PhoneNumberBox
        • Page 1
        • Phone Number Config
        • Country Flag Display
        • Shadow Effects
        • Input Validation
        • Border and Background
        • Placeholder and Animation
        • Text & Cursor Customization
        • Font and Text Style
        • Corner and Fill Config
        • System Theme (Preview)
        • Public Methods & Text
        • Events and Callbacks
      • Siticone Otp
        • Security & Input Protection
        • Interactive Feedback
        • Input Validation
        • Box Appearance & Layout
        • Data Extraction & Display
        • State Analysis
        • Events and Callbacks
        • Additional Public Methods
    • Buttons and Elements
      • Siticone Button
        • Animation Effects
        • Theme & System Integration
        • User Assist & Interaction
        • Layout & Content
        • Visual Effects & Styling
        • Badge Configuration
        • Manage State & Behavior
        • Performance and Rendering
        • Events for Control Updates
      • Siticone TileButton
        • Animation Effects
        • Color Settings
        • Visual Style
        • Icon Settings
        • Advanced Styling
        • Badge Display
        • Loading Indicator
        • State Management
        • Tool-tip Settings
        • Accessibility
        • Corner Radius
      • Siticone ImageButton
        • Content Presentation
        • Interaction and Behavior
        • Feedback and Animations
        • Visual Style and Layout
        • Badge Features
        • Theme Integration
        • Events and Callbacks
      • Siticone MenuButton
        • Appearance and Visual Style
        • Icon Customization
        • Animation Features
        • Behavior and Interaction
        • Events and Callbacks
      • Siticone CloseButton
        • Appearance Customization
        • Animation and Visual Effects
        • Behavioral Settings
        • Accessibility Features
        • Tool-tip Configuration
        • Countdown Display Config
        • Events and Callbacks
      • Siticone CopyButton
        • Appearance & Visual Effects
        • Corner and Shape Config
        • Behavior & Target Copy
        • Notification Customization
        • Context Menu Customization
        • Accessibility Features
        • Events and Callbacks
      • Siticone DashboardButton
        • Visual Effects
        • Visual Appearance
        • Notification Badge
        • Selection Indicator
        • Layout and Text
        • State Management & Colors
        • Animation Settings
        • Shape Customization
        • Accessibility
        • User Interaction Events
      • Siticone NavBackButton
        • Behavior and Feedback
        • Visual Appearance
        • Dimensions & Icon Styling
        • Animation Effects
        • Visual Style Enhancements
        • Events and Callbacks
      • Siticone NavForwardBtn
        • Behavior & Read-Only Config
        • Icon Customization
        • Colors & Visual Feedback
        • Button Dimensions & Shape
        • Animation Features
        • Visual Style and Effects
        • Events for Animation
        • Control Overrides
        • Events and Callbacks
      • Siticone NotificationBtn
        • Tool-tip Features
        • Layout & Size Customization
        • Bell Appearance & Behavior
        • Badge (Count) Features
        • Interaction and Gesture
        • Visual Effects and Animation
        • Visual Style and Shadow
        • Additional Behavior Settings
        • Events for Feedback
        • Events and Callbacks
      • Siticone PlayPauseBtn
        • Progress Indicator
        • Animation Effects
        • Visual Style
        • Shape Customization
        • Shape Customization
        • Icon Customization
        • Behavior
        • Events and Callbacks
    • Container and Layout
      • Siticone Panel
        • Border Customization
        • Corner Curvature
        • Background Appearance
        • Gradient Effects
        • Interactive Ripple Effects
        • Backdrop Effects
        • Event Notifications
      • Siticone AdvancedPanel
        • Essential Styling
        • Motion and Animation
        • Color and Gradient
        • Depth and Shadow
        • Border Enhancements
        • Interactive States
        • Background Effects
        • Content Management
        • Events and Callback
      • Siticone FlatPanel
        • Appearance and Styling
        • Performance & Rendering
        • Design-Time Integration
      • Siticone FlowPanel
        • Appearance & Visual Effects
        • Layout Customization
        • Performance Optimization
        • Interaction and Behavior
        • Theme & DPI Integration
        • Events and Callbacks
      • Siticone Container
        • Color and Gradients
        • Border Design and Styling
        • Corner and Shape Config
        • Shadow & Elevation Effects
        • Interactive and Animations
        • Badge Configuration
        • Content Management
        • Context Menu Integration
        • Dragging and Interaction
        • Security and Feedback
        • Events and Callbacks
      • Siticone SplitContainer
        • Event Handling
        • Splitter Movement & Behavior
        • Animation & Smooth Drag
        • Appearance and Styling
        • State Management
        • Accessibility & Keyboard Navigation
        • Context Menu Integration
        • System Theme Integration
        • Drag and Drop Panel Reordering
      • Siticone GroupBox
        • Theming and Aesthetics
        • Border & Edge Effects
        • Text & Title Styling
        • Layout Configuration
        • Chevron Styling
        • Badge Config & Animation
        • Collapsible Features
        • Interaction Behavior & Events
        • Status Elements
      • Siticone NativeGroupBox
        • Border Customization
        • Appearance & Layout
      • Siticone DragPanel
        • Layout Customization
        • Appearance Customization
        • Rendering Quality
        • Interactive Behavior
      • Siticone Card
        • Color and Gradients
        • Border Config & Styling
        • Corner and Shape Config
        • Shadow and Elevation
        • Interactive Effects and Animations
        • Hover Effects
        • Visual Effects
        • Badge Configuration
        • Security and Feedback Settings
        • Dynamic Content & Context Menu
        • Drag-and-Drop Interaction
        • Front-Facing Events
      • Siticone TabControl
        • General Layout and Sizing
        • Appearance and Color Customization
        • Close Button Customization
        • Pin Functionality
        • Tab Management and Navigation
        • Animation and Visual Effects
        • Context Menu Customization
        • Events and Callbacks
      • Siticone Workbook (Preview)
    • Progress and Loading
      • Siticone HProgressBar
        • Rounded Corners & Shape Customization
        • Progress Value & Range Management
        • Orientation & Layout
        • Animation & Indeterminate Mode
        • Progress State Colors & Thresholds
        • Gradient & Bar Styling
        • Label & Tooltip Customization
        • Read‑Only Mode
        • Ripple Effects
        • User Experience Enhancements
        • System Theme Tracking
        • Events and Callbacks
      • Siticone VProgressBar
        • Appearance & Styling
        • Behavior, Animation & Interaction
        • System Integration & Events
      • Siticone HBarsProgress
        • Animation Control
        • Progress Value Management
        • Appearance and Styling
        • Display and Interaction
        • Events and Callbacks
      • Siticone VBarsProgress
        • Animation Features
        • Progress and Range Settings
        • Line Configuration
        • Color and Appearance
        • Display Options
        • User Interaction
        • Events and Callbacks
      • Siticone HLineProgress
        • Range Settings
        • Animation Settings
        • Color and Gradient Design
        • Visual Effects
        • Pulse Animation Settings
        • Corner Radius Customization
        • Page
      • Siticone VLineProgress
        • Range Settings
        • Animation Settings
        • Color and Gradient Customization
        • Background and Highlight Effects
        • Pulse Animation Settings
        • Corner Radius Settings
      • Siticone CircularSpinner
        • Visual Customization
        • Geometry and Layout
        • Motion and Animation
        • Progress Indication
        • Events
      • Siticone LoadingSpinner
        • General Control Methods & Events
        • Animation Settings
        • Appearance & Visual Customization
        • Progress Display Customization
        • Size & Radius Customization
        • Ring & Spoke Customization
        • Special Effects
        • Events and Callbacks
      • Siticone RadialProgress
        • Core Configuration
        • Visual Styling
        • Interaction and Control
        • Animation and Motion
        • Advanced Effects & Readonly State
        • Color Customization
        • Indeterminate Mode
        • Events
      • Siticone SmoothCSpinner
        • Appearance Customization
        • Animation Control
        • Arc Dimension Settings
      • Siticone SmoothLProgress
        • Dual-Bar Behavior
        • Visual Appearance
        • Motion Dynamics
        • Animation Control
    • Sliders and Range
      • Siticone HSlider
        • Appearance and Layout
        • Read-Only Customization
        • Visual Effects & Animations
        • Interaction & Behavior
        • Data Binding & State Management
        • Events & Accessibility
        • Built-In Context Menu Operations
      • Siticone VSlider
        • Data & Value Management
        • Appearance Customization
        • Read-Only Mode Appearance
        • Visual Effects & Animations
        • Interaction & Feedback Settings
        • Events & Event Handling
        • State Management
        • Accessibility & Data Binding Support
      • Siticone HTrackBar
        • Data & Value Management
        • Appearance Customization
        • Animation & Interaction Effects
        • Behavior & Interaction
        • Accessibility & Data Binding
        • Events
      • Siticone VTrackBar
        • Value and Range Configuration
        • Appearance Customization
        • Animation and Interaction Customization
        • Feedback Mechanisms
        • Context Menu and Tooltip Features
        • Accessibility and Keyboard Support
        • State Management and Data Binding
        • Events
      • Siticone HRangeSlider
        • Behavior & Value Management
        • Appearance Customization
        • User Interaction
        • Events
      • Siticone HRangeTrackBar
        • Behavior Settings
        • Appearance Settings
        • Event Handling
        • Built-In Context Menu Functionality
        • Keyboard and Mouse Interaction
    • Data Display and Grid
      • Siticone DataGrid
        • Data Management & Binding
        • Theming and Appearance Customization
        • Behavior & Interaction
        • Built-In Data Import/Export and Encryption
        • Search and Filtering Capabilities
        • Text Formatting and Cell Styling (Ribbon Toolbar)
        • User Interaction Enhancements
        • Events and Callbacks
      • Siticone Label
        • Text and Content
        • Transparent Background
        • Layout & Rendering Enhancements
        • Standard Layout Properties (Inherited)
      • Siticone LinkedLabel
        • Text and Link Behavior
        • Color Properties
        • Font and Appearance
        • Events
      • Siticone ShimmerLabel
        • Shimmer Appearance
        • Shimmer Behavior
        • Shimmer Text
    • Form Design Framework
      • Siticone Form
        • Window Behavior & Layout
        • Title Bar Customization
        • Control Box (Window Buttons) Customization
        • Theme and Appearance
        • Animation & Visual Effects
        • Events and Public Methods
      • Siticone EmptyForm
        • Visual Appearance & Styling
        • Rendering and Performance Enhancements
      • Siticone DragForm
        • Drag Functionality
        • Accessibility and Keyboard Navigation
        • Performance Optimizations
        • Appearance Customization
    • Gauges and Measurement
      • Siticone GaugeClock
        • Value Hand Customization
        • Core Appearance & Theme
        • Typography & Labeling
        • Gauge Configuration & Value Range
        • 3D Effects and Metallic Appearance
        • Visual Effects and Enhancements
        • Gradient Customization
        • Display & Format Options
        • Scale and Tick Mark Configuration
        • Animation & Interaction
        • Export/Import and Context Menu Options
        • Section Management
        • Events and Callbacks
      • Siticone GaugeDigital
        • Gauge Core Settings
        • LED Display Settings
        • Visual Style and Themes
        • 3D Effects
        • Lighting Effects
        • Typography and Scale
        • Custom Gradients and Texture
        • Animation and Interactivity
        • Context Menu Operations
        • Events
      • Siticone GaugeNumeric
        • Gauge Display & Value
        • Scale and Markers
        • Typography & Text
        • Color Customization
        • 3D and Special Effects
        • Interaction & Tool-tip
        • Additional Features & Events
      • Siticone GaugeZone
        • ZonePasswordForm (Password Dialog Control)
        • Control Features
    • Chip and Group Controls
      • Siticone Chip
        • Appearance & Color Scheme
        • Corner and Shape Customization
        • Visual Effects
        • Interaction & Behavior
        • Close Button Customization
        • Selection Indicator Customization
        • Visual Content
        • Events
      • Siticone GroupChip
        • Group Management
        • Visual Effects
        • State Colors
        • Close Button Styling & Layout
        • Selection Indicator
        • Visual Elements
        • Color Scheme
        • Border Customization
        • Corner Customization
        • Interactive Features
        • Animation Settings
        • Behavior
        • Events
      • Siticone GroupChipPanel
        • Drag-and-Drop Customization
        • Chip Selection Customization
        • Chip Management API
        • Chip Events
      • Siticone GroupButton
        • Material Design Effects
        • Surface Styling
        • Screen Reader Support
        • Alert System (Badge Features)
        • Selection and Interactive States
        • Selection Markers and Indicator Customization
        • Content Layout
        • Animation and Motion
        • Corner and Shape Customization
        • Events and Callbacks
    • Media and Graphics
      • Siticone Audio
        • Basic Behavior and State
        • Appearance Customization
        • Sound Wave Animation and Style
        • Visual Effects and Animations
        • Events and Callbacks
      • Siticone PictureBox
        • Image Loading and Display
        • Layout and Sizing
        • Shape and Border Config
        • Image Quality and Effects
        • Image Transformations
        • Slideshow Functionality
        • Interaction & Behavior
        • Performance & Display
      • Signature Pad
        • Context Menu Customization
        • Template Customization
        • Animation Features
        • Stroke Aesthetics and Dynamics
        • Input Processing and Guides
        • Visual Guides
        • Rendering Quality
        • Performance
        • User Experience
        • Public Methods for Signature Handling
        • Public Events for Integration
        • Events
    • Separator Controls
      • Siticone HSeparator
        • Segment Configuration
        • Line Multiplication
        • Visual Styling
      • Siticone VSeparator
        • Segment Configuration
        • Line Multiplication
        • Visual Styling
        • Enumerations
    • Utility Controls
      • Siticone BackgroundWkr
        • Worker Initialization and Configuration
        • Custom Progress Reporting Functionality
      • Siticone SystemInfo
        • System and Service Information
        • Security and User Information
        • Performance and Memory Metrics
        • System Hardware and Operating System Details
        • Peripherals and Additional Devices
        • Hardware (Detailed)
        • Display Details
        • Network Information
        • Configuration Options
        • Methods for Data Retrieval and Export
        • Events and Callbacks
      • Siticone TaskbarBadgeS.
        • Badge Display & Formatting
        • Animation Effects
        • Notification Effects
        • Flash / Highlight Effects
        • System Theme Integration
        • Parent Form Integration
        • Events and Callbacks
      • Siticone ThemeSwitcher
        • Layout and Spacing
        • Visual Effects and Animation
        • Icon Customization
        • Border and Corner Configuration
        • Color Scheme
        • Behavior and State
        • Accessibility
      • Siticone ThemeTracker
        • Theme and Accent Information
        • Theme Application and Automation
        • Theme & Accent Events
        • Initialization
      • Siticone IdGen
        • Unique ID Customization
        • Character Set Customization
        • ID Generation Strategy and Distribution Settings
        • ID Generation and Collision Handling
    • Data Formatting and Display
      • Siticone Humanizer Date..
        • Data Management
        • Formatting Settings
        • Calculation Options
        • Custom Translations
      • Siticone HumanizerDec..
        • Input Value Configuration
        • Automatic Humanized Output
        • Customizable Humanization
      • Siticone HumanizerFloat
        • Formatting Features
        • Validation Features
        • Currency Features
        • Localization Features
        • Value and Precision Features
        • Read-Only Display Features
        • Additional Public Methods
        • Enumerations (for Customization)
      • Siticone HumanizerInt
        • Core Number Conversion
        • Text Customization and Styling Options
        • Number Scale & Localization
        • Currency Features
        • Performance and Asynchronous Processing
        • Caching Mechanism and Management
        • Settings Change Notifications
      • Siticone HumanizerLong
        • Core Number Conversion
        • Formatting and Localization Options
        • Security and Data Integrity
        • Performance and Caching
        • Events for Developer Integration
    • Special Purpose Controls
      • Siticone CardNumber
        • Appearance Customization
        • Credit Card Specific Features
        • Input and Validation
        • Read-Only Customization
        • Shadow & Animation Effects
        • Selection and Text Editing
        • Context Menu Support
        • Credit Card Events
      • Siticone CopyUrl
        • URL Display and Core Functionality
        • Icon Management
        • Copy Button Customization
        • Text Styling
        • Background & Border Styling
        • Corner Styling
        • Animation Effects
        • Interaction Behavior
        • Notification System
        • Additional Built-In Features
      • Siticone Rating
        • Rating Functionality
        • Appearance Customization
        • Layout and Sizing Customization
        • Behavior Customization
        • Animation Customization
        • Focus and Accessibility Customization
        • Right‑Click Context Menu Customization
      • Siticone RatingEmoji
        • Theme Management
        • Emoji Customization
        • Visual Enhancement
        • Selection and Rating
        • Animation and Interaction Dynamics
        • User Feedback
        • Data Persistence
Powered by GitBook
On this page
  • Overview
  • Events and Their Details
  • Key Points
  • Best Practices
  • Common Pitfalls
  • Usage Scenarios
  • Code Example and Demo
  • Review
  • Summary
  • Additional Sections
  1. Net Framework | Net Core UI
  2. Progress and Loading
  3. Siticone HProgressBar

Events and Callbacks

This feature empowers developers to respond to various control events, enabling reactive behavior and dynamic interaction with the progress bar based on its state and user actions.

Overview

The Event Handling feature exposes several events that notify the application of key changes and interactions within the progress bar. Events such as ValueChanged, IndeterminateChanged, ProgressReachedThreshold, ProgressCompleted, and SystemThemeChanged allow developers to hook custom logic into the control. This supports dynamic UI updates, logging, and responsive feedback mechanisms in response to progress changes or user interactions.


Events and Their Details

The table below summarizes the main events provided by the control along with their descriptions:

Event Name
Type/Signature
Description

ValueChanged

EventHandler

Fired when the progress value changes, providing the new value via ValueChangedEventArgs.

IndeterminateChanged

EventHandler

Raised when the control switches between determinate and indeterminate (marquee) modes.

ProgressReachedThreshold

EventHandler

Triggered when the progress value reaches a defined threshold (e.g., warning or error), passing the threshold value.

ProgressCompleted

EventHandler

Occurs when the progress value reaches the maximum, indicating that the operation is complete.

SystemThemeChanged

EventHandler

Raised when the operating system's theme changes, providing the new theme so that the control can update its styling.

Note: These events allow developers to create responsive behaviors and synchronize the progress bar with the overall application state.


Key Points

Aspect
Details

Reactive Programming

The events enable a reactive programming model, allowing developers to execute custom logic when specific progress states occur.

State Awareness

Events such as ValueChanged and ProgressCompleted help monitor the progress of operations and update the UI accordingly.

Theme Synchronization

The SystemThemeChanged event ensures that theme changes are propagated to the control, promoting a cohesive look and feel.


Best Practices

Practice
Explanation

Subscribe Early

Register event handlers during the initialization of the control to ensure that all state changes are captured and handled appropriately.

Use Meaningful Event Logic

Implement concise and clear logic within event handlers to avoid performance bottlenecks, especially if progress changes occur frequently.

Handle Exceptions in Handlers

Wrap event handler logic in try-catch blocks if necessary to prevent unexpected exceptions from disrupting the UI.

Unsubscribe When No Longer Needed

Ensure that event handlers are unsubscribed when the control is disposed or the event is no longer needed to avoid memory leaks.


Common Pitfalls

Pitfall
Explanation
Avoidance Strategy

Ignoring Event Handler Performance

Complex operations inside event handlers can block the UI thread, leading to sluggish performance, particularly during rapid progress updates.

Offload heavy processing to background threads or use asynchronous patterns inside event handlers.

Not Unsubscribing Event Handlers

Failing to remove event subscriptions when the control is disposed may cause memory leaks or unexpected behavior in long-running applications.

Unsubscribe from events in the control's Dispose method or when they are no longer required.

Overcomplicating Event Logic

Implementing overly complex logic in event handlers can make debugging and maintenance difficult.

Keep event handler logic modular and focused on a single responsibility.


Usage Scenarios

Scenario
Description
Sample Code Integration

Monitoring Progress Changes

Respond to each progress update by logging the value or updating other UI elements when the ValueChanged event fires.

csharp<br>// Subscribe to the ValueChanged event to log progress updates<br>SiticoneHProgressBar progressBar = new SiticoneHProgressBar();<br>progressBar.ValueChanged += (sender, e) => {<br> Console.WriteLine($"Progress updated: {e.CurrentValue}");<br>};<br>this.Controls.Add(progressBar);<br>

Handling Indeterminate State Transition

When the progress bar switches between determinate and indeterminate modes, execute specific logic (e.g., pausing other operations) using the IndeterminateChanged event.

csharp<br>// Handle changes in the indeterminate mode<br>SiticoneHProgressBar progressBar = new SiticoneHProgressBar();<br>progressBar.IndeterminateChanged += (sender, e) => {<br> MessageBox.Show("The progress mode has changed.", "Mode Changed");<br>};<br>this.Controls.Add(progressBar);<br>

Alerting on Critical Progress Levels

Use the ProgressReachedThreshold event to alert the user or trigger corrective actions when the progress exceeds defined warning or error thresholds.

csharp<br>// Alert when a critical threshold is reached<br>SiticoneHProgressBar progressBar = new SiticoneHProgressBar();<br>progressBar.ProgressReachedThreshold += (sender, threshold) => {<br> MessageBox.Show($"Progress has reached the threshold of {threshold}.", "Threshold Alert");<br>};<br>this.Controls.Add(progressBar);<br>

Finalizing Processes on Completion

Execute cleanup or next-step logic when the progress completes using the ProgressCompleted event.

csharp<br>// Perform actions upon progress completion<br>SiticoneHProgressBar progressBar = new SiticoneHProgressBar();<br>progressBar.ProgressCompleted += (sender, e) => {<br> MessageBox.Show("Operation completed!", "Completion");<br>};<br>this.Controls.Add(progressBar);<br>

Synchronizing with System Theme

Update additional UI elements when the system theme changes by subscribing to the SystemThemeChanged event.

csharp<br>// Adjust UI elements when system theme changes<br>SiticoneHProgressBar progressBar = new SiticoneHProgressBar();<br>progressBar.SystemThemeChanged += (sender, newTheme) => {<br> // Update the form's background or other controls based on newTheme<br> this.BackColor = newTheme == SystemTheme.Dark ? Color.Black : Color.White;<br>};<br>this.Controls.Add(progressBar);<br>


Code Example and Demo

Below is an extensive example demonstrating how to integrate and handle various events within a simple WinForms application:

using System;
using System.Drawing;
using System.Windows.Forms;
using SiticoneNetFrameworkUI;

namespace EventHandlingDemo
{
    public class MainForm : Form
    {
        private SiticoneHProgressBar progressBar;
        private Label statusLabel;
        private Button startProgressButton;
        private Timer progressTimer;
        private int progressValue = 0;

        public MainForm()
        {
            // Initialize the form
            Text = "Event Handling Demo";
            Size = new Size(600, 400);
            this.StartPosition = FormStartPosition.CenterScreen;

            // Initialize the progress bar
            progressBar = new SiticoneHProgressBar()
            {
                Location = new Point(50, 50),
                Size = new Size(500, 30),
                Minimum = 0,
                Maximum = 100,
                Value = 0
            };

            // Subscribe to progress events
            progressBar.ValueChanged += ProgressBar_ValueChanged;
            progressBar.ProgressCompleted += ProgressBar_ProgressCompleted;
            progressBar.ProgressReachedThreshold += ProgressBar_ProgressReachedThreshold;
            progressBar.IndeterminateChanged += ProgressBar_IndeterminateChanged;
            progressBar.SystemThemeChanged += ProgressBar_SystemThemeChanged;

            // Initialize a label to display event statuses
            statusLabel = new Label()
            {
                Location = new Point(50, 100),
                AutoSize = true,
                Font = new Font("Segoe UI", 12, FontStyle.Bold),
                Text = "Status: Waiting for progress..."
            };

            // Button to start progress simulation
            startProgressButton = new Button()
            {
                Text = "Start Progress",
                Location = new Point(50, 150),
                AutoSize = true
            };
            startProgressButton.Click += StartProgressButton_Click;

            // Timer to simulate progress updates
            progressTimer = new Timer()
            {
                Interval = 500  // Update every 500ms
            };
            progressTimer.Tick += (s, e) =>
            {
                if (progressValue < progressBar.Maximum)
                {
                    progressValue += 10;
                    progressBar.Value = progressValue;
                }
                else
                {
                    progressTimer.Stop();
                }
            };

            // Add controls to the form
            Controls.Add(progressBar);
            Controls.Add(statusLabel);
            Controls.Add(startProgressButton);
        }

        private void StartProgressButton_Click(object sender, EventArgs e)
        {
            progressValue = progressBar.Minimum;
            progressBar.Value = progressValue;
            progressTimer.Start();
        }

        private void ProgressBar_ValueChanged(object sender, ValueChangedEventArgs e)
        {
            statusLabel.Text = $"Progress updated: {e.CurrentValue}%";
        }

        private void ProgressBar_ProgressCompleted(object sender, EventArgs e)
        {
            MessageBox.Show("Progress Completed!", "Completion");
            statusLabel.Text = "Status: Operation completed!";
        }

        private void ProgressBar_ProgressReachedThreshold(object sender, int threshold)
        {
            MessageBox.Show($"Progress has reached the threshold: {threshold}%", "Threshold Alert");
        }

        private void ProgressBar_IndeterminateChanged(object sender, EventArgs e)
        {
            statusLabel.Text = "Status: Indeterminate mode changed.";
        }

        private void ProgressBar_SystemThemeChanged(object sender, SystemTheme newTheme)
        {
            // Update the form's background color based on the new theme
            this.BackColor = newTheme == SystemTheme.Dark ? Color.FromArgb(30, 30, 30) : Color.White;
        }

        [STAThread]
        public static void Main()
        {
            Application.EnableVisualStyles();
            Application.Run(new MainForm());
        }
    }
}

Review

Aspect
Evaluation

Responsiveness

The event-driven approach ensures that the application reacts promptly to changes in progress, mode, and system theme, keeping the UI dynamic and responsive.

Flexibility

With multiple events available, developers can implement a wide range of custom behaviors, from logging progress to synchronizing the UI with system theme changes.

Ease of Integration

The clear event signatures and straightforward usage make it easy to integrate event handling into existing applications with minimal overhead.


Summary

The Event Handling feature provides a robust set of events that enable developers to react to changes in the progress bar's state and user interactions. By leveraging events such as ValueChanged, ProgressCompleted, and SystemThemeChanged, applications can maintain a dynamic, responsive UI that adapts to both user actions and system-level changes. This flexibility is essential for creating modern, interactive applications that provide real-time feedback and maintain visual consistency.


Additional Sections

Troubleshooting Tips

Tip
Description

Verify Event Subscriptions

Ensure that all event handlers are correctly subscribed, especially if events appear not to fire as expected.

Debug Handler Logic

Use logging or breakpoints within event handlers to verify that they are invoked and executing the desired logic without causing performance issues.

Unsubscribe Appropriately

When disposing of the control or form, make sure to unsubscribe event handlers to prevent memory leaks and unintended behavior.

Integration Checklist

Checklist Item
Status

Subscribe to all relevant events (ValueChanged, ProgressCompleted, etc.)

[ ] Done

Ensure event handlers execute without blocking the UI

[ ] Done

Unsubscribe from events when the control is disposed

[ ] Done

Test the control under different progress and theme conditions

[ ] Done

Validate that custom event logic (e.g., threshold alerts) works as intended

[ ] Done


This comprehensive documentation should assist developers in understanding, integrating, and leveraging the Event Handling feature of the provided control effectively.

PreviousSystem Theme TrackingNextSiticone VProgressBar

Last updated 4 months ago