📚
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
  • Feature Settings and Customization
  • Key Points
  • Best Practices
  • Common Pitfalls
  • Usage Scenarios
  • Real Life Usage Scenarios
  • Troubleshooting Tips
  • Integration Example
  • Review
  • Summary
  1. Net Framework | Net Core UI
  2. Gauges and Measurement
  3. Siticone GaugeClock

Events and Callbacks

Allows developers to integrate custom logic or update other parts of the application in response to changes in the gauge’s state, etc.

Overview

The Events and Callbacks feature in the SiticoneGaugeClock control exposes public events and virtual callback methods that are triggered during key operations. When the gauge value changes (either through programmatic updates or user interaction), the ValueChanged event is fired. Similarly, when an animated transition completes, the AnimationCompleted event is raised. Additionally, a standard PropertyChanged event is provided for notifying subscribers when a property value changes. These events enable the host application to respond dynamically—for example, by logging changes, updating related UI components, or triggering business logic.


Feature Settings and Customization

The table below outlines the available events and their corresponding callback methods, describing their function, default behavior, and sample usage snippets.

Event / Method
Description
Default Behavior / Signature
Sample Usage or Code Snippet

ValueChanged

Fires when the gauge’s value is updated (either through animation or direct assignment).

EventHandler: void(object sender, EventArgs e)

csharp<br/>gauge.ValueChanged += (s, e) => { MessageBox.Show("Gauge value changed."); };<br/>

AnimationCompleted

Fires when an ongoing animation (transition between values) completes.

EventHandler: void(object sender, EventArgs e)

csharp<br/>gauge.AnimationCompleted += (s, e) => { /* Additional logic after animation */ };<br/>

PropertyChanged

Notifies subscribers when a property value has changed; useful for data binding and UI updates.

PropertyChangedEventHandler: void(object sender, PropertyChangedEventArgs e)

csharp<br/>gauge.PropertyChanged += (s, e) => { Console.WriteLine($"{e.PropertyName} updated."); };<br/>

OnValueChanged()

Virtual method that raises the ValueChanged event; can be overridden to inject custom behavior.

protected virtual void OnValueChanged(EventArgs e)

Override this method in a derived control to add custom logic before or after the event is raised.

OnAnimationCompleted()

Virtual method that raises the AnimationCompleted event; can be overridden in a subclass.

protected virtual void OnAnimationCompleted(EventArgs e)

Override to customize the behavior when an animation finishes.

Note: The events are raised by internal logic (e.g., when the value is updated via SetTargetValue or when the animation timer completes), so subscribing to these events allows your application to monitor and react to gauge state changes.


Key Points

The table below summarizes the critical aspects of the Events and Callbacks feature.

Aspect
Details

Responsive Updates

Events ensure that any change in the gauge—whether through user interaction or programmatic updates—is immediately notified to subscribers.

Customizability

Virtual callback methods (OnValueChanged and OnAnimationCompleted) can be overridden to customize the control’s behavior.

Integration Flexibility

The events can be used for data binding, logging, triggering further actions, or updating related UI components.


Best Practices

Use the following guidelines to ensure effective utilization of events and callbacks.

Practice
Explanation
Code Example

Subscribe Early

Attach event handlers during initialization to capture all changes from the control.

csharp<br/>public MainForm() { InitializeComponent(); <br/> gauge.ValueChanged += Gauge_ValueChanged; }<br/><br/>private void Gauge_ValueChanged(object sender, EventArgs e) { /* Handle event */ }<br/>

Keep Event Handlers Lightweight

Ensure that event handler code executes quickly to avoid UI lag during frequent value updates or animations.

Offload heavy processing to background threads if needed.

Override Virtual Methods When Necessary

For custom behavior that must occur before or after the standard event raising, override OnValueChanged or OnAnimationCompleted.

csharp<br/>protected override void OnValueChanged(EventArgs e) { /* Custom logic */; base.OnValueChanged(e); }<br/>

Unsubscribe When Not Needed

Detach event handlers when the control is disposed or no longer needed to prevent memory leaks.

In the Dispose method, unsubscribe from events.


Common Pitfalls

Avoid these common issues when working with events and callbacks.

Pitfall
Description
Recommendation

Neglecting to Unsubscribe

Failure to remove event handlers can lead to memory leaks and unintended behavior when controls are re-created.

Ensure proper unsubscription in Dispose or when the event is no longer needed.

Overly Complex Handlers

Complex or long-running operations inside event handlers may block the UI thread, causing lag.

Keep handlers simple; consider using asynchronous methods or delegating heavy work to background threads.

Overriding Without Calling Base Methods

Overriding OnValueChanged or OnAnimationCompleted without calling the base method may prevent the event from being raised.

Always call base.OnValueChanged(e) or base.OnAnimationCompleted(e) when overriding.


Usage Scenarios

The table below outlines typical scenarios where the Events and Callbacks feature is advantageous.

Scenario
Description
Sample Code or Explanation

Real-Time Dashboard Updates

Automatically update other UI elements or trigger analytics when the gauge value changes.

Subscribe to ValueChanged to update a status label with the latest value.

Animation-Driven Actions

Trigger specific actions (such as logging or triggering further animations) once the gauge animation completes.

Subscribe to AnimationCompleted to log the end of an animated transition.

Data Binding and MVVM Integration

Use PropertyChanged events to keep bound view models updated when gauge properties change.

Bind the PropertyChanged event to update a view model property in a data binding scenario.


Real Life Usage Scenarios

The table below presents real-world examples demonstrating the application of events and callbacks.

Real Life Scenario
Description
Code Example

Financial Trading Application

Update a summary panel in real time as the gauge (e.g., market index) changes by subscribing to ValueChanged.

csharp<br/>gauge.ValueChanged += (s, e) => { summaryPanel.Update(gauge.Value); };<br/>

Automotive Dashboard

Trigger safety alerts when the speed gauge animation completes, ensuring that alerts are only fired once the transition finishes.

csharp<br/>gauge.AnimationCompleted += (s, e) => { AlertSystem.CheckSpeed(gauge.Value); };<br/>

Industrial Process Control

Use PropertyChanged events to automatically log changes to critical gauge properties for audit and analysis purposes.

csharp<br/>gauge.PropertyChanged += (s, e) => { Logger.Log($"{e.PropertyName} changed."); };<br/>


Troubleshooting Tips

If issues arise with event handling or callbacks, consider the following troubleshooting tips.

Issue
Potential Cause
Suggested Resolution

Event Not Firing

The event may not fire if the corresponding property is not updated, or the base method is not called in an override.

Check that properties are updated correctly and that overridden methods call the base implementation.

Memory Leaks

Persistent subscriptions from events can cause memory leaks if not unsubscribed properly.

Unsubscribe from events in the control's Dispose method or when the handler is no longer needed.

Unresponsive UI

Long-running code within an event handler can block the UI thread.

Optimize event handler code; offload heavy work to a background thread or use asynchronous methods.


Integration Example

Below is a complete code sample demonstrating how to integrate and handle events and callbacks in a WinForms application using the SiticoneGaugeClock control:

using System;
using System.ComponentModel;
using System.Drawing;
using System.Windows.Forms;
using SiticoneNetFrameworkUI; // Ensure the namespace matches your project setup

namespace GaugeDemoApp
{
    public class MainForm : Form
    {
        private SiticoneGaugeClock gauge;
        private Label statusLabel;

        public MainForm()
        {
            InitializeComponent();
            RegisterEventHandlers();
        }

        private void InitializeComponent()
        {
            this.gauge = new SiticoneGaugeClock();
            this.statusLabel = new Label();
            this.SuspendLayout();
            // 
            // gauge
            // 
            this.gauge.Location = new Point(30, 30);
            this.gauge.Size = new Size(300, 300);
            // Set an initial value for demonstration
            this.gauge.Value = 50f;
            // 
            // statusLabel
            // 
            this.statusLabel.Location = new Point(30, 340);
            this.statusLabel.Size = new Size(300, 30);
            this.statusLabel.Text = "Gauge value: 50";
            // 
            // MainForm
            // 
            this.ClientSize = new Size(360, 400);
            this.Controls.Add(this.gauge);
            this.Controls.Add(this.statusLabel);
            this.Text = "Gauge Demo - Events and Callbacks";
            this.ResumeLayout(false);
        }

        private void RegisterEventHandlers()
        {
            // Subscribe to ValueChanged to update the status label when the gauge value changes.
            this.gauge.ValueChanged += Gauge_ValueChanged;
            // Subscribe to AnimationCompleted to perform actions after an animation finishes.
            this.gauge.AnimationCompleted += Gauge_AnimationCompleted;
            // Subscribe to PropertyChanged for logging changes.
            this.gauge.PropertyChanged += Gauge_PropertyChanged;
        }

        private void Gauge_ValueChanged(object sender, EventArgs e)
        {
            // Update the status label with the new gauge value.
            statusLabel.Text = $"Gauge value: {gauge.Value:F1}";
        }

        private void Gauge_AnimationCompleted(object sender, EventArgs e)
        {
            // Notify that the animation has completed.
            MessageBox.Show("Animation completed. Gauge value update finished.", "Animation", MessageBoxButtons.OK, MessageBoxIcon.Information);
        }

        private void Gauge_PropertyChanged(object sender, PropertyChangedEventArgs e)
        {
            // Log the property change (could also update other UI elements or trigger further actions).
            Console.WriteLine($"Property {e.PropertyName} has changed.");
        }

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

In this example, the MainForm subscribes to the ValueChanged, AnimationCompleted, and PropertyChanged events. When the gauge value updates, the status label is refreshed; once an animation completes, a message box is displayed; and every property change is logged to the console. This illustrates how to use events and callbacks to integrate gauge state updates with other UI elements and application logic.


Review

The Events and Callbacks feature provides a robust mechanism for notifying your application of changes to the gauge. By subscribing to events like ValueChanged and AnimationCompleted, you can seamlessly integrate the gauge with other UI elements and business logic. Overriding virtual methods further enhances customization by allowing you to inject specific behavior into the control’s internal workflow.


Summary

The Events and Callbacks feature allows developers to respond dynamically to gauge state changes by subscribing to events and, if needed, overriding virtual callback methods. With events such as ValueChanged, AnimationCompleted, and PropertyChanged, you can update the UI, trigger further actions, and log changes efficiently. Detailed tables, best practices, usage scenarios, troubleshooting tips, and a full integration example have been provided to facilitate smooth implementation and effective customization in your WinForms applications.


Additional sections such as Key Points, Best Practices, and Real Life Usage Scenarios further assist in optimizing the use of events and callbacks, ensuring that your application remains responsive and interactive as gauge values change.

PreviousSection ManagementNextSiticone GaugeDigital

Last updated 4 months ago