首页
学习
活动
专区
圈层
工具
发布
50 篇文章
1
【愚公系列】2023年09月 WPF控件专题 XAML介绍
2
【愚公系列】2023年09月 WPF控件专题 WPF应用程序组成
3
【愚公系列】2023年09月 WPF控件专题 Window窗体属性和事件
4
【愚公系列】2023年09月 WPF控件专题 Label、TextBox、PasswordBox控件介绍
5
【愚公系列】2023年09月 WPF控件专题 Button控件详解
6
【愚公系列】2023年09月 WPF控件专题 RadioButton控件详解
7
【愚公系列】2023年09月 WPF控件专题 CheckBox控件详解
8
【愚公系列】2023年09月 WPF控件专题 Image控件详解
9
【愚公系列】2023年09月 WPF控件专题 Border控件详解
10
【愚公系列】2023年09月 WPF控件专题 ComboBox控件详解
11
【愚公系列】2023年09月 WPF控件专题 ListBox控件详解
12
【愚公系列】2023年09月 WPF控件专题 DatePicker控件详解
13
【愚公系列】2023年09月 WPF控件专题 Calendar控件详解
14
【愚公系列】2023年09月 WPF控件专题 Slider控件详解
15
【愚公系列】2023年09月 WPF控件专题 ProgressBar控件详解
16
【愚公系列】2023年10月 WPF控件专题 StackPanel控件详解
17
【愚公系列】2023年10月 WPF控件专题 WrapPanel控件详解
18
【愚公系列】2023年10月 WPF控件专题 DockPanel控件详解
19
【愚公系列】2023年10月 WPF控件专题 Canvas控件详解
20
【愚公系列】2023年10月 WPF控件专题 Grid控件详解
21
【愚公系列】2023年10月 WPF控件专题 Groupbox控件详解
22
【愚公系列】2023年10月 WPF控件专题 Expander控件详解
23
【愚公系列】2023年10月 WPF控件专题 TabControl控件详解
24
【愚公系列】2023年10月 WPF控件专题 Frame控件详解
25
【愚公系列】2023年10月 WPF控件专题 ListView控件详解
26
【愚公系列】2023年10月 WPF控件专题 DataGrid控件详解
27
【愚公系列】2023年10月 WPF控件专题 Menu控件详解
28
【愚公系列】2023年10月 WPF控件专题 ContextMenu控件详解
29
【愚公系列】2023年10月 WPF控件专题 TreeView控件详解
30
【愚公系列】2023年10月 WPF控件专题 ToolBar控件详解
31
【愚公系列】2023年10月 WPF控件专题 ToolBarTray控件详解
32
【愚公系列】2023年10月 WPF控件专题 StatusBar控件详解
33
【愚公系列】2023年11月 WPF控件专题 MediaElement控件详解
34
【愚公系列】2023年11月 WPF控件专题 RichTextBox控件详解
35
【愚公系列】2023年11月 WPF控件专题 GridView控件详解
36
【愚公系列】2023年11月 WPF控件专题 Rectangle控件详解
37
【愚公系列】2023年11月 WPF控件专题 Popup控件详解
38
【愚公系列】2023年11月 WPF控件专题 OpenFileDialog控件详解
39
【愚公系列】2023年11月 WPF控件专题 SaveFileDialog控件详解
40
【愚公系列】2023年11月 WPF控件专题 RepeatButton控件详解
41
【愚公系列】2023年11月 WPF控件专题 Ellipse控件详解
42
【愚公系列】2023年11月 WPF控件专题 Polygon控件详解
43
【愚公系列】2023年11月 WPF控件专题 Path控件详解
44
【愚公系列】2023年11月 WPF控件专题 WindowFormsHost控件详解
45
【愚公系列】2023年11月 WPF控件专题 WebBrowser控件详解
46
【愚公系列】2023年11月 WPF控件专题 Validation控件详解
47
【愚公系列】2023年11月 WPF控件专题 Page控件详解
48
【愚公系列】2023年11月 WPF控件专题 PrintDialog控件详解
49
【愚公系列】2023年11月 WPF控件专题 Track控件详解
50
【愚公系列】2023年11月 WPF控件专题 Polyline控件详解

【愚公系列】2023年09月 WPF控件专题 CheckBox控件详解

🏆 作者简介,愚公搬代码 🏆《头衔》:华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,阿里云专家博主,腾讯云优秀博主,掘金优秀博主,51CTO博客专家等。 🏆《近期荣誉》:2022年CSDN博客之星TOP2,2022年华为云十佳博主等。 🏆《博客内容》:.NET、Java、Python、Go、Node、前端、IOS、Android、鸿蒙、Linux、物联网、网络安全、大数据、人工智能、U3D游戏、小程序等相关领域知识。 🏆🎉欢迎 👍点赞✍评论⭐收藏

🚀前言

WPF控件是Windows Presentation Foundation(WPF)中的基本用户界面元素。它们是可视化对象,可以用来创建各种用户界面。WPF控件可以分为两类:原生控件和自定义控件。

原生控件是由Microsoft提供的内置控件,如Button、TextBox、Label、ComboBox等。这些控件都是WPF中常见的标准用户界面元素。

自定义控件则允许开发人员使用XAML和C#等编程语言来创建个性化的用户界面元素。自定义控件可以根据需求提供更多的功能和自定义化选项,以及更好的用户体验。

🚀一、CheckBox控件详解

CheckBox控件是WPF中常用的用户交互控件之一,用于表示一个二进制选项,用户可以选择或取消选择该选项。其常见的使用场景包括选择/取消选择某些功能,控制某些设置等。

CheckBox控件具有以下常用属性:

  • Content:用于显示复选框旁边的文本内容。
  • IsChecked:用于获取或设置复选框的选中状态,其值类型为Nullable<bool>,即既可以为true,也可以为false,还可以为null表示未选中。
  • IsThreeState:指示是否启用三态模式,即除了true和false外,还可以有一个null的状态。默认值为false。

WPF中可以通过XAML或代码来创建CheckBox控件,下面分别介绍两种方法:

  1. XAML创建CheckBox控件
代码语言:html
复制
<CheckBox Content="是否同意协议" IsChecked="True" />

在上述代码中,Content属性用于显示文本内容,IsChecked属性用于设置初始选中状态。

  1. 代码创建CheckBox控件
代码语言:c#
复制
CheckBox checkBox = new CheckBox();
checkBox.Content = "是否同意协议";
checkBox.IsChecked = true;
stackPanel.Children.Add(checkBox);

在上述代码中,我们创建了一个名为checkBox的CheckBox控件,并设置Content和IsChecked属性,最后通过将其添加到一个名为stackPanel的Panel容器中,使其显示在界面中。

需要注意的是,在WPF中,可以通过自定义ControlTemplate来修改CheckBox控件的外观和行为。例如,可以修改CheckBox的选中状态图标、背景色、边框等,以满足不同的设计需求。CheckBox控件是WPF中常用的用户交互控件之一,用于表示一个二进制选项,用户可以选择或取消选择该选项。其常见的使用场景包括选择/取消选择某些功能,控制某些设置等。

CheckBox控件具有以下常用属性:

  • Content:用于显示复选框旁边的文本内容。
  • IsChecked:用于获取或设置复选框的选中状态,其值类型为Nullable<bool>,即既可以为true,也可以为false,还可以为null表示未选中。
  • IsThreeState:指示是否启用三态模式,即除了true和false外,还可以有一个null的状态。默认值为false。

WPF中可以通过XAML或代码来创建CheckBox控件,下面分别介绍两种方法:

  1. XAML创建CheckBox控件
代码语言:html
复制
<CheckBox Content="是否同意协议" IsChecked="True" />

在上述代码中,Content属性用于显示文本内容,IsChecked属性用于设置初始选中状态。

  1. 代码创建CheckBox控件
代码语言:c#
复制
CheckBox checkBox = new CheckBox();
checkBox.Content = "是否同意协议";
checkBox.IsChecked = true;
stackPanel.Children.Add(checkBox);

在上述代码中,我们创建了一个名为checkBox的CheckBox控件,并设置Content和IsChecked属性,最后通过将其添加到一个名为stackPanel的Panel容器中,使其显示在界面中。

需要注意的是,在WPF中,可以通过自定义ControlTemplate来修改CheckBox控件的外观和行为。例如,可以修改CheckBox的选中状态图标、背景色、边框等,以满足不同的设计需求。

🔎1.属性介绍

WPF中CheckBox控件的属性包括:

  1. Content:控件的文本内容。
  2. IsChecked:控件的勾选状态,可以绑定到数据模型的属性。
  3. IsThreeState:控件的是否支持三态选择。
  4. Checked:勾选状态下的事件处理方法。
  5. Unchecked:非勾选状态下的事件处理方法。
  6. Indeterminate:中间状态下的事件处理方法。
  7. Command:与该控件关联的命令。
  8. CommandParameter:命令的参数。
  9. CommandTarget:命令的目标对象。
  10. HorizontalContentAlignment:控件内容的水平对齐方式。
  11. VerticalContentAlignment:控件内容的垂直对齐方式。
  12. Margin:控件的外边距。
  13. Padding:控件的内边距。
  14. Width:控件的宽度。
  15. Height:控件的高度。
  16. Foreground:控件前景色。
  17. Background:控件背景色。
  18. BorderBrush:控件边框颜色。
  19. BorderThickness:控件边框粗细。WPF中CheckBox控件的属性包括:

🔎2.常用场景

  1. 选项设置:在设置软件的一些选项时,可以使用CheckBox控件来让用户选择或取消某些选项。
  2. 多选筛选:在数据查询界面或数据筛选界面,可以使用多个CheckBox来实现多选筛选功能。
  3. 订阅与取消订阅:在订阅一些资讯或服务时,可以使用CheckBox来让用户选择是否订阅或取消订阅。
  4. 表单中的确认:在表单中,可以用CheckBox来让用户确认填写的信息是否正确。
  5. 条款同意:在一些注册或协议页面中,可以使用CheckBox来让用户同意相关条款。
  6. 任务状态:在任务管理系统中,可以使用CheckBox来标记完成的任务。
  7. 产品特性:在产品展示页面中,可以使用CheckBox来展示产品的不同特性,用户可以选择自己需要的特性。

🔎3.具体案例

代码语言:html
复制
<Grid Name="grid1">
    <!--中间状态时 IsChecked  空-->
    <!--<CheckBox Name="chkSport" Content="体育" IsChecked="True" IsThreeState="True" HorizontalAlignment="Left" Margin="264,117,0,0" VerticalAlignment="Top"/>
    <CheckBox Content="唱歌"  HorizontalAlignment="Left" Margin="337,120,0,0" VerticalAlignment="Top"/>
    <CheckBox Content="跳舞"  HorizontalAlignment="Left" Margin="398,120,0,0" VerticalAlignment="Top"/>-->
    <Button Content="添加" HorizontalAlignment="Left" Margin="255,169,0,0" VerticalAlignment="Top" Width="75" Click="Button_Click"/>
    <Button Content="获取" Name="btnGet" HorizontalAlignment="Left" Margin="369,169,0,0" VerticalAlignment="Top" Width="75" Click="BtnGet_Click"/>
</Grid>
代码语言:c#
复制
private void Button_Click(object sender, RoutedEventArgs e)
{
    //MessageBox.Show(chkSport.IsChecked.ToString());


 
    //代码动态添加CheckBox
    string[] names = { "体育", "唱歌", "跳舞", "绘画" };
    for (int i = 0; i < names.Length; i++)
    {
        CheckBox chk = new CheckBox();
        chk.Content = names[i];
        chk.HorizontalAlignment = HorizontalAlignment.Left;
        chk.VerticalAlignment = VerticalAlignment.Top;
        chk.Margin = new Thickness(40+i*80, 60, 0, 0);
        grid1.Children.Add(chk);
    }

}

private void BtnGet_Click(object sender, RoutedEventArgs e)
{
    //获取窗口中所有勾选的CheckBox的Content
    string strContens = "";
    foreach (UIElement ele in grid1.Children)
    {
        if (ele is CheckBox)
        {
            CheckBox chk = ele as CheckBox;
            if (chk.IsChecked == true)
            {
                if (strContens != "")
                    strContens += ",";
                strContens += chk.Content.ToString();
            }
        }
    }
    MessageBox.Show(strContens);
}

我正在参与2023腾讯技术创作特训营第二期有奖征文,瓜分万元奖池和键盘手表

下一篇
举报
领券