1、RangeBase(基类) 的示例
Controls/ProgressControl/RangeBaseDemo.xaml

<Page
x:Class="Windows10.Controls.ProgressControl.RangeBaseDemo"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Controls.ProgressControl"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <TextBlock Name="lblMsg" Margin="5" /> <!--
Slider - 滑动条控件,继承自 RangeBase,下面介绍 RangeBase 的相关知识点
Minimum - 范围控件的最小值(double 类型)
Maximum - 范围控件的最大值(double 类型)
Value - 范围控件的当前值(double 类型)
SmallChange - 小变化步长(double 类型),按键盘的“上/下/左/右”键
LargeChange - 大变化步长(double 类型),按键盘的“PageUp/PageDown”键(经测试无效,另外 Home 键和 End 键是可用的)
ValueChanged - 范围控件的当前值发生变化后触发的事件
--> <Slider Name="slider" Width="200" Margin="5" HorizontalAlignment="Left" Foreground="Orange" Background="Red" Style="{StaticResource MySliderStyle}"
Minimum="1000" Maximum="2000" Value="1500" SmallChange="10" LargeChange="100" ValueChanged="slider_ValueChanged">
</Slider> </StackPanel>
</Grid>
</Page>

Controls/ProgressControl/RangeBaseDemo.xaml.cs

/*
* RangeBase(基类) - 范围控件基类(继承自 Control, 请参见 /Controls/BaseControl/ControlDemo/)
*/ using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Controls.Primitives; namespace Windows10.Controls.ProgressControl
{
public sealed partial class RangeBaseDemo : Page
{
public RangeBaseDemo()
{
this.InitializeComponent();
} private void slider_ValueChanged(object sender, RangeBaseValueChangedEventArgs e)
{
// RangeBaseValueChangedEventArgs
// OldValue - 范围控件的之前的值
// NewValue - 范围控件的当前的值
lblMsg.Text = $"slider old value:{e.OldValue}, slider new value:{e.NewValue}";
}
}
}

2、Slider 的示例
Controls/ProgressControl/SliderDemo.xaml

<Page
x:Class="Windows10.Controls.ProgressControl.SliderDemo"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Controls.ProgressControl"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent"> <Grid.Resources>
<local:MyThumbToolTipValueConverter x:Key="MyThumbToolTipValueConverter" />
</Grid.Resources> <!--
Slider - 滑动条控件
Header - 可以设置一个纯文本,不能命中测试,空 Header 的话不会占用任何空间
HeaderTemplate - 可以将 Header 设置为任何 xaml,且支持命中测试
Orientation - 滑动条的布局方向
Horizontal - 水平放置
Vertical - 垂直放置
IsDirectionReversed - 值的增加方向为左到右或下到上则为 false(默认值),反之为 true
IsThumbToolTipEnabled - 是否在 thumb 旁显示当前值的提示
ThumbToolTipValueConverter - 在 thumb 旁显示当前值的提示时所使用的 Converter
TickPlacement - 如何显示刻度线,Windows.UI.Xaml.Controls.Primitives.TickPlacement枚举(None, TopLeft, BottomRight, Outside, Inline)
TickFrequency - 刻度线的间隔
StepFrequency - 每一步的间隔
SnapsTo - 贴靠方式
StepValues - 按 StepFrequency 做 Snap(默认值)
通过鼠标拖动或鼠标点击控制 Slider 时,其值是 StepFrequency 的整倍数(注:键盘控制时,步长来自于基类 RangeBase 的 SmallChange, LargeChange)
Ticks - 按 TickFrequency 做 Snap
通过鼠标拖动或鼠标点击控制 Slider 时,其值是 TickFrequency 的整倍数(注:键盘控制时,步长来自于基类 RangeBase 的 SmallChange, LargeChange) 注:可以通过 Foreground, Background 来设置 Slider 的部分状态的颜色,更多的样式设置还是要去修改控件模板
-->
<StackPanel Margin="10 0 10 10"> <Slider Margin="5" Width="100" Value="20" HorizontalAlignment="Left" Foreground="Orange" Background="Red" Style="{StaticResource MySliderStyle}"
Header="Slider" /> <Slider Margin="5" Height="100" HorizontalAlignment="Left" Foreground="Orange" Background="Red" Style="{StaticResource MySliderStyle}"
Orientation="Vertical" IsDirectionReversed="True"
IsThumbToolTipEnabled="True" ThumbToolTipValueConverter="{StaticResource MyThumbToolTipValueConverter}">
<Slider.HeaderTemplate>
<DataTemplate>
<TextBlock Text="Slider" Foreground="Red" />
</DataTemplate>
</Slider.HeaderTemplate>
</Slider> <Slider Margin="5" Width="800" Minimum="0" Maximum="800" HorizontalAlignment="Left" Foreground="Orange" Background="Red" Style="{StaticResource MySliderStyle}"
TickPlacement="Inline" TickFrequency="80"
StepFrequency="100" SnapsTo="StepValues" /> </StackPanel>
</Grid>
</Page>

Controls/ProgressControl/SliderDemo.xaml.cs

/*
* Slider - 滑动条控件(继承自 RangeBase, 请参见 /Controls/ProgressControl/RangeBaseDemo.xaml)
* Thumb - 可由用户拖动的控件(Slider 内的可拖动部分就是一个 Thumb 控件)
*/ using System;
using Windows.UI.Xaml.Controls;
using Windows.UI.Xaml.Data; namespace Windows10.Controls.ProgressControl
{
public sealed partial class SliderDemo : Page
{
public SliderDemo()
{
this.InitializeComponent();
}
} // 为 Slider 的 ThumbToolTipValueConverter 提供 Converter
public sealed class MyThumbToolTipValueConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, string language)
{
// 在 thumb 旁显示的当前值的后面加一个百分号
return value + "%";
} public object ConvertBack(object value, Type targetType, object parameter, string language)
{
return null;
}
}
}

3、ProgressBar 的示例
Controls/ProgressControl/ProgressBarDemo.xaml

<Page
x:Class="Windows10.Controls.ProgressControl.ProgressBarDemo"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Controls.ProgressControl"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <!--
ProgressBar - 进度条控件
IsIndeterminate - 是否是无法确定进度的进度条
ShowPaused - 显示暂停状态
ShowError - 显示错误状态 注:可以通过 Foreground, Background 来设置 ProgressBar 的部分状态的颜色,更多的样式设置还是要去修改控件模板
--> <ProgressBar IsIndeterminate="True" Width="200" HorizontalAlignment="Left"
Foreground="Orange" Background="Red"
ShowPaused="{Binding IsChecked, ElementName=radPaused}"
ShowError="{Binding IsChecked, ElementName=radError}" /> <ProgressBar IsIndeterminate="False" Width="200" Minimum="0" Maximum="100" Value="50" HorizontalAlignment="Left" Margin="0 20 0 0"
Foreground="Orange" Background="Red"
ShowPaused="{Binding IsChecked, ElementName=radPaused}"
ShowError="{Binding IsChecked, ElementName=radError}"/> <StackPanel Orientation="Horizontal" Margin="0 20 0 0">
<RadioButton x:Name="radRunning" GroupName="ProgressState" Content="Running" IsChecked="True"/>
<RadioButton x:Name="radPaused" GroupName="ProgressState" Content="Paused"/>
<RadioButton x:Name="radError" GroupName="ProgressState" Content="Error"/>
</StackPanel> </StackPanel>
</Grid>
</Page>

Controls/ProgressControl/ProgressBarDemo.xaml.cs

/*
* ProgressBar - 进度条控件(继承自 RangeBase, 请参见 /Controls/ProgressControl/RangeBaseDemo.xaml)
*/ using Windows.UI.Xaml.Controls; namespace Windows10.Controls.ProgressControl
{
public sealed partial class ProgressBarDemo : Page
{
public ProgressBarDemo()
{
this.InitializeComponent();
}
}
}

4、ProgressRing 的示例
Controls/ProgressControl/ProgressRingDemo.xaml

<Page
x:Class="Windows10.Controls.ProgressControl.ProgressRingDemo"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:Windows10.Controls.ProgressControl"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"> <Grid Background="Transparent">
<StackPanel Margin="10 0 10 10"> <!--
ProgressRing - 进度圈控件
IsActive - 是否显示
-->
<ProgressRing Margin="5" Foreground="White" Width="200" Height="200" HorizontalAlignment="Left"
IsActive="{Binding IsChecked, ElementName=chkIsActive}"/> <CheckBox Name="chkIsActive" Margin="5" Content="IsActive" IsChecked="True" /> </StackPanel>
</Grid>
</Page>

Controls/ProgressControl/ProgressRingDemo.xaml.cs

/*
* ProgressRing - 进度圈控件(继承自 Control, 请参见 /Controls/BaseControl/ControlDemo/)
*/ using Windows.UI.Xaml.Controls; namespace Windows10.Controls.ProgressControl
{
public sealed partial class ProgressRingDemo : Page
{
public ProgressRingDemo()
{
this.InitializeComponent();
}
}
}

控件(进度类): RangeBase, Slider, ProgressBar, ProgressRing的更多相关文章

  1. 背水一战 Windows 10 (34) - 控件(进度类): RangeBase, Slider, ProgressBar, ProgressRing

    [源码下载] 背水一战 Windows 10 (34) - 控件(进度类): RangeBase, Slider, ProgressBar, ProgressRing 作者:webabcd 介绍背水一 ...

  2. 背水一战 Windows 10 (70) - 控件(控件基类): UIElement - Transform3D(3D变换), Projection(3D投影)

    [源码下载] 背水一战 Windows 10 (70) - 控件(控件基类): UIElement - Transform3D(3D变换), Projection(3D投影) 作者:webabcd 介 ...

  3. 背水一战 Windows 10 (77) - 控件(控件基类): ContentControl, UserControl, Page

    [源码下载] 背水一战 Windows 10 (77) - 控件(控件基类): ContentControl, UserControl, Page 作者:webabcd 介绍背水一战 Windows ...

  4. 背水一战 Windows 10 (76) - 控件(控件基类): Control - 基础知识, 焦点相关, 运行时获取 ControlTemplate 和 DataTemplate 中的元素

    [源码下载] 背水一战 Windows 10 (76) - 控件(控件基类): Control - 基础知识, 焦点相关, 运行时获取 ControlTemplate 和 DataTemplate 中 ...

  5. 背水一战 Windows 10 (75) - 控件(控件基类): FrameworkElement - 基础知识, 相关事件, HorizontalAlignment, VerticalAlignment

    [源码下载] 背水一战 Windows 10 (75) - 控件(控件基类): FrameworkElement - 基础知识, 相关事件, HorizontalAlignment, Vertical ...

  6. 背水一战 Windows 10 (74) - 控件(控件基类): UIElement - 与 CanDrag 相关的事件, 与 AllowDrop 相关的事件

    [源码下载] 背水一战 Windows 10 (74) - 控件(控件基类): UIElement - 与 CanDrag 相关的事件, 与 AllowDrop 相关的事件 作者:webabcd 介绍 ...

  7. 背水一战 Windows 10 (73) - 控件(控件基类): UIElement - 拖放的基本应用, 手动开启 UIElement 的拖放操作

    [源码下载] 背水一战 Windows 10 (73) - 控件(控件基类): UIElement - 拖放的基本应用, 手动开启 UIElement 的拖放操作 作者:webabcd 介绍背水一战 ...

  8. 背水一战 Windows 10 (72) - 控件(控件基类): UIElement - UIElement 的位置, UIElement 的布局, UIElement 的其他特性

    [源码下载] 背水一战 Windows 10 (72) - 控件(控件基类): UIElement - UIElement 的位置, UIElement 的布局, UIElement 的其他特性 作者 ...

  9. 背水一战 Windows 10 (71) - 控件(控件基类): UIElement - RenderTransform(2D变换), Clip(剪裁)

    [源码下载] 背水一战 Windows 10 (71) - 控件(控件基类): UIElement - RenderTransform(2D变换), Clip(剪裁) 作者:webabcd 介绍背水一 ...

随机推荐

  1. java 27 - 3 反射之 通过反射获取构造方法并使用

    类 Constructor<T>:提供关于类的单个构造方法的信息以及对它的访问权限. 通过反射的方法获取构造方法并使用  ps:先忽略泛型 A.1:获取构造方法的数组: public Co ...

  2. 向数据库中插入一个DateTime类型的数据到一个Date类型的字段中,需要转换类型。TO_DATE('{0}','YYYY-MM-DD'))

    需要指出的是,C#中有datetime类型,但是这个类型是包括小时,分钟,秒的.这个格式与数据库中的Date类型不符,如果将now设为datetime类型插入数据会失败. 需要通过TO_DATE('字 ...

  3. django自带wsgi server vs 部署uwsgi+nginx后的性能对比

    一.下面先交代一下测试云主机 cpu: root@alexknight:/tmp/webbench-1.5# cat /proc/cpuinfo |grep model model : model n ...

  4. BZOJ 1010 【HNOI2008】 玩具装箱toy

    Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊的一维容器中.P教授有编号为1... ...

  5. POJ 1743 Musical Theme

    感觉最近好混乱......各种OJ都刷一点,感觉不太好......尤其是这种英文题 这道题一开始还没有看懂.听了ljh大犇的解释后终于明白了.下面我为英语和我一样的人翻译一下题面: 输入n个数.求最长 ...

  6. 招聘 微软全球技术支持中心 sql server组

    微软亚太区全球技术支持中心(APGC CSS)是微软为个人用户.开发者.IT 专业人员到合作伙伴和企业级合作伙伴提供全方位.多元化的服务和技术支持的部门.一个优秀的SQL Server技术支持工程师应 ...

  7. Centos 7 安装 和 卸载 Mysql5.7(压缩包)

    今天装的了mysql,遇到了很多问题,好在最后一一解决了,现在记录在此,防止日后老路重走... 1.下载 当然是去官网,下一个linux下的版本,64位的 tar.gz,好吧这里贴个名字--[mysq ...

  8. 链路层的简介和MTU

    链路层杂谈(凭个人理解瞎说的,欢迎拍砖) 链路层,说白了就是把网络层的IP数据处理一下,加点东西,放到物理层上去.    加的东西:源.目的地址和CRC校验值,有的还有类型这个字段,用来区分协议.  ...

  9. C# where用法

    where 子句用于指定类型约束,这些约束可以作为泛型声明中定义的类型参数的变量. 1.接口约束. 例如,可以声明一个泛型类 MyGenericClass,这样,类型参数 T 就可以实现 ICompa ...

  10. c++虚函数注意事项

    >在基类方法声明中使用关键字virtual,可以使该方法在基类及所有的派生类中是虚的 >如果使用指向对象的引用或指针来调用虚方法,程序将使用对象类型定义的方法,而不使用为引用或指针类型定义 ...