如何在Windows UWP中为分段控制创建自定义的渲染器。我跟着这个link自定义渲染在IOS和Android的分段控制。但我找不到任何Windows UWP。任何人都可以提供任何资源,或者是否有任何其他方式做到这一点,类似于Windows UWP中的分段控制。Xamarin:用于Windows的分段控制uwp
回答
。
我最近发现了nuget包FreshEssentials。它具有分段按钮组的实现。按照这个github link找到实现。它很容易使用。
我自定义风格的单选按钮做了一次。为您的按钮编辑RadioButton样式 - 创建正在查看的已选中和未选中样式,并为其分配相同的组,以便当时只能选择一个按钮。 不知道有没有更简单的方法。
编辑:SAMPE代码,编辑您想要的方式:我找到了解决自己
<Page.Resources>
<Style x:Key="RadioButtonStyle1" TargetType="RadioButton">
<Setter Property="Background" Value="Transparent"/>
<Setter Property="Foreground" Value="{ThemeResource RadioButtonContentForegroundThemeBrush}"/>
<Setter Property="Padding" Value="0,0,0,0"/>
<Setter Property="HorizontalAlignment" Value="Center"/>
<Setter Property="VerticalAlignment" Value="Stretch"/>
<Setter Property="HorizontalContentAlignment" Value="Center"/>
<Setter Property="VerticalContentAlignment" Value="Center"/>
<Setter Property="FontFamily" Value="{ThemeResource ContentControlThemeFontFamily}"/>
<Setter Property="FontSize" Value="{ThemeResource ControlContentThemeFontSize}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="RadioButton">
<Border BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}"
Background="{TemplateBinding Background}">
<VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="CommonStates">
<VisualState x:Name="Normal"/>
<VisualState x:Name="PointerOver">
</VisualState>
<VisualState x:Name="Pressed">
</VisualState>
<VisualState x:Name="Disabled">
<Storyboard>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="Background" Storyboard.TargetName="BackgroundRectangle">
<DiscreteObjectKeyFrame KeyTime="0" Value="{ThemeResource RadioButtonDisabledBackgroundThemeBrush}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="Foreground" Storyboard.TargetName="ContentPresenter">
<DiscreteObjectKeyFrame KeyTime="0" Value="{ThemeResource RadioButtonContentDisabledForegroundThemeBrush}"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</VisualState>
</VisualStateGroup>
<VisualStateGroup x:Name="CheckStates">
<VisualState x:Name="Checked">
<Storyboard>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="Background" Storyboard.TargetName="BackgroundRectangle">
<DiscreteObjectKeyFrame KeyTime="0" Value="Blue"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames Storyboard.TargetProperty="Foreground" Storyboard.TargetName="ContentPresenter">
<DiscreteObjectKeyFrame KeyTime="0" Value="White"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</VisualState>
<VisualState x:Name="Unchecked">
</VisualState>
<VisualState x:Name="Indeterminate"/>
</VisualStateGroup>
<VisualStateGroup x:Name="FocusStates">
<VisualState x:Name="Focused">
<Storyboard>
<DoubleAnimation Duration="0" To="1" Storyboard.TargetProperty="Opacity" Storyboard.TargetName="FocusVisualWhite"/>
<DoubleAnimation Duration="0" To="1" Storyboard.TargetProperty="Opacity" Storyboard.TargetName="FocusVisualBlack"/>
</Storyboard>
</VisualState>
<VisualState x:Name="Unfocused"/>
<VisualState x:Name="PointerFocused"/>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<Grid HorizontalAlignment="Stretch">
<Grid x:Name="BackgroundRectangle" Background="Transparent">
<Border BorderThickness="1" BorderBrush="White" Margin="0" HorizontalAlignment="Stretch">
<Rectangle Margin="0" StrokeThickness="{ThemeResource RadioButtonBorderThemeThickness}" HorizontalAlignment="Stretch" UseLayoutRounding="False"/>
</Border>
<TextBlock VerticalAlignment="Center" HorizontalAlignment="Center" x:Name="Title"></TextBlock>
</Grid>
<ContentPresenter x:Name="ContentPresenter" Foreground="White" AutomationProperties.AccessibilityView="Raw"
ContentTemplate="{TemplateBinding ContentTemplate}" ContentTransitions="{TemplateBinding ContentTransitions}"
Content="{TemplateBinding Content}" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}"
Margin="{TemplateBinding Padding}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Page.Resources>
<Grid Height="40" Background="Black" BorderThickness="0">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="10"/>
<ColumnDefinition Width="Auto"/>
<ColumnDefinition Width="Auto"/>
<ColumnDefinition Width="Auto"/>
<ColumnDefinition Width="Auto"/>
<ColumnDefinition Width="10"/>
</Grid.ColumnDefinitions>
<RadioButton Height="30" Content="Button1" Grid.Column="1" Style="{StaticResource RadioButtonStyle1}" GroupName="MainGroup" Checked="Button1_OnChecked"></RadioButton>
<RadioButton Height="30" Content="Button2" Grid.Column="2" Style="{StaticResource RadioButtonStyle1}" GroupName="MainGroup" Checked="Button2_OnChecked"></RadioButton>
<RadioButton Height="30" Content="Button3" Grid.Column="3" Style="{StaticResource RadioButtonStyle1}" GroupName="MainGroup" Checked="Button3_OnChecked"></RadioButton>
<RadioButton Height="30" Content="Button4" Grid.Column="4" Style="{StaticResource RadioButtonStyle1}" GroupName="MainGroup" Checked="Button4_OnChecked"></RadioButton>
</Grid>
能否请您对UWP定制提供一些代码。是的,它可以用单选按钮来完成,但不确定在这种情况下uwp中使用的布局模板。 –
在样式开始的行下添加了样本代码 – RTDev
的编辑,您可以看到一些
- 1. Xamarin按行分开控制
- 2. 使用Xamarin控制UWP应用程序(Android)
- 3. Xamarin Forms UWP PageRenderer
- 4. 使用UWP windows mobile禁用Xamarin Forms上的UI虚拟化10
- 5. C#Windows窗体:用于制表控制
- 6. 适用于Windows IOT的SQLite控制台
- 7. 采用分段控制切换的tableView
- 8. Windows UWP开发问题(Windows 10模拟器和Xamarin)
- 9. Xamarin,UWP和依赖
- 10. 如何区分段控制中的段?
- 11. 滚动对广告的控制 - 的Windows Phone UWP
- 12. UWP上的Xamarin MasterDetailPage菜单
- 13. Windows 10中的背景控制UWP不会模糊
- 14. 通过分段控制
- 15. iOS分段控制问题
- 16. 分段控制导航栏
- 17. iphone分段控制和uitableview
- 18. ScrollViews和分段控制器
- 19. Xamarin Forms:用于UWP和win8.1的自定义progressbar渲染器
- 20. 带SQlite的Xamarin(iOS Android UWP)使用OneToMany
- 21. 分段控制输入Android应用
- 22. 使用分段控制Swift 3
- 23. 在UWP中禁用焦点控制
- 24. 在WPF控制 - 显示UWP应用
- 25. Xamarin UWP应用程序不起作用
- 26. 分段控制差分按钮
- 27. Xamarin UWP品牌工具栏
- 28. 的Windows UWP使用RichTextEditor
- 29. 使用UWP的OCR(Windows 10)
- 30. 按分段标题推送到分段控制段
Asesome @Himanshu(y)! –
还有这个:(https://github.com/1iveowl/Plugin.SegmentedControl –