C# WPF 自定义控件 滑块控件 开关控件 ToggleButton Switcher

2023-10-10 03:30

本文主要是介绍C# WPF 自定义控件 滑块控件 开关控件 ToggleButton Switcher,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

滑块效果演示如图:

 源码下载地址

https://download.csdn.net/download/shizu11zz/86934041icon-default.png?t=M85Bhttps://download.csdn.net/download/shizu11zz/86934041

直接贴源码,有帮助的话求点个赞,不过分吧:

【MainWindow.Xaml】

<Windowxmlns="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:WPF_Test2"x:Class="WPF_Test2.MainWindow"mc:Ignorable="d" x:Name="mwindow"Title="MainWindow" Height="350" Width="525" Background="LightBlue"><Grid><Grid.ColumnDefinitions><ColumnDefinition Width="1*"/><ColumnDefinition Width="1*"/></Grid.ColumnDefinitions><local:Switcher Grid.Column="0" /><local:Switcher Grid.Column="1" Height="60" Width="160" FontSize="28" Foreground="Red" IsChecked="True"BorderThickness="1" BorderBrush="Yellow" CheckedTip=" 开"  UncheckedTip="关 "BallColor="Red" Checked="sw_Checked" Unchecked="sw_Unchecked"/></Grid>
</Window>

【 Generic.Xaml】

<ResourceDictionary   xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="clr-namespace:WPF_Test2"><local:HeightCornerRadiusConverter x:Key="hcrConverter"/><local:CheckedToHidenConvert x:Key="CheckedToHidenConvert"/><local:CheckedToVisbilityConvert x:Key="CheckedToVisbilityConvert"/><Style x:Name="SwitcherStyle" TargetType="{x:Type local:Switcher}"><Setter Property="Height" Value="40"/><Setter Property="Width" Value="90"/><Setter Property="FontSize" Value="18"/><Setter Property="Foreground" Value="White"/><Setter Property="BorderThickness" Value="2"/><Setter Property="BorderBrush" Value="White"/><Setter Property="Background" Value="#ff212c7e"/><Setter Property="IsChecked" Value="True"/><Setter Property="Template"><Setter.Value><ControlTemplate TargetType="{x:Type local:Switcher}"><Border x:Name="bd1" BorderThickness="{TemplateBinding BorderThickness}" BorderBrush="{TemplateBinding BorderBrush}" CornerRadius="{TemplateBinding ActualHeight ,Converter={StaticResource hcrConverter}}" Background="{TemplateBinding Background}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="1"><Grid x:Name="gd1"><Ellipse x:Name="e1" Grid.Column="0" Fill="{TemplateBinding BallColor}" Width="{Binding ActualHeight, RelativeSource={RelativeSource Mode=Self}}"Panel.ZIndex="1" Grid.ColumnSpan="2"><UIElement.RenderTransform><TranslateTransform X="0" x:Name="trans"/></UIElement.RenderTransform><Ellipse.Style><Style TargetType="Ellipse"><Setter Property="Margin" Value="0,3"/><Style.Triggers><Trigger Property="IsMouseOver" Value="True"><Setter Property="Margin" Value="0,2"/></Trigger></Style.Triggers></Style></Ellipse.Style></Ellipse><TextBlock x:Name="cTip" Margin="4,2" VerticalAlignment="Center" HorizontalAlignment="Left" Text="{TemplateBinding CheckedTip}" Visibility="{TemplateBinding IsChecked,Converter={StaticResource CheckedToHidenConvert}}"/><TextBlock x:Name="unTip" Margin="4,2" VerticalAlignment="Center" HorizontalAlignment="Right" Text="{TemplateBinding UncheckedTip}" Visibility="{TemplateBinding IsChecked,Converter={StaticResource CheckedToVisbilityConvert}}"/></Grid></Border><ControlTemplate.Triggers><MultiTrigger><MultiTrigger.Conditions><Condition Property="IsMouseOver"  Value="True"/><Condition Property="IsChecked" Value="False"/></MultiTrigger.Conditions><MultiTrigger.Setters><Setter Property="Background" Value="LightGray"/></MultiTrigger.Setters></MultiTrigger><MultiTrigger><MultiTrigger.Conditions><Condition Property="IsMouseOver" Value="True"/><Condition Property="IsChecked" Value="True"/></MultiTrigger.Conditions><MultiTrigger.Setters><Setter Property="Background" Value="#ff546ab3"/></MultiTrigger.Setters></MultiTrigger><MultiTrigger><MultiTrigger.Conditions><Condition Property="IsMouseOver"  Value="False"/><Condition Property="IsChecked" Value="False"/></MultiTrigger.Conditions><MultiTrigger.Setters><Setter Property="Background" Value="Gray"/></MultiTrigger.Setters></MultiTrigger></ControlTemplate.Triggers></ControlTemplate></Setter.Value></Setter></Style>
</ResourceDictionary>

【Switcher.cs】

using System;
using System.Globalization;
using System.Windows;
using System.Windows.Controls.Primitives;
using System.Windows.Data;
using System.Windows.Media;
using System.Windows.Media.Animation;namespace WPF_Test2
{public class Switcher : ToggleButton{private System.Windows.Media.TranslateTransform ballMoveX;static Switcher(){DefaultStyleKeyProperty.OverrideMetadata(typeof(Switcher), new FrameworkPropertyMetadata(typeof(Switcher)));}#region Propdppublic static readonly DependencyProperty CheckedTipProperty =DependencyProperty.Register("CheckedTip", typeof(string), typeof(Switcher), new PropertyMetadata("ON"));public static readonly DependencyProperty UncheckedTipProperty =DependencyProperty.Register("UncheckedTip", typeof(string), typeof(Switcher), new PropertyMetadata("OFF"));public static readonly DependencyProperty BallColorProperty =DependencyProperty.Register("BallColor", typeof(Brush), typeof(Switcher), new PropertyMetadata(new SolidColorBrush(Colors.White)));public string CheckedTip{get { return (string)GetValue(CheckedTipProperty); }set { SetValue(CheckedTipProperty, value); }}public string UncheckedTip{get { return (string)GetValue(UncheckedTipProperty); }set { SetValue(UncheckedTipProperty, value); }}public Brush BallColor{get { return (Brush)GetValue(BallColorProperty); }set { SetValue(BallColorProperty, value); }}#endregionpublic Switcher() : base(){Checked += CheckedAnimation;Unchecked += UncheckedAnimation;Loaded += (e, s) =>{ballMoveX = ((Switcher)e).GetTemplateChild("trans") as System.Windows.Media.TranslateTransform;if (IsChecked != null) ballMoveX.X = (IsChecked == true ? -1 : 1) * (ActualWidth - ActualHeight) / 2;};}#region AnimationsDoubleAnimation ballAnima = new DoubleAnimation(0, new Duration(new TimeSpan(0, 0, 0, 0, 300))){EasingFunction = new CubicEase() { EasingMode = System.Windows.Media.Animation.EasingMode.EaseInOut }};private void CheckedAnimation(object sender, RoutedEventArgs e){if (!IsLoaded) e.Handled = true;//未初始化成功时,不向外传递Checked事件if (ballMoveX == null) return;ballAnima.To = -(ActualWidth - ActualHeight) / 2;ballMoveX.BeginAnimation(System.Windows.Media.TranslateTransform.XProperty, ballAnima);}private void UncheckedAnimation(object sender, RoutedEventArgs e){if (!IsLoaded) e.Handled = true;//未初始化成功时,不向外传递Unchecked事件if (ballMoveX == null) return;ballAnima.To = (ActualWidth - ActualHeight) / 2;ballMoveX.BeginAnimation(System.Windows.Media.TranslateTransform.XProperty, ballAnima);}#endregion}#region Converters/// <summary>/// 根据控件高度设置控件圆角半径/// 圆角半径为高度的二分之一/// </summary>public class HeightCornerRadiusConverter : IValueConverter{public object Convert(object value, Type targetType, object parameter, CultureInfo culture){return 0.5 * int.Parse(value.ToString());}public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture){throw new NotImplementedException();}}/// <summary>/// 当Ischecked=True时,/// 隐藏CheckedTip文本/// </summary>public class CheckedToVisbilityConvert : IValueConverter{public object Convert(object value, Type targetType, object parameter, CultureInfo culture){if (value == null) return Visibility.Hidden;return (bool)value ? Visibility.Visible : Visibility.Hidden;}public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture){throw new NotImplementedException();}}/// <summary>/// 当Ischecked=False时,/// 隐藏UncheckedTip文本/// </summary>public class CheckedToHidenConvert : IValueConverter{public object Convert(object value, Type targetType, object parameter, CultureInfo culture){if (value == null) return Visibility.Hidden;return (bool)value ? Visibility.Hidden : Visibility.Visible;}public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture){throw new NotImplementedException();}}#endregion
}

这篇关于C# WPF 自定义控件 滑块控件 开关控件 ToggleButton Switcher的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/177626

相关文章

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

C#利用Free Spire.XLS for .NET复制Excel工作表

《C#利用FreeSpire.XLSfor.NET复制Excel工作表》在日常的.NET开发中,我们经常需要操作Excel文件,本文将详细介绍C#如何使用FreeSpire.XLSfor.NET... 目录1. 环境准备2. 核心功能3. android示例代码3.1 在同一工作簿内复制工作表3.2 在不同

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

C#实现高性能拍照与水印添加功能完整方案

《C#实现高性能拍照与水印添加功能完整方案》在工业检测、质量追溯等应用场景中,经常需要对产品进行拍照并添加相关信息水印,本文将详细介绍如何使用C#实现一个高性能的拍照和水印添加功能,包含完整的代码实现... 目录1. 概述2. 功能架构设计3. 核心代码实现python3.1 主拍照方法3.2 安全HBIT

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

C#使用SendMessage实现进程间通信的示例代码

《C#使用SendMessage实现进程间通信的示例代码》在软件开发中,进程间通信(IPC)是关键技术之一,C#通过调用WindowsAPI的SendMessage函数实现这一功能,本文将通过实例介绍... 目录第一章:SendMessage的底层原理揭秘第二章:构建跨进程通信桥梁2.1 定义通信协议2.2

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很