 
- XAML - Home
- XAML - Overview
- XAML - Environment Setup
- Writing XAML Aplication On MAC OS
- XAML Vs C# Code
- XAML Vs.VB.NET
- XAML - Building Blocks
- XAML - Controls
- XAML - Layouts
- XAML - Event Handling
- XAML - Data Binding
- XAML - Markup Extensions
- XAML - Dependency Properties
- XAML - Resources
- XAML - Templates
- XAML - Styles
- XAML - Triggers
- XAML - Debugging
- XAML - Custom Controls
XAML - Button
The Button class represents the most basic type of button control. The hierarchical inheritance of Button class is as follows −
 
Properties
| Sr.No. | Property & Description | 
|---|---|
| 1 | Background Gets or sets a brush that provides the background of the control. (Inherited from Control) | 
| 2 | BorderBrush Gets or sets a brush that describes the border fill of a control. (Inherited from Control) | 
| 3 | BorderThickness Gets or sets the border thickness of a control. (Inherited from Control) | 
| 4 | Content Gets or sets the content of a ContentControl. (Inherited from ContentControl) | 
| 5 | ClickMode Gets or sets a value that indicates when the Click event occurs, in terms of device behavior. (Inherited from ButtonBase) | 
| 6 | ContentTemplate Gets or sets the data template that is used to display the content of the ContentControl. (Inherited from ContentControl) | 
| 7 | FontFamily Gets or sets the font used to display text in the control. (Inherited from Control) | 
| 8 | FontSize Gets or sets the size of the text in this control. (Inherited from Control) | 
| 9 | FontStyle Gets or sets the style in which the text is rendered. (Inherited from Control) | 
| 10 | FontWeight Gets or sets the thickness of the specified font. (Inherited from Control) | 
| 11 | Foreground Gets or sets a brush that describes the foreground color. (Inherited from Control) | 
| 12 | Height Gets or sets the suggested height of a FrameworkElement. (Inherited from FrameworkElement) | 
| 13 | HorizontalAlignment Gets or sets the horizontal alignment characteristics that are applied to a FrameworkElement when it is composed in a layout parent, such as a panel or items control. (Inherited from FrameworkElement) | 
| 14 | IsEnabled Gets or sets a value indicating whether the user can interact with the control. (Inherited from Control) | 
| 15 | IsPressed Gets a value that indicates whether a ButtonBase is currently in a pressed state. (Inherited from ButtonBase) | 
| 16 | Margin Gets or sets the outer margin of a FrameworkElement. (Inherited from FrameworkElement) | 
| 17 | Name Gets or sets the identifying name of the object. When a XAML processor creates the object tree from XAML markup, run-time code can refer to the XAML-declared object by this name. (Inherited from FrameworkElement) | 
| 18 | Opacity Gets or sets the degree of the object's opacity. (Inherited from UIElement) | 
| 19 | Resources Gets the locally defined resource dictionary. In XAML, you can establish resource items as child object elements of a frameworkElement. Resources property element, through XAML implicit collection syntax. (Inherited from FrameworkElement) | 
| 20 | Style Gets or sets an instance Style that is applied for this object during layout and rendering. (Inherited from FrameworkElement) | 
| 21 | Template Gets or sets a control template. The control template defines the visual appearance of a control in UI, and is defined in XAML markup. (Inherited from Control) | 
| 22 | VerticalAlignment Gets or sets the vertical alignment characteristics that are applied to a FrameworkElement when it is composed in a parent object such as a panel or items control. (Inherited from FrameworkElement) | 
| 23 | Visibility Gets or sets the visibility of a UIElement. A UIElement that is not visible is not rendered and does not communicate its desired size to layout. (Inherited from UIElement) | 
| 24 | Width Gets or sets the width of a FrameworkElement. (Inherited from FrameworkElement) | 
Methods
| Sr.No. | Method & Description | 
|---|---|
| 1 | ClearValue Clears the local value of a dependency property. (Inherited from DependencyObject) | 
| 2 | FindName Retrieves an object that has the specified identifier name. (Inherited from FrameworkElement) | 
| 3 | OnApplyTemplate Invoked whenever application code or internal processes (such as a rebuilding layout pass) call ApplyTemplate. In simplest terms, this means the method is called just before a UI element displays in your app. Override this method to influence the default post-template logic of a class. (Inherited from FrameworkElement) | 
| 4 | OnContentChanged Invoked when the value of the Content property changes. (Inherited from ContentControl) | 
| 5 | OnDragEnter Called before the DragEnter event occurs. (Inherited from Control) | 
| 6 | OnDragLeave Called before the DragLeave event occurs. (Inherited from Control) | 
| 7 | OnDragOver Called before the DragOver event occurs. (Inherited from Control) | 
| 8 | OnDrop Called before the Drop event occurs. (Inherited from Control) | 
| 9 | OnGotFocus Called before the GotFocus event occurs. (Inherited from Control) | 
| 10 | OnKeyDown Called before the KeyDown event occurs. (Inherited from Control) | 
| 11 | OnKeyUp Called before the KeyUp event occurs. (Inherited from Control) | 
| 12 | OnLostFocus Called before the LostFocus event occurs. (Inherited from Control) | 
| 13 | SetBinding Attaches a binding to a FrameworkElement, using the provided binding object. (Inherited from FrameworkElement) | 
Events
| Sr.No. | Event & Description | 
|---|---|
| 1 | Click Occurs when a button control is clicked. (Inherited from ButtonBase) | 
| 2 | DataContextChanged Occurs when the value of the FrameworkElement. DataContext property changes. (Inherited from FrameworkElement) | 
| 3 | DragEnter Occurs when the input system reports an underlying drag event with this element as the target. (Inherited from UIElement) | 
| 4 | DragLeave Occurs when the input system reports an underlying drag event with this element as the origin. (Inherited from UIElement) | 
| 5 | DragOver Occurs when the input system reports an underlying drag event with this element as the potential drop target. (Inherited from UIElement) | 
| 6 | DragStarting Occurs when a drag operation is initiated. (Inherited from UIElement) | 
| 7 | GotFocus Occurs when a UIElement receives focus. (Inherited from UIElement) | 
| 8 | Holding Occurs when an otherwise unhandled Hold interaction occurs over the hit test area of this element. (Inherited from UIElement) | 
| 9 | IsEnabledChanged Occurs when the IsEnabled property changes. (Inherited from Control) | 
| 10 | OnKeyDown Occurs when a keyboard key is pressed while the UIElement has focus. (Inherited from UIElement) | 
| 11 | OnKeyUp Occurs when a keyboard key is released while the UIElement has focus. (Inherited from UIElement) | 
| 12 | LostFocus Occurs when a UIElement loses focus. (Inherited from UIElement) | 
| 13 | SizeChanged Occurs when either the ActualHeight or the ActualWidth property changes value on a FrameworkElement. (Inherited from FrameworkElement) | 
Example
The following example contains three buttons that respond differently based on their ClickMode property value.
Here is the XAML code in which three buttons are created with some properties and a click event.
<Window x:Class = "XAMLButton.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 Margin = "10"> 
         <Button x:Name = "button1"  
            Content = "Hover" 
            Click = "OnClick1" 
            ClickMode = "Hover" 
            Margin = "10"  
            Width = "150" 
            HorizontalAlignment = "Center" 
            Foreground = "Gray"/> 
			<Button x:Name = "button2"  
            Content = "Press to Click" 
            Click = "OnClick2"  
            ClickMode = "Press" 
            Margin = "10"  
            Width = "150"  
            HorizontalAlignment = "Center"  
            Foreground = "DarkBlue"/> 
			<Button x:Name = "button3"  
            Content = "Release" 
            Click = "OnClick3"  
            ClickMode = "Release" 
            Margin = "10"  
            Width = "150" 
            HorizontalAlignment = "Center"/> 
      </StackPanel> 
   </Grid>
   
</Window>
Here is the click event implementation in C#.
using System; 
using System.Windows; 
using System.Windows.Controls; 
using System.Windows.Media;  
namespace XAMLButton { 
   /// <summary> 
      /// Interaction logic for MainWindow.xaml 
   /// </summary>
	public partial class MainWindow : Window {
      public MainWindow() { 
         InitializeComponent(); 
      }  
      void OnClick1(object sender, RoutedEventArgs e) { 
         button1.Foreground = new SolidColorBrush(Colors.Blue); 
         MessageBox.Show("On Hover click event occurs."); 
      } 
      void OnClick2(object sender, RoutedEventArgs e) { 
         button2.Foreground = new SolidColorBrush(Colors.Green); 
         MessageBox.Show("On Press click event occurs."); 
      } 
      void OnClick3(object sender, RoutedEventArgs e) { 
         button1.Foreground = new SolidColorBrush(Colors.Green); 
         button2.Foreground = new SolidColorBrush(Colors.Blue); 
         MessageBox.Show("On Release click event occurs."); 
      }
   } 
} 
When you compile and execute the above code, it will produce the following screen −
 
When the mouse enters in the region of the first button, it will display the following message −
 
When you press the second button, it will display the following message −
 
When you release the last button after a click, it will display the following message −
 
We recommend you to execute the above example code and experiment with some other properties and events.