📚
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
  • Key Points
  • Best Practices
  • Common Pitfalls
  • Usage Scenarios
  • Real Life Usage Scenarios
  • Troubleshooting Tips
  • Code Examples and Demos
  • Review
  • Summary
  • Additional Useful Sections
  1. Net Framework | Net Core UI
  2. Utility Controls
  3. Siticone TaskbarBadgeS.

Events and Callbacks

A component that notifies subscribers about badge updates, animation completions, and system theme changes through a series of events and callbacks.

Overview

The Events and Callbacks feature of the SiticoneTaskbarBadgeSystem component provides mechanisms for the application to react to changes in the badge value, the completion of animations, and system theme alterations. The component exposes events such as BadgeChanged, AnimationCompleted, BadgeUpdating, and SystemThemeChanged. These events enable developers to intercept badge updates before they occur, react after animations complete, and update the UI in response to system theme changes. Remember that for all dynamic features, including events, the ParentForm property must be set in the OnShown overload method of the parent form using taskbarBadge.ParentForm = this;—do not rely solely on auto-detection.


Key Points

Key Point
Description

Pre-Update Interception

The BadgeUpdating event allows intercepting and possibly canceling badge updates before they are applied.

Post-Update Notification

The BadgeChanged event is fired after the badge value has been updated, providing a notification to subscribers.

Animation Completion

The AnimationCompleted event signals that an animation sequence has finished, allowing for subsequent actions or UI updates.

System Theme Change

The SystemThemeChanged event notifies subscribers when the system theme changes, ensuring the application can update its UI accordingly.


Best Practices

Best Practice
Description

Subscribe Early

Subscribe to the events as early as possible, ideally during form initialization, to capture all relevant state changes.

Validate Event Data

Use the information provided in the event arguments (e.g., BadgeUpdateEventArgs and SystemThemeChangedEventArgs) to make informed UI updates.

Handle Cancellation Appropriately

In the BadgeUpdating event, check the Cancel flag and update the new value accordingly if the update is to be prevented.

Update UI on Event Callbacks

Use the AnimationCompleted and SystemThemeChanged events to adjust UI elements, ensuring that all state transitions are seamless.


Common Pitfalls

Pitfall
How to Avoid It

Late Subscription to Events

Ensure that you subscribe to events in the form's initialization process; subscribing after updates may cause missed events.

Ignoring the Cancel Flag in BadgeUpdating

When handling BadgeUpdating, always check and respect the Cancel flag to avoid unwanted badge updates.

Overcomplicating Event Handlers

Keep event handler logic simple and focused to avoid performance issues, especially in high-frequency update scenarios.

Forgetting ParentForm Integration

Failing to set the ParentForm in the OnShown method may cause events related to animations and system theme changes to not fire correctly.


Usage Scenarios

Scenario
Description

Dynamic Badge Management

Use BadgeUpdating to validate or modify new badge values before they are applied, ensuring data integrity.

Sequential Animation Updates

Use AnimationCompleted to chain UI actions after an animation finishes, such as logging or further UI refreshes.

Adaptive UI Responses

Subscribe to SystemThemeChanged to adapt UI components (e.g., badge colors) dynamically when the system theme changes.

Post-Update Notification

Use BadgeChanged to trigger additional actions (e.g., updating counters or logs) after the badge value has been successfully updated.


Real Life Usage Scenarios

Scenario
Description

Email or Messaging Applications

Use BadgeUpdating to intercept badge changes for new messages and trigger visual or audio notifications before finalizing the update.

Interactive Dashboards

Leverage AnimationCompleted to refresh data panels once the badge animation has completed, ensuring smooth transitions.

Themed Applications

Use SystemThemeChanged to switch UI themes in real time, so that the badge and related components remain consistent with system settings.

Mobile-like Notification Systems

Combine BadgeChanged and AnimationCompleted events to synchronize notification updates with other UI animations for a polished experience.


Troubleshooting Tips

Tip
Description

Ensure Early Event Subscription

Subscribe to events early during the initialization phase to avoid missing critical callbacks.

Debug Event Handlers

Insert logging or breakpoints in your event handlers (BadgeUpdating, BadgeChanged, etc.) to verify that they are being fired as expected.

Validate Event Arguments

Check the event argument values in BadgeUpdating and SystemThemeChanged to ensure they contain the expected data.

Confirm ParentForm Setup

Verify that the ParentForm property is set only in the OnShown method to allow proper initialization and firing of events.


Code Examples and Demos

Integration in Parent Form

Ensure that the ParentForm property is set in the OnShown method to enable proper event handling.

public partial class MainForm : Form
{
    private SiticoneTaskbarBadgeSystem taskbarBadge;

    public MainForm()
    {
        InitializeComponent();
        taskbarBadge = new SiticoneTaskbarBadgeSystem();

        // Subscribe to events early in the initialization process.
        taskbarBadge.BadgeUpdating += TaskbarBadge_BadgeUpdating;
        taskbarBadge.BadgeChanged += TaskbarBadge_BadgeChanged;
        taskbarBadge.AnimationCompleted += TaskbarBadge_AnimationCompleted;
        taskbarBadge.SystemThemeChanged += TaskbarBadge_SystemThemeChanged;
    }

    protected override void OnShown(EventArgs e)
    {
        base.OnShown(e);
        // Explicitly set the ParentForm property here.
        taskbarBadge.ParentForm = this;
    }

    private void TaskbarBadge_BadgeUpdating(object sender, SiticoneTaskbarBadgeSystem.BadgeUpdateEventArgs e)
    {
        // Example: Log the badge update or modify the new value.
        Console.WriteLine($"Badge updating from {e.OldValue} to {e.NewValue}");
        // To cancel the update, you can set e.Cancel = true;
    }

    private void TaskbarBadge_BadgeChanged(object sender, EventArgs e)
    {
        // Respond to a successful badge update.
        Console.WriteLine("Badge value has been updated.");
    }

    private void TaskbarBadge_AnimationCompleted(object sender, EventArgs e)
    {
        // Handle post-animation logic here.
        Console.WriteLine("Badge animation completed.");
    }

    private void TaskbarBadge_SystemThemeChanged(object sender, SiticoneTaskbarBadgeSystem.SystemThemeChangedEventArgs e)
    {
        // Update UI elements based on the new system theme.
        Console.WriteLine($"System theme changed to: {e.NewTheme}");
    }
}

Demonstrating Badge Update with Interception

Use event handlers to modify or cancel badge updates before they are applied.

private void btnUpdateBadge_Click(object sender, EventArgs e)
{
    // This example shows a scenario where the badge is updated only if the new value is acceptable.
    int newBadgeValue = taskbarBadge.BadgeValue + 1;
    // The BadgeUpdating event will be triggered before the value is actually updated.
    taskbarBadge.BadgeValue = newBadgeValue;
}

Complete Demo Application Flow

Below is a complete demo that integrates event subscriptions and dynamic updates with explicit ParentForm assignment in the OnShown method.

public partial class MainForm : Form
{
    private SiticoneTaskbarBadgeSystem taskbarBadge;

    public MainForm()
    {
        InitializeComponent();
        taskbarBadge = new SiticoneTaskbarBadgeSystem();

        // Subscribe to events.
        taskbarBadge.BadgeUpdating += TaskbarBadge_BadgeUpdating;
        taskbarBadge.BadgeChanged += TaskbarBadge_BadgeChanged;
        taskbarBadge.AnimationCompleted += TaskbarBadge_AnimationCompleted;
        taskbarBadge.SystemThemeChanged += TaskbarBadge_SystemThemeChanged;
    }

    protected override void OnShown(EventArgs e)
    {
        base.OnShown(e);
        // Set the ParentForm property here; this is the only acceptable location for it.
        taskbarBadge.ParentForm = this;
    }

    private void TaskbarBadge_BadgeUpdating(object sender, SiticoneTaskbarBadgeSystem.BadgeUpdateEventArgs e)
    {
        // Example: Validate or modify the badge update.
        Console.WriteLine($"Attempting to update badge from {e.OldValue} to {e.NewValue}");
        if (e.NewValue < 0)
        {
            // Cancel the update if the new value is invalid.
            e.Cancel = true;
            Console.WriteLine("Badge update cancelled: Negative value not allowed.");
        }
    }

    private void TaskbarBadge_BadgeChanged(object sender, EventArgs e)
    {
        // Notification that the badge value has changed.
        Console.WriteLine("Badge has been successfully updated.");
    }

    private void TaskbarBadge_AnimationCompleted(object sender, EventArgs e)
    {
        // Perform additional actions after the badge animation completes.
        Console.WriteLine("Badge animation completed successfully.");
    }

    private void TaskbarBadge_SystemThemeChanged(object sender, SiticoneTaskbarBadgeSystem.SystemThemeChangedEventArgs e)
    {
        // Adjust UI elements based on the new system theme.
        Console.WriteLine($"System theme changed to: {e.NewTheme}");
    }

    private void btnIncreaseBadge_Click(object sender, EventArgs e)
    {
        if (taskbarBadge.BadgeType != BadgeType.Notification)
        {
            taskbarBadge.BadgeValue += 1;
        }
    }

    private void btnDecreaseBadge_Click(object sender, EventArgs e)
    {
        if (taskbarBadge.BadgeType != BadgeType.Notification && taskbarBadge.BadgeValue > 0)
        {
            taskbarBadge.BadgeValue -= 1;
        }
    }
}

Review

Aspect
Description

Early Subscription

Subscribe to events during form initialization to ensure no badge or theme changes are missed.

Interception Mechanism

Use BadgeUpdating to intercept and possibly cancel badge updates before they occur, allowing for validation and custom logic.

Post-Event Notifications

BadgeChanged and AnimationCompleted notify the application of successful updates and animation completions, enabling further actions.

Dynamic UI Adaptation

SystemThemeChanged allows the application to update its UI dynamically in response to system theme changes.


Summary

Summary Aspect
Description

Feature Purpose

Provides a robust event-driven mechanism to handle badge updates, animations, and system theme changes within the application.

Implementation Focus

Subscribe to events early and ensure the ParentForm is set only in the OnShown method to guarantee proper event firing and handling.

Developer Considerations

Respect event data and cancellation flags to maintain data integrity and deliver a seamless user experience.

Benefit

Enhances application responsiveness by allowing developers to react to changes in badge state, animation completion, and theme shifts.


Additional Useful Sections

Integration Checklist

Step
Details

1. Instantiate the Badge Component

Create an instance of SiticoneTaskbarBadgeSystem in your main form.

2. Subscribe to Events

Subscribe to BadgeUpdating, BadgeChanged, AnimationCompleted, and SystemThemeChanged events during form initialization.

3. Override OnShown

Override the parent's OnShown method to set the ParentForm property explicitly with taskbarBadge.ParentForm = this;.

4. Test Event Handling

Verify that each event is fired at the appropriate time by performing badge updates and theme changes.

5. Validate Event Arguments

Confirm that the event arguments (e.g., BadgeUpdateEventArgs) contain the correct data for processing within your event handlers.

Demo Application Flow

public partial class MainForm : Form
{
    private SiticoneTaskbarBadgeSystem taskbarBadge;

    public MainForm()
    {
        InitializeComponent();
        taskbarBadge = new SiticoneTaskbarBadgeSystem();
        // Subscribe to all relevant events.
        taskbarBadge.BadgeUpdating += TaskbarBadge_BadgeUpdating;
        taskbarBadge.BadgeChanged += TaskbarBadge_BadgeChanged;
        taskbarBadge.AnimationCompleted += TaskbarBadge_AnimationCompleted;
        taskbarBadge.SystemThemeChanged += TaskbarBadge_SystemThemeChanged;
    }

    protected override void OnShown(EventArgs e)
    {
        base.OnShown(e);
        // Set the ParentForm property here only.
        taskbarBadge.ParentForm = this;
    }

    private void TaskbarBadge_BadgeUpdating(object sender, SiticoneTaskbarBadgeSystem.BadgeUpdateEventArgs e)
    {
        // Log and optionally cancel badge updates.
        Console.WriteLine($"Updating badge from {e.OldValue} to {e.NewValue}");
        if (e.NewValue < 0)
        {
            e.Cancel = true;
            Console.WriteLine("Update cancelled: Negative value not allowed.");
        }
    }

    private void TaskbarBadge_BadgeChanged(object sender, EventArgs e)
    {
        Console.WriteLine("Badge update completed.");
    }

    private void TaskbarBadge_AnimationCompleted(object sender, EventArgs e)
    {
        Console.WriteLine("Animation finished.");
    }

    private void TaskbarBadge_SystemThemeChanged(object sender, SiticoneTaskbarBadgeSystem.SystemThemeChangedEventArgs e)
    {
        Console.WriteLine($"Theme changed to: {e.NewTheme}");
    }

    private void btnIncreaseBadge_Click(object sender, EventArgs e)
    {
        if (taskbarBadge.BadgeType != BadgeType.Notification)
        {
            taskbarBadge.BadgeValue += 1;
        }
    }

    private void btnDecreaseBadge_Click(object sender, EventArgs e)
    {
        if (taskbarBadge.BadgeType != BadgeType.Notification && taskbarBadge.BadgeValue > 0)
        {
            taskbarBadge.BadgeValue -= 1;
        }
    }
}

This comprehensive documentation for the Events and Callbacks feature covers how to subscribe to, handle, and utilize various events in the SiticoneTaskbarBadgeSystem component. Following these guidelines and examples ensures that developers can react dynamically to badge updates, animation completions, and system theme changes—thereby enhancing the overall responsiveness and adaptability of their .NET WinForms applications.

PreviousParent Form IntegrationNextSiticone ThemeSwitcher

Last updated 4 months ago