EleCho.WpfSuite 0.9.16

Prefix Reserved
dotnet add package EleCho.WpfSuite --version 0.9.16                
NuGet\Install-Package EleCho.WpfSuite -Version 0.9.16                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EleCho.WpfSuite" Version="0.9.16" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EleCho.WpfSuite --version 0.9.16                
#r "nuget: EleCho.WpfSuite, 0.9.16"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EleCho.WpfSuite as a Cake Addin
#addin nuget:?package=EleCho.WpfSuite&version=0.9.16

// Install EleCho.WpfSuite as a Cake Tool
#tool nuget:?package=EleCho.WpfSuite&version=0.9.16                

EleCho.WpfSuite

WPF layout panels, controls, value converters, markup extensions, transitions and utilities

For full documentation, see wpfsuite.elecho.dev

Usage

Add XML namespace to your XAML file:

<Window xmlns:ws="https://schemas.elecho.dev/wpfsuite">
    ...     
</Window>

Enjoy!

<Window x:Class="WpfTest.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfTest"
        xmlns:ws="https://schemas.elecho.dev/wpfsuite"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">

    <ws:ScrollViewer Margin="12"
                     ScrollWithWheelDelta="True">
        <ws:StackPanel Spacing="8">
            <ws:TextBox Width="200"
                        Placeholder="This is a text box with placeholder"/>
            <ws:Image Source="/Assets/TestAvatar.jpg"
                      CornerRadius="10"/>

            <StackPanel>
                <TextBlock Text="WrapPanel with spacing"/>
                <ItemsControl ItemsSource="{Binding TestItems}">
                    <ItemsControl.ItemsPanel>
                        <ItemsPanelTemplate>
                            <ws:WrapPanel HorizontalSpacing="8"
                                          VerticalSpacing="8"/>
                        </ItemsPanelTemplate>
                    </ItemsControl.ItemsPanel>
                </ItemsControl>
            </StackPanel>
        </ws:StackPanel>
    </ws:ScrollViewer>

</Window>

Features

The following is a summary of the features of WPF Suite.

Layout panels:

  • StackPanel: Origin stack panel with Spacing property
  • WrapPanel: Origin wrap panel with HorizontalSpacing and VerticalSpacing property
  • FlexPanel: Flex layout implementation with HorizontalSpacing and VerticalSpacing property
  • MasonryPanel: Masonry layout implementation with FlowSpacing and ItemSpacing property

Controls:

The WPF Suite has overridden many native controls, added some properties, or optimized their logic. You can directly access the corresponding controls via the WPF Suite namespace.

Almost all controls have added the CornerRadius property, so now if you need to adjust the corner radius of a certain control, you just need to set this property instead of changing the control template.

<ws:Button Content="Hello world"
           CornerRadius="3">

If a corresponding control has multiple states, such as "mouse hover" and "mouse press", WPF Suite also exposes certain values corresponding to these states directly through properties, such as "HoverBackground" which represents the background color used by the control in the hover state. Therefore, if you need to change the style of certain controls in different states, you just need to set the corresponding properties.

<ws:Button Content="Hello world"
           HoverBackground="Pink">

When using the default Border in WPF, it allows the content to exceed the bounds of the Border. Even if you set a CornerRadius and ClipToBounds, it won't be able to clip the content to fit within the rounded corners. However, when using the Border provided by the WPF Suite, you can achieve automatic clipping by using BorderContentAdapter or binding the content's Clip property to the Border's ContentClip property.

<Border CornerRadius="5" Width="50" Height="50">
    <ws:BorderContentAdapter>
        <Rectangle Fill="Pink"/>
    </ws:BorderContentAdapter>
</Border>

<ws:Border CornerRadius="5" Width="50" Height="50">
    <Rectangle Fill="Pink"
               Clip="{Binding RelativeSource={RelativeSource AncestorType=ws:Border},Path=ContentClip}"/>
</ws:Border>

<ws:Border x:Name="NamedBorder" CornerRadius="5" Width="50" Height="50">
    <Rectangle Fill="Pink"
               Clip="{Binding ElementName=NamedBorder,Path=ContentClip}"/>
</ws:Border>

ContentControl in WPF suite can be understood as a ContentControl with added transition effects. After setting the transition effects, the specified transition effect will be executed when the content changes.

<ws:ContentControl Content="Some content">
    <ws:ContentControl.Transition>
        <ws:SlideFadeTransition Duration="0:0:0.200"/>
    </ws:ContentControl.Transition>
</ws:ContentControl>

WPF Suite has also made several optimizations for ScrollViewer. For example, it now supports smooth scrolling with the mouse and allows for finer scrolling using touchpad, which was not available in the original ScrollViewer.

<ws:ScrollViewer>
    <ws:StackPanel Spacing="8">
        <TextBlock Text="Some content"/>
        
    </ws:StackPanel>
</ws:ScrollViewer>

The enhanced features of ScrollViewer can be disabled via its properties.

In WPF, by default you cannot scroll the content of a ScrollViewer through a pen device. However, WPF Suite provides a solution to simulate the pen as a touch device. Through this method, you can use the pen to scroll the content of the ScrollViewer.

<ws:ScrollViewer ws:StylusTouchDevice.Simulate="True">
    <ws:StackPanel Spacing="8">
        <TextBlock Text="Some content"/>
        
    </ws:StackPanel>
</ws:ScrollViewer>

Transitions:

  • FadeTransition: Fades out the current content and fades in the new content by animating the opacity
  • SlideTransition: Moves the old content out of view, and the new content into view
  • SlideFadeTransition: Composite of SlideTransition and FadeTransition
  • ScaleTransition: Scale the old content to smaller and fade out, and scale the new content from a larger zoom to 1
  • ScaleFadeTransition: Composite of ScaleTransition and FadeTransition
  • RotateTransition: Rotate the old content and new content by specified angle
  • RotateFadeTransition: Composite of RotateTransition and FadeTransition

Value converters:

  • AddNumberConverter: Mathematical calculations, addition
  • SubtractNumberConverter: Mathematical calculations, subtraction
  • MultiplyNumberConverter: Mathematical calculations, multiplication
  • DivideNumberConverter: Mathematical calculations, division
  • ClampNumberConverter: Clamps the given value between the given minimum float and maximum values
  • NumberCompareConverter: Compare between numbers, support equal, not equal, greator than, greator or equal, less than, less or equal
  • EqualConverter: Check if the value equals converter parameter
  • NotEqualConverter: Check if the value not equal to converter parameter
  • ValueIsNullConverter: Determines whether the object is empty
  • ValueIsNotNullConverter: Determines whether the object is not empty
  • InvertBooleanConverter: Inverts the boolean value
  • ValueConverterGroup: Converts the value using the specified multiple converters
  • StringIsNullOrEmptyConverter: Check if string is null or empty, returns a boolean value
  • StringIsNotNullOrEmptyConverter: Check if string is not null or empty, returns a boolean value
  • StringIsNullOrWhiteSpaceConverter: Check if string is null or white space, returns a boolean value
  • StringIsNotNullOrWhiteSpaceConverter: Check if string is not null or white space, returns a boolean value
  • CollectionIsNullOrEmptyConverter: Check if collection is null or empty, returns a boolean value
  • CollectionIsNotNullOrEmptyConverter: Check if collection is not null or empty, returns a boolean value
  • StringToImageSourceConverter: Convert any valid URI string to image source
  • NumberToThicknessConverter: Convert number to uniform thickness
  • NumberToCornerRadiusConverter: Convert number to uniform corner radius
  • InvertThicknessConverter: Invert the given thickness value

Markup extensions:

  • String: Represents text as a sequence of UTF-16 code units. (returns System.String)
  • Char: Represents a character as a UTF-16 code unit. (returns System.Char)
  • Boolean: Represents a Boolean (true or false) value. (returns System.Boolean)
  • Byte: Represents an 8-bit unsigned integer. (returns System.Byte)
  • Int16: Represents a 16-bit signed integer. (returns System.Int16)
  • Int32: Represents a 32-bit signed integer. (returns System.Int32)
  • Int64: Represents a 64-bit signed integer. (returns System.Int64)
  • Single: Represents a single-precision floating-point number. (returns System.Single)
  • Double: Represents a double-precision floating-point number. (returns System.Double)
  • Decimal: Represents a decimal floating-point number. (returns System.Decimal)
  • HsvColor: Represents a color from HSV color space values (returns System.Windows.Media.Color)

Animations:

  • CornerRadiusAnimation: Animates the value of a CornerRadius property between two target values using linear interpolation over a specified Duration.
  • QuadraticBezierEase: Quadratic bezier curve easing function
  • CubicBezierEase: Cubic bezier curve easing function

Utilities:

You can easily create windows with Mica or Acrylic materials through WPF Suite, just like this:

<Window ... 
        xmlns:ws="https://schemas.elecho.dev/wpfsuite"
        Background="Transparent"
        ws:WindowOption.Backdrop="Mica">
    ...
</Window>

You can also set the color mode of the current window. When IsDarkMode is set to True, Mica and Acrylic materials will also change accordingly.

<Window ...
        xmlns:ws="https://schemas.elecho.dev/wpfsuite"
        Background="Transparent"
        ws:WindowOption.Backdrop="Mica"
        ws.WindowOption.IsDarkMode="True">
    ...
</Window>

WindowOption.Backdrop can be used only on Windows11, if you want use acrylic on Windows10, you should use WindowOption.AccentState:

<Window ...
        xmlns:ws="https://schemas.elecho.dev/wpfsuite"
        Background="Transparent"
        ws.WindowOption.AccentState="AcrylicBlurBehind">
    ...
</Window>

If you want to use an acrylic material mixed with a certain color, there are two options.

Use ordinary acrylic material and set the form color to a translucent corresponding color.

<Window ...
        xmlns:ws="https://schemas.elecho.dev/wpfsuite"
        Background="#11FF0000"
        ws.WindowOption.AccentState="AcrylicBlurBehind">
    ...
</Window>

Or use accent gradient color property.

<Window ...
        xmlns:ws="https://schemas.elecho.dev/wpfsuite"
        Background="Transparent"
        ws.WindowOption.AccentState="AcrylicBlurBehind"
        ws.WindowOption.AccentGradientColor="#33FF8888">
    ...
</Window>
  • BindingProxy: A utility class for binding, commonly used when a collection element has property to be bound to a page DataContext
  • ScrollViewerUtils: Utilities for set vertical offset and horizontal offset of scroll viewer and scroll content presenter
  • ItemsControlUtils: Utilities for removing item from ItemsControl with transitions
  • ColorUtils: Utilities for color calculation
  • BooleanValues: Static value of boolean 'true' and 'false'
  • ValidationUtils: DependencyProperty validation utilities
Product Compatible and additional computed target framework versions.
.NET net6.0-windows7.0 is compatible.  net7.0-windows was computed.  net8.0-windows was computed.  net8.0-windows7.0 is compatible. 
.NET Framework net45 is compatible.  net451 was computed.  net452 was computed.  net46 is compatible.  net461 was computed.  net462 was computed.  net463 was computed.  net47 is compatible.  net471 was computed.  net472 was computed.  net48 is compatible.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on EleCho.WpfSuite:

Package Downloads
EleCho.WpfSuite.FluentDesign

FluentDesign for WPF Suite

GitHub repositories (1)

Showing the top 1 popular GitHub repositories that depend on EleCho.WpfSuite:

Repository Stars
SlimeNull/ScreenBroadcaster
Screen broadcast and remote control tool based on FFmpeg. 基于 FFmpeg 的屏幕广播与远程操控工具.
Version Downloads Last updated
0.9.16 46 1/5/2025
0.9.15.1 74 1/2/2025
0.9.15 87 12/31/2024
0.9.14 127 12/4/2024
0.9.13 85 12/4/2024
0.9.12 112 12/1/2024
0.9.11 83 11/28/2024
0.9.10.1 75 11/27/2024
0.9.10 104 11/22/2024
0.9.9.2 101 11/22/2024
0.9.9.1 94 11/22/2024
0.9.9 95 11/22/2024
0.9.8 95 11/20/2024
0.9.7 127 11/13/2024
0.9.6 88 11/13/2024
0.9.5 127 11/10/2024
0.9.4 114 11/10/2024
0.9.3 87 11/10/2024
0.9.2 90 11/9/2024
0.9.1.3 113 11/9/2024
0.9.1.2 116 10/25/2024
0.9.1.1 84 10/25/2024
0.9.1 185 9/28/2024
0.9.0 95 9/26/2024
0.8.1 279 9/5/2024
0.8.0 122 8/31/2024
0.7.4 111 8/30/2024
0.7.3 105 8/29/2024
0.7.2 109 8/26/2024
0.7.1 131 8/22/2024
0.7.0 176 8/20/2024
0.6.7 155 8/19/2024
0.6.6 121 8/18/2024
0.6.5 130 8/17/2024
0.6.4 122 8/8/2024
0.6.3 106 8/7/2024
0.6.2 70 8/5/2024
0.6.1 162 7/17/2024
0.6.0 107 7/15/2024
0.5.3 143 7/3/2024
0.5.2 87 7/3/2024
0.5.1 90 7/2/2024
0.4.1 227 6/13/2024
0.4.0 142 6/7/2024
0.3.3 114 5/30/2024
0.3.2 96 5/28/2024
0.3.1 111 5/28/2024
0.3.0 120 5/25/2024
0.2.1 123 4/25/2024
0.2.0 122 4/24/2024
0.1.6 117 4/20/2024
0.1.5 111 4/18/2024
0.1.4 100 4/18/2024
0.1.3 111 4/18/2024
0.1.2 117 4/17/2024
0.1.1 122 4/16/2024
0.1.0 120 4/16/2024
0.0.14 107 4/15/2024
0.0.13 111 4/15/2024
0.0.12 100 4/15/2024
0.0.11 150 4/14/2024
0.0.10 134 4/13/2024