- XAML 教程
- XAML - 首頁
- XAML - 概述
- XAML - 環境設定
- 在 macOS 上編寫 XAML 應用程式
- XAML 與 C# 程式碼
- XAML 與 VB.NET
- XAML - 構建塊
- XAML - 控制元件
- XAML - 佈局
- XAML - 事件處理
- XAML - 資料繫結
- XAML - 標記擴充套件
- XAML - 依賴屬性
- XAML - 資源
- XAML - 模板
- XAML - 樣式
- XAML - 觸發器
- XAML - 除錯
- XAML - 自定義控制元件
- XAML 有用資源
- XAML - 快速指南
- XAML - 有用資源
- XAML - 討論
XAML - 複選框
複選框是一個使用者可以選擇(選中)或取消選擇(取消選中)的控制元件。它提供了一個使用者可以選擇的一系列選項,例如應用於應用程式的一系列設定。複選框類的層次繼承如下:
屬性
| 序號 | 屬性和描述 |
|---|---|
| 1 | Background 獲取或設定一個畫刷,提供控制元件的背景。(繼承自 Control) |
| 2 | BorderBrush 獲取或設定一個畫刷,描述控制元件的邊框填充。(繼承自 Control) |
| 3 | BorderThickness 獲取或設定控制元件的邊框粗細。(繼承自 Control) |
| 4 | Content 獲取或設定 ContentControl 的內容。(繼承自 ContentControl) |
| 5 | ClickMode 獲取或設定一個值,指示 Click 事件何時發生,以裝置行為的形式。(繼承自 ButtonBase) |
| 6 | ContentTemplate 獲取或設定用於顯示 ContentControl 內容的資料模板。(繼承自 ContentControl) |
| 7 | FontFamily 獲取或設定用於在控制元件中顯示文字的字型。(繼承自 Control) |
| 8 | FontSize 獲取或設定此控制元件中文字的大小。(繼承自 Control) |
| 9 | FontStyle 獲取或設定呈現文字的樣式。(繼承自 Control) |
| 10 | FontWeight 獲取或設定指定字型的粗細。(繼承自 Control) |
| 11 | Foreground 獲取或設定一個畫刷,描述前景色。(繼承自 Control) |
| 12 | Height 獲取或設定 FrameworkElement 的建議高度。(繼承自 FrameworkElement) |
| 13 | HorizontalAlignment 獲取或設定應用於 FrameworkElement 的水平對齊特性,當它在佈局父級(如面板或專案控制元件)中組合時。(繼承自 FrameworkElement) |
| 14 | IsChecked 獲取或設定 ToggleButton 是否被選中。(繼承自 ToggleButton) |
| 15 | IsEnabled 獲取或設定一個值,指示使用者是否可以與控制元件互動。(繼承自 Control) |
| 16 | IsPressed 獲取一個值,指示 ButtonBase 當前是否處於按下狀態。(繼承自 ButtonBase) |
| 17 | IsThreeState 獲取或設定一個值,指示控制元件是否支援三種狀態。(繼承自 ToggleButton) |
| 18 | Margin 獲取或設定 FrameworkElement 的外邊距。(繼承自 FrameworkElement) |
| 19 | Name 獲取或設定物件的標識名稱。當 XAML 處理器從 XAML 標記建立物件樹時,執行時程式碼可以透過此名稱引用 XAML 宣告的物件。(繼承自 FrameworkElement) |
| 20 | Opacity 獲取或設定物件的透明度。(繼承自 UIElement) |
| 21 | Resources 獲取本地定義的資源字典。在 XAML 中,您可以將資源項作為 frameworkElement 的子物件元素建立。Resources 屬性元素,透過 XAML 隱式集合語法。(繼承自 FrameworkElement) |
| 22 | Style 獲取或設定一個 Style 例項,在佈局和渲染期間應用於此物件。(繼承自 FrameworkElement) |
| 23 | Template 獲取或設定控制元件模板。控制元件模板定義 UI 中控制元件的視覺外觀,並在 XAML 標記中定義。(繼承自 Control) |
| 24 | VerticalAlignment 獲取或設定應用於 FrameworkElement 的垂直對齊特性,當它在父物件(如面板或專案控制元件)中組合時。(繼承自 FrameworkElement) |
| 25 | Visibility 獲取或設定 UIElement 的可見性。不可見的 UIElement 不會呈現,也不會將其所需大小傳達給佈局。(繼承自 UIElement) |
| 26 | Width 獲取或設定 FrameworkElement 的寬度。(繼承自 FrameworkElement) |
方法
| 序號 | 方法和描述 |
|---|---|
| 1 | ClearValue 清除依賴屬性的本地值。(繼承自 DependencyObject) |
| 2 | FindName 檢索具有指定標識名稱的物件。(繼承自 FrameworkElement) |
| 3 | OnApplyTemplate 每當應用程式程式碼或內部程序(例如重建佈局傳遞)呼叫 ApplyTemplate 時都會呼叫。簡單來說,這意味著該方法在 UI 元素在應用程式中顯示之前被呼叫。重寫此方法以影響類的預設模板後邏輯。(繼承自 FrameworkElement) |
| 4 | OnContentChanged 當 Content 屬性的值更改時呼叫。(繼承自 ContentControl) |
| 5 | OnDragEnter 在 DragEnter 事件發生之前呼叫。(繼承自 Control) |
| 6 | OnDragLeave 在 DragLeave 事件發生之前呼叫。(繼承自 Control) |
| 7 | OnDragOver 在 DragOver 事件發生之前呼叫。(繼承自 Control) |
| 8 | OnDrop 在 Drop 事件發生之前呼叫。(繼承自 Control) |
| 9 | OnGotFocus 在 GotFocus 事件發生之前呼叫。(繼承自 Control) |
| 10 | OnKeyDown 在 KeyDown 事件發生之前呼叫。(繼承自 Control) |
| 11 | OnKeyUp 在 KeyUp 事件發生之前呼叫。(繼承自 Control) |
| 12 | OnLostFocus 在 LostFocus 事件發生之前呼叫。(繼承自 Control) |
| 13 | OnToggle 當 ToggleButton 接收切換刺激時呼叫。(繼承自 ToggleButton) |
| 14 | SetBinding 使用提供的繫結物件將繫結附加到 FrameworkElement。(繼承自 FrameworkElement) |
事件
| 序號 | 事件和描述 |
|---|---|
| 1 | Checked 當 ToggleButton 被選中時觸發。(繼承自 ToggleButton) |
| 2 | Click 當按鈕控制元件被點選時發生。(繼承自 ButtonBase) |
| 3 | DataContextChanged 當 FrameworkElement.DataContext 屬性的值更改時發生。(繼承自 FrameworkElement) |
| 4 | DragEnter 當輸入系統報告基礎拖動事件並將此元素作為目標時發生。(繼承自 UIElement) |
| 5 | DragLeave 當輸入系統報告基礎拖動事件並將此元素作為源時發生。(繼承自 UIElement) |
| 6 | DragOver 當輸入系統報告基礎拖動事件並將此元素作為潛在放置目標時發生。(繼承自 UIElement) |
| 7 | DragStarting 當拖動操作開始時發生。(繼承自 UIElement) |
| 8 | GotFocus 當 UIElement 獲得焦點時發生。(繼承自 UIElement) |
| 9 | Holding 當在此元素的命中測試區域上發生未處理的 Hold 互動時發生。(繼承自 UIElement) |
| 10 | Intermediate 當 ToggleButton 的狀態切換到不確定狀態時觸發。(繼承自 ToggleButton) |
| 11 | IsEnabledChanged 當 IsEnabled 屬性更改時發生。(繼承自 Control) |
| 12 | KeyDown 當 UIElement 具有焦點時按下鍵盤鍵時發生。(繼承自 UIElement) |
| 13 | KeyUp 當 UIElement 具有焦點時釋放鍵盤鍵時發生。(繼承自 UIElement) |
| 14 | LostFocus 當 UIElement 失去焦點時發生。(繼承自 UIElement) |
| 15 | SizeChanged 當 FrameworkElement 上的 ActualHeight 或 ActualWidth 屬性的值更改時發生。(繼承自 FrameworkElement) |
| 16 | Unchecked 當 ToggleButton 被取消選中時發生。(繼承自 ToggleButton) |
示例
以下示例包含兩個複選框。第一個複選框有兩個狀態:選中或未選中。第二個複選框有三個狀態:選中、未選中和不確定狀態。兩個複選框都根據 Checked、Unchecked 和 Intermediate 事件顯示訊息。
以下是建立了兩個複選框並設定了一些屬性和事件的 XAML 程式碼。
<Window x:Class = "XAMLCheckBox.MainWindow"
xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml"
Title = "MainWindow" Height = "350" Width = "604">
<Grid>
<StackPanel Orientation = "Vertical" >
<CheckBox x:Name = "cb1"
Content = "2 state CheckBox"
Checked = "HandleCheck"
Unchecked = "HandleUnchecked"
Margin = "10" />
<TextBlock x:Name = "text1" Margin = "10" />
<CheckBox x:Name = "cb2"
Content = "3 state CheckBox"
IsThreeState = "True"
Indeterminate = "HandleThirdState"
Checked = "HandleCheck"
Unchecked = "HandleUnchecked"
Margin = "10" />
<TextBlock x:Name = "text2" Margin = "10" />
</StackPanel>
</Grid>
</Window>
以下是 C# 中針對不同事件的實現:
using System;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;
namespace XAMLCheckBox {
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window {
public MainWindow() {
InitializeComponent();
}
private void HandleCheck(object sender, RoutedEventArgs e) {
CheckBox cb = sender as CheckBox;
if (cb.Name == "cb1") {
text1.Text = "2 state CheckBox is checked.";
} else {
text2.Text = "3 state CheckBox is checked.";
}
}
private void HandleUnchecked(object sender, RoutedEventArgs e) {
CheckBox cb = sender as CheckBox;
if (cb.Name == "cb1") {
text1.Text = "2 state CheckBox is unchecked.";
} else {
text2.Text = "3 state CheckBox is unchecked.";
}
}
private void HandleThirdState(object sender, RoutedEventArgs e) {
CheckBox cb = sender as CheckBox;
text2.Text = "3 state CheckBox is in indeterminate state.";
}
}
}
編譯並執行以上程式碼後,將產生以下輸出:
建議您執行以上示例程式碼並嘗試一些其他屬性和事件。