WPF-UI.Violeta
3.0.5.8
See the version list below for details.
dotnet add package WPF-UI.Violeta --version 3.0.5.8
NuGet\Install-Package WPF-UI.Violeta -Version 3.0.5.8
<PackageReference Include="WPF-UI.Violeta" Version="3.0.5.8" />
paket add WPF-UI.Violeta --version 3.0.5.8
#r "nuget: WPF-UI.Violeta, 3.0.5.8"
// Install WPF-UI.Violeta as a Cake Addin #addin nuget:?package=WPF-UI.Violeta&version=3.0.5.8 // Install WPF-UI.Violeta as a Cake Tool #tool nuget:?package=WPF-UI.Violeta&version=3.0.5.8
WPF UI Violeta
WPF UI Violeta is based on WPF UI, and provides the Fluent experience in your known and loved WPF framework. Some new immersive controls like Toast
, Flyout
, ContentDialog
, MessageBox
and etc.
Some idea or codes are ported from ModernWpf and Fischless.
When I decided to create this project I was listening to the song Violeta
.
🚀 Getting started
Similar to WPF UI.
<Application
xmlns:ui="http://schemas.lepo.co/wpfui/2022/xaml"
xmlns:vio="http://schemas.lepo.co/wpfui/2022/xaml/violeta">
<Application.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ui:ThemesDictionary Theme="Dark" />
<ui:ControlsDictionary />
<vio:ControlsDictionary />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</Application.Resources>
</Application>
👋Examples
Toast
Toast
is an independent popup notification that automatically disappears after a specified time.Toast.Information("I am information message"); Toast.Error("I am error message"); Toast.Success("I am success message"); Toast.Warning("I am warning message"); Toast.Show(owner: null!, "I am any message", new ToastConfig());
Flyout
The
FlyoutService
enables you to attachFlyout
menus or tooltips to various controls such asButton
, providing a flexible and intuitive way to display additional content or options.<ui:Button Content="Show Flyout"> <ui:FlyoutService.Flyout> <ui:Flyout Placement="Bottom"> <StackPanel> <TextBlock HorizontalAlignment="Left" Text="Show the flyout message here" /> <Button Command="{Binding GotItCommand}" Content="Got it" /> </StackPanel> </ui:Flyout> </ui:FlyoutService.Flyout> </ui:Button>
ContentDialog
The
ContentDialogHostService
simplifies the creation and management ofContentDialog
instances in your application.ContentDialog dialog = new() { Title = "My sample dialog", Content = "Content of the dialog", CloseButtonText = "Close button", PrimaryButtonText = "Primary button", SecondaryButtonText = "Secondary button" }; // Setting the dialog container dialog.DialogHost = ContentDialogHostService.ContentPresenterForDialogs; // Showing the dialog await dialog.ShowAsync(CancellationToken.None);
MessageBox
To utilize Win32's classic
MessageBox
methods while supporting modern UI themes like Mica and dark mode.global using MessageBox = Wpf.Ui.Violeta.Controls.MessageBox; // Sync methods _ = MessageBox.Information("This is a information message"); _ = MessageBox.Warning("This is a warning message"); _ = MessageBox.Error("This is a error message"); MessageBoxResult result = MessageBox.Question("This is a question and do you want to click OK?"); // Async methods _ = await MessageBox.InformationAsync("This is a information message"); _ = await MessageBox.WarningAsync("This is a warning message"); _ = await MessageBox.ErrorAsync("This is a error message"); MessageBoxResult result = await MessageBox.QuestionAsync("This is a question and do you want to click OK?");
ToggleButtonGroup
Turn the ToggleButton under the same Group into a radio button.
<StackPanel Orientation="Horizontal"> <StackPanel.Resources> <vio:ToggleButtonGroup x:Key="ToggleButtonGroup" /> </StackPanel.Resources> <ToggleButton vio:ToggleButtonGroup.Group="{DynamicResource ToggleButtonGroup}" Content="1st" IsChecked="True" /> <ToggleButton vio:ToggleButtonGroup.Group="{DynamicResource ToggleButtonGroup}" Content="2nd" /> </StackPanel>
Splash
Show the Splash Screen in another UI thread.
public App() { Splash.ShowAsync("pack://application:,,,/Wpf.Ui.Test;component/wpfui.png"); InitializeComponent(); } public MainWindow() { InitializeComponent(); Splash.CloseOnLoaded(this, minimumMilliseconds: 1800); }
TreeListView
TreeListView is a better way to display hierarchical data.
<vio:TreeListView Model="{Binding TreeTestModel}"> <vio:TreeListView.View> <ui:GridView> <ui:GridView.Columns> <ui:GridViewColumn Width="400" Header="Column1"> <ui:GridViewColumn.CellTemplate> <DataTemplate> <vio:TreeRowExpander Content="{Binding Column1}" /> </DataTemplate> </ui:GridViewColumn.CellTemplate> </ui:GridViewColumn> <ui:GridViewColumn Width="250" DisplayMemberBinding="{Binding Column2, Mode=TwoWay}" Header="Column2" /> <ui:GridViewColumn Width="250" DisplayMemberBinding="{Binding Column3, Mode=TwoWay}" Header="Column3" /> <ui:GridViewColumn Width="250" Header="IsChecked"> <ui:GridViewColumn.CellTemplate> <DataTemplate> <ui:ToggleSwitch IsChecked="{Binding IsChecked}" /> </DataTemplate> </ui:GridViewColumn.CellTemplate> </ui:GridViewColumn> </ui:GridView.Columns> </ui:GridView> </vio:TreeListView.View> </vio:TreeListView>
public partial class ViewModel : ObservableObject { [ObservableProperty] private TreeCollection<TreeTestModel> treeTestModel = CreateTestModel(); public static TreeCollection<TreeTestModel> CreateTestModel() { return new TreeCollection<TreeTestModel>() { Children = new( [ new() { Column1 = "Test 1", Column2 = "Test 1", Column3 = "Test 1", Children = new( [ new() { Column1 = "Test 1.1", Column2 = "Test 1.1", Column3 = "Test 1.1", Children = new( [ new() { Column1 = "Test 1.2", Column2 = "Test 1.2", Column3 = "Test 1.2", }, ]), }, ]), }, new() { Column1 = "Test 2", Column2 = "Test 2", Column3 = "Test 2", } ]), }; } } [ObservableObject] public partial class TreeTestModel : TreeObject<TreeTestModel> { [ObservableProperty] private string? column1; [ObservableProperty] private string? column2; [ObservableProperty] private string? column3; [ObservableProperty] private bool isChecked = false; }
ImageView
Provides a scalable image control.
<vio:ImageView Source="/wpfui.png" />
📷 Screenshots
Under construction
Thanks
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0-windows7.0 is compatible. net7.0-windows was computed. net7.0-windows7.0 is compatible. net8.0-windows was computed. net8.0-windows7.0 is compatible. net9.0-windows was computed. |
.NET Framework | net472 is compatible. net48 is compatible. net481 is compatible. |
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on WPF-UI.Violeta:
Repository | Stars |
---|---|
QL-Win/QuickLook
Bring macOS “Quick Look” feature to Windows
|
|
babalae/better-genshin-impact
📦BetterGI · 更好的原神 - 自动拾取 | 自动剧情 | 全自动钓鱼(AI) | 全自动七圣召唤 | 自动伐木 | 自动刷本 | 自动采集/挖矿/锄地 | 一条龙 | 全连音游 - UI Automation Testing Tools For Genshin Impact
|
Version | Downloads | Last updated |
---|---|---|
3.0.5.28 | 229 | 12/31/2024 |
3.0.5.27 | 461 | 12/8/2024 |
3.0.5.26 | 533 | 11/20/2024 |
3.0.5.25 | 95 | 11/19/2024 |
3.0.5.24 | 105 | 11/19/2024 |
3.0.5.23 | 944 | 10/27/2024 |
3.0.5.22 | 116 | 10/27/2024 |
3.0.5.21 | 115 | 10/27/2024 |
3.0.5.20 | 172 | 10/16/2024 |
3.0.5.19 | 108 | 10/13/2024 |
3.0.5.18 | 237 | 10/9/2024 |
3.0.5.17 | 105 | 10/7/2024 |
3.0.5.16 | 196 | 9/30/2024 |
3.0.5.15 | 155 | 9/27/2024 |
3.0.5.14 | 141 | 9/23/2024 |
3.0.5.13 | 128 | 9/19/2024 |
3.0.5.12 | 404 | 9/10/2024 |
3.0.5.11 | 112 | 9/10/2024 |
3.0.5.10 | 153 | 9/10/2024 |
3.0.5.9 | 103 | 9/8/2024 |
3.0.5.8 | 96 | 9/8/2024 |
3.0.5.7 | 143 | 9/3/2024 |
3.0.5.6 | 131 | 8/26/2024 |
3.0.5.5 | 138 | 8/23/2024 |
3.0.5.4 | 143 | 8/22/2024 |
3.0.5.3 | 323 | 8/20/2024 |
3.0.5.2 | 199 | 8/15/2024 |
3.0.5.1 | 127 | 8/15/2024 |
3.0.5 | 128 | 8/13/2024 |