WPF 滑动按钮

蜕变之旅 2013-05-22 10:54:16
WPF怎么做一个左右滑动的按钮
...全文
396 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
ariesget 2013-05-22
  • 打赏
  • 举报
回复
ToggleButton 样式模板。滑块可以用一个Border位移动画来实现,用触发器来触发这个位移动画。
薛小坏 2013-05-22
  • 打赏
  • 举报
回复
http://www.cnblogs.com/lhx880619/archive/2011/12/26/2302657.html 帮你顶
薛小坏 2013-05-22
  • 打赏
  • 举报
回复
引用 4 楼 tuibianzhilvwsq 的回复:
[quote=引用 1 楼 DABIN0814 的回复:] http://www.cnblogs.com/lhx880619/archive/2011/12/26/2302657.html 帮你顶
你这个我看过了,不行,你这个是点击的效果,我要拖动按钮的效果,像iphone开关那样,按钮在中间,向左拖就是开,向右拖动就是关[/quote] 我刚才看到一个这样的例子,你看看改改能不能用http://www.cnblogs.com/lanymy/archive/2013/05/20/3088516.html
ariesget 2013-05-22
  • 打赏
  • 举报
回复
忘了说要加个引用 xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
ariesget 2013-05-22
  • 打赏
  • 举报
回复

    <Style x:Key="ButtonFocusVisual">
        <Setter Property="Control.Template">
            <Setter.Value>
                <ControlTemplate>
                    <Rectangle Margin="2" SnapsToDevicePixels="true" Stroke="{DynamicResource {x:Static SystemColors.ControlTextBrushKey}}" StrokeThickness="1" StrokeDashArray="1 2"/>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>
    <SolidColorBrush x:Key="ButtonNormalBorder" Color="#FF707070"/>
    <Style x:Key="SliderToggleButton" TargetType="{x:Type ToggleButton}">
        <Setter Property="FocusVisualStyle" Value="{StaticResource ButtonFocusVisual}"/>
        <Setter Property="BorderThickness" Value="1"/>
        <Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.ControlTextBrushKey}}"/>
        <Setter Property="HorizontalContentAlignment" Value="Center"/>
        <Setter Property="VerticalContentAlignment" Value="Center"/>
        <Setter Property="Padding" Value="1"/>
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type ToggleButton}">
                    <ControlTemplate.Resources>
                        <Storyboard PresentationOptions:Freeze="True" x:Key="ToggleOn">
                            <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" Storyboard.TargetName="SlidingBorder">
                                <EasingThicknessKeyFrame KeyTime="0:0:0.1" Value="15,0,0,0"/>
                                <EasingThicknessKeyFrame KeyTime="0:0:0.2" Value="30,0,0,0"/>
                            </ThicknessAnimationUsingKeyFrames>
                        </Storyboard>
                        <Storyboard PresentationOptions:Freeze="True" x:Key="ToggleOff">
                            <ThicknessAnimationUsingKeyFrames Storyboard.TargetProperty="(FrameworkElement.Margin)" Storyboard.TargetName="SlidingBorder">
                                <EasingThicknessKeyFrame KeyTime="0:0:0.1" Value="0"/>
                            </ThicknessAnimationUsingKeyFrames>
                        </Storyboard>
                    </ControlTemplate.Resources>
                    <Grid>
                        <Grid.ColumnDefinitions>
                            <ColumnDefinition Width="*" />
                            <ColumnDefinition Width="60" />
                        </Grid.ColumnDefinitions>
                        <ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="4" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
                        <Grid Grid.Column="1" Width="Auto" Background="{x:Null}">
                            <Border BorderBrush="#FF9DA2A4" BorderThickness="1" CornerRadius="1">
                                <Border.Background>
                                    <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                        <GradientStop Color="White" Offset="1"/>
                                        <GradientStop Color="#FF858688"/>
                                        <GradientStop Color="#FFDBDCDD" Offset="0.112"/>
                                        <GradientStop Color="#FFAAABAD" Offset="0.04"/>
                                        <GradientStop Color="#FFCACBCC" Offset="0.08"/>
                                        <GradientStop Color="#FFFEFEFE" Offset="0.149"/>
                                    </LinearGradientBrush>
                                </Border.Background>
                            </Border>
                            <TextBlock TextWrapping="Wrap" Text="关" d:LayoutOverrides="Width, Height" VerticalAlignment="Center" HorizontalAlignment="Right" Margin="0,0,10,0"/>
                            <TextBlock TextWrapping="Wrap" Text="开" VerticalAlignment="Center" HorizontalAlignment="Left" Margin="10,0,0,0"/>
                            <Border x:Name="SlidingBorder" BorderBrush="Black" BorderThickness="1" Width="30" HorizontalAlignment="Left" CornerRadius="1" Background="{TemplateBinding Background}">
                                <Border BorderThickness="1">
                                    <Border.Background>
                                        <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                            <GradientStop Color="#00000000" Offset="0"/>
                                            <GradientStop Color="#7FFFFFFF" Offset="1"/>
                                        </LinearGradientBrush>
                                    </Border.Background>
                                </Border>
                            </Border>
                        </Grid>
                        <Border x:Name="DisabledBorder" BorderBrush="{x:Null}" BorderThickness="1" Grid.ColumnSpan="2" CornerRadius="1" Background="White" Opacity="0" IsHitTestVisible="False"/>
                    </Grid>
                    <ControlTemplate.Triggers>
                        <Trigger Property="IsKeyboardFocused" Value="true"/>
                        <Trigger Property="IsChecked" Value="true">
                            <Trigger.ExitActions>
                                <BeginStoryboard x:Name="ToggleOff_BeginStoryboard" Storyboard="{StaticResource ToggleOff}"/>
                            </Trigger.ExitActions>
                            <Trigger.EnterActions>
                                <BeginStoryboard Storyboard="{StaticResource ToggleOn}"/>
                            </Trigger.EnterActions>
                        </Trigger>
                        <Trigger Property="IsEnabled" Value="false">
                            <Setter Property="Foreground" Value="#ADADAD"/>
                            <Setter Property="Opacity" TargetName="DisabledBorder" Value="0.35"/>
                        </Trigger>
                        <Trigger SourceName="SlidingBorder" Property="IsMouseOver" Value="True">
                            <Setter TargetName="SlidingBorder" Property="BorderBrush" Value="#FFFFE8A3"/>
                        </Trigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
        <Setter Property="BorderBrush" Value="#FF2F63FF"/>
    </Style>
蜕变之旅 2013-05-22
  • 打赏
  • 举报
回复
引用 2 楼 ariesget 的回复:
ToggleButton 样式模板。滑块可以用一个Border位移动画来实现,用触发器来触发这个位移动画。
大侠,能不能帮写一个例子啊,我刚开始学WPF,急用这个,多谢了
蜕变之旅 2013-05-22
  • 打赏
  • 举报
回复
引用 1 楼 DABIN0814 的回复:
http://www.cnblogs.com/lhx880619/archive/2011/12/26/2302657.html 帮你顶
你这个我看过了,不行,你这个是点击的效果,我要拖动按钮的效果,像iphone开关那样,按钮在中间,向左拖就是开,向右拖动就是关
蜕变之旅 2013-05-22
  • 打赏
  • 举报
回复
大侠,能不能帮写一个例子啊,我刚开始学WPF,急用这个,多谢了

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧