• WPF 控件专题 RadioButton详解


    1、RadioButton 介绍

        RadioButton :单选按钮;

    **************************************************************************************************************

    2、常用属性介绍

        Background:背景。    BorderBrush:边框颜色。    BorderThickness:边框宽度。

        Content:获取或设置 ContentControl 的内容。        GroupName:控件所属组的组名。

        FontFamily:获取或设置控件的字体系列。

        FontSize:获取或设置字号。

        FontStretch:获取或设置字体在屏幕上紧缩或加宽的程度。

        FontStyle:获取或设置字体样式。

        FontWeight:获取或设置指定字体的粗细。

        Foreground:前景色。    Width/Height:宽度/高度。    IsEnabled:使能,是否可用。

        IsChecked:获取或设置是否选中 ToggleButton,最重要的属性。

        IsMouseOver:鼠标是否移入控件元素区域内。    IsPressed:是否按下。

        Margin:元素外边距。    Name:元素标识名称。    Opacity:透明度。

        Template:控件模板。    Visibility:可见性设置。
        
        FlowDirection:获取或设置文本和其他用户界面 (UI) 元素在控制其布局的任何父元素内流动的方向。

        RenderTransform:获取或设置影响此元素的呈现位置的转换信息。(旋转角度等设置)
        
        RenderTransformOrigin:获取或设置由 RenderTransform 声明的任何可能呈现转换的中心点,相对于元素的边界。

        HorizontalAlignment/VerticalAlignment:获取或设置在父元素(如面板或项控件)中组合此元素时所应用的水平对齐特征/垂直对齐特征。

        HorizontalContentAlignment/VerticalContentAlignment:获取或设置控件内容的水平对齐方式/垂直对齐方式。

    **************************************************************************************************************

    3、具体代码示例

    1. <StackPanel Margin="20">
    2. <RadioButton Name="rb1" Checked="WriteText2" Foreground="#dddddd" Margin="10" IsChecked="True">Yes</RadioButton>
    3. <RadioButton Name="rb2" Checked="WriteText2" Foreground="#dddddd" Margin="10">No</RadioButton>
    4. <RadioButton Name="rb3" Checked="WriteText2" Foreground="#dddddd" Margin="10">No opinion</RadioButton>
    5. <TextBlock Foreground="#dddddd" Margin="10" FontSize="15">
    6. <Run >选中项为:</Run>
    7. <Run x:Name="txtb"></Run>
    8. </TextBlock>
    9. </StackPanel>
    10. 代码示例二
    11. <StackPanel Margin="20" >
    12. <RadioButton Name="rb1" Width="160" Checked="WriteText2" Foreground="#dddddd" Margin="10" IsChecked="True">Yes</RadioButton>
    13. <Border Background="Teal" HorizontalAlignment="Center" VerticalAlignment="Center" Margin="10">
    14. <RadioButton Name="rb2" Checked="WriteText2" Foreground="#dddddd" FontSize="15" FontFamily="微软雅黑"
    15. Width="160" Height="45" HorizontalContentAlignment="Right" VerticalContentAlignment="Center">No</RadioButton>
    16. </Border>
    17. <!--设置元素流动方向为从右往左,控件内容水平居右,垂直居下-->
    18. <Border Background="Teal" HorizontalAlignment="Center" VerticalAlignment="Center">
    19. <RadioButton Name="rb3" Checked="WriteText2" Foreground="#dddddd" FlowDirection="RightToLeft"
    20. Width="160" Height="45" Content="No opinion" FontSize="15" HorizontalContentAlignment="Right" VerticalContentAlignment="Bottom"></RadioButton>
    21. </Border>
    22. <TextBlock Foreground="#dddddd" Margin="10" FontSize="15">
    23. <Run >选中项为:</Run>
    24. <Run x:Name="txtb"></Run>
    25. </TextBlock>
    26. </StackPanel>
    27. 代码示例三
    28. <StackPanel>
    29. <RadioButton GroupName="colorgrp" Margin="10" Foreground="#dddddd" IsChecked="True">Red</RadioButton>
    30. <RadioButton GroupName="colorgrp" Margin="10" Foreground="#dddddd" >Blue</RadioButton>
    31. <RadioButton GroupName="numgrp" Margin="10" Foreground="#dddddd" IsChecked="True">1</RadioButton>
    32. <RadioButton GroupName="numgrp" Margin="10" Foreground="#dddddd" >2</RadioButton>
    33. </StackPanel>

    后台代码

    1. private void WriteText2(object sender, RoutedEventArgs e)
    2. {
    3. RadioButton radioButton = (sender as RadioButton);
    4. if (radioButton != null && radioButton.Content != null)
    5. {
    6. txtb.Text = radioButton.Content.ToString();
    7. }
    8. }

    **************************************************************************************************************

    4、效果图

    示例二效果图,对FlowDirection进行设置,第三个单选按钮效果如下

    **************************************************************************************************************

    5、总结和扩展

        如果要在同一个布局块中,创建连个单独的RadioButton组,那么就需要对RadioButton进行分组,分组的话要使用GroupName属性,同一组的RadioButton,组名要一样,这样就可以区分了,具体示例参考代码三。

    **************************************************************************************************************

  • 相关阅读:
    SpringBoot项目--电脑商城【显示商品详情功能】
    React Query 数据库插件:与分布式系统的协作指南
    火山引擎DataLeap的数据血缘用例与设计概述
    SQL SERVER中XML查询:FOR XML指定RAW
    【笑小枫的按步照搬系列】JDK8下载安装配置
    调试平衡小车过程中间遇到的问题
    Flutter 数据存储大全之使用 MongoDB Realm 构建离线 Flutter 应用(教程含源码)
    【区分vue2和vue3下的element UI Message 消息提示组件,分别详细介绍属性,事件,方法如何使用,并举例】
    2019年初Java开发面试经验(南京)
    倒计时编写
  • 原文地址:https://blog.csdn.net/BYH371256/article/details/125347001