Custom TextBox
Learn creating a Custom TextBox using Windows App SDK with this Tutorial
data:image/s3,"s3://crabby-images/a7fd9/a7fd94b06c41904d848f7ca10e5657b8c9cde4e2" alt="Custom TextBox"
Custom TextBox shows how to create a Style for a TextBox using Windows App SDK.
Step 1
Follow Setup and Start on how to get Setup and Install what you need for Visual Studio 2022 and Windows App SDK.
data:image/s3,"s3://crabby-images/d34b7/d34b7f5bcf4d3a8ff8b41d9aae2c7f42876124df" alt="Visual Studio 2022"
data:image/s3,"s3://crabby-images/5f1f1/5f1f1ceb4b799e7dfbcdedae37f1d23a1a8d8bec" alt="Create a new project"
data:image/s3,"s3://crabby-images/c0d08/c0d08117cdb4008cd7b228a71dc755842d2774b4" alt="Blank App, Packages (WinUI in Desktop)"
data:image/s3,"s3://crabby-images/a8d71/a8d71590275d4e2f41ad555f5c86b82098a645a7" alt="Configure project"
Step 2
data:image/s3,"s3://crabby-images/32c9c/32c9c5795d3caa41464119b03de2db15e66acc4f" alt="Solution Explorer App.xaml"
Step 3
In the XAML for App.xaml below the Comment
of <!-- Other app resources here -->
type in the following XAML
for the Style
of CustomTextBox
that will be used to target a TextBox
:
<Style x:Key="CustomTextBox" TargetType="TextBox">
<Setter Property="MinWidth"
Value="{ThemeResource TextControlThemeMinWidth}"/>
<Setter Property="MinHeight"
Value="{ThemeResource TextControlThemeMinHeight}"/>
<Setter Property="Foreground" Value="Gold"/>
<Setter Property="Background"
Value="{ThemeResource TextControlBackground}"/>
<Setter Property="SelectionHighlightColor"
Value="{ThemeResource TextControlSelectionHighlightColor}"/>
<Setter Property="BorderThickness" Value="2"/>
<Setter Property="FontFamily"
Value="{ThemeResource ContentControlThemeFontFamily}"/>
<Setter Property="FontSize"
Value="{ThemeResource ControlContentThemeFontSize}"/>
<Setter Property="ScrollViewer.HorizontalScrollMode" Value="Auto"/>
<Setter Property="ScrollViewer.VerticalScrollMode" Value="Auto"/>
<Setter Property="ScrollViewer.HorizontalScrollBarVisibility" Value="Hidden"/>
<Setter Property="ScrollViewer.VerticalScrollBarVisibility" Value="Hidden"/>
<Setter Property="ScrollViewer.IsDeferredScrollingEnabled" Value="False"/>
<Setter Property="Padding" Value="{ThemeResource TextControlThemePadding}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="TextBox">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="CommonStates">
<!-- Visual State Disabled -->
<!-- Visual State Normal & Pointer Over -->
<!-- Visual State Focused -->
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<!-- Content -->
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Step 4
While still the XAML for App.xaml below the Comment
of <!-- Visual State Disabled -->
type in the following XAML:
<VisualState x:Name="Disabled">
<Storyboard>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="HeaderContentPresenter">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlHeaderForegroundDisabled}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Background"
Storyboard.TargetName="BorderElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlBackgroundDisabled}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="BorderBrush"
Storyboard.TargetName="BorderElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlBorderBrushDisabled}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="ContentElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlForegroundDisabled}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="PlaceholderTextContentPresenter">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlPlaceholderForegroundDisabled}"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</VisualState>
This XAML is for the Visual State that will represent the State
of Disabled
for the TextBox
used in the Custom TextBox.
Step 5
While still the XAML for App.xaml below the Comment
of <!-- Visual State Normal & Pointer Over -->
type in the following XAML:
<VisualState x:Name="Normal"/>
<VisualState x:Name="PointerOver">
<Storyboard>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="BorderBrush"
Storyboard.TargetName="BorderElement">
<DiscreteObjectKeyFrame KeyTime="0" Value="GoldenRod"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Background"
Storyboard.TargetName="BorderElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlBackgroundPointerOver}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="PlaceholderTextContentPresenter">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlPlaceholderForegroundPointerOver}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="ContentElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlForegroundPointerOver}"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</VisualState>
This XAML is for the Visual State that will represent the States
of Normal
and PointerOver
for the TextBox
used in the Custom TextBox.
Step 6
While still the XAML for App.xaml below the Comment
of <!-- Visual State Focused -->
type in the following XAML:
<VisualState x:Name="Focused">
<Storyboard>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="PlaceholderTextContentPresenter">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlPlaceholderForegroundFocused}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Background"
Storyboard.TargetName="BorderElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlBackgroundFocused}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="BorderBrush"
Storyboard.TargetName="BorderElement">
<DiscreteObjectKeyFrame KeyTime="0" Value="Gold"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="Foreground"
Storyboard.TargetName="ContentElement">
<DiscreteObjectKeyFrame KeyTime="0"
Value="{ThemeResource TextControlForegroundFocused}"/>
</ObjectAnimationUsingKeyFrames>
<ObjectAnimationUsingKeyFrames
Storyboard.TargetProperty="RequestedTheme"
Storyboard.TargetName="ContentElement">
<DiscreteObjectKeyFrame KeyTime="0" Value="Light"/>
</ObjectAnimationUsingKeyFrames>
</Storyboard>
</VisualState>
This XAML is for the Visual State that will represent the State
of Focused
for the TextBox
used in the Custom TextBox.
Step 7
Then in the XAML for App.xaml below the Comment
of <!-- Content -->
type in the following XAML:
<Border x:Name="BorderElement" Grid.Row="1"
Grid.RowSpan="1" Grid.ColumnSpan="2" CornerRadius="15"
BorderBrush="Salmon" Background="LightSalmon"
BorderThickness="{TemplateBinding BorderThickness}" />
<ScrollViewer x:Name="ContentElement" Grid.Row="1"
AutomationProperties.AccessibilityView="Raw"
IsTabStop="False" ZoomMode="Disabled"
HorizontalScrollMode="{TemplateBinding
ScrollViewer.HorizontalScrollMode}"
HorizontalScrollBarVisibility="{TemplateBinding
ScrollViewer.HorizontalScrollBarVisibility}"
IsHorizontalRailEnabled="{TemplateBinding
ScrollViewer.IsHorizontalRailEnabled}"
IsVerticalRailEnabled="{TemplateBinding
ScrollViewer.IsVerticalRailEnabled}"
IsDeferredScrollingEnabled="{TemplateBinding
ScrollViewer.IsDeferredScrollingEnabled}"
Margin="{TemplateBinding BorderThickness}"
Padding="{TemplateBinding Padding}"
VerticalScrollBarVisibility="{TemplateBinding
ScrollViewer.VerticalScrollBarVisibility}"
VerticalScrollMode="{TemplateBinding
ScrollViewer.VerticalScrollMode}" />
<ContentPresenter x:Name="PlaceholderTextContentPresenter"
Grid.Row="1" Grid.ColumnSpan="2"
Content="{TemplateBinding PlaceholderText}"
Foreground="Gold" IsHitTestVisible="False"
Margin="{TemplateBinding BorderThickness}"
Padding="{TemplateBinding Padding}"
TextWrapping="{TemplateBinding TextWrapping}"/>
This XAML is the Content for the layout of a TextBox
when the Style
is applied for the Custom TextBox.
Step 8
data:image/s3,"s3://crabby-images/44121/441214bcbad0d58c130630196bfbdd648d46abcd" alt="Solution Explorer MainWindow.xaml"
Step 9
In the XAML for MainWindow.xaml there will be some XAML for a StackPanel
, this should be Removed:
<StackPanel Orientation="Horizontal"
HorizontalAlignment="Center" VerticalAlignment="Center">
<Button x:Name="myButton" Click="myButton_Click">Click Me</Button>
</StackPanel>
Step 10
While still in the XAML for MainWindow.xaml above </Window>
, type in the following XAML:
<TextBox Margin="50" Text="TextBox" VerticalAlignment="Center"
Style="{StaticResource CustomTextBox}"/>
This XAML contains a TextBox
with Style
set to the
StaticResource
of CustomTextBox
from App.xaml.
Step 11
data:image/s3,"s3://crabby-images/c4c80/c4c80a9c189a19f97c44e26f95b2adeaa6136542" alt="Solution Explorer MainWindow.xaml.cs"
Step 12
In the Code for MainWindow.xaml.cs
there be a Method of myButton_Click(...)
this should be Removed by removing the following:
private void myButton_Click(object sender, RoutedEventArgs e)
{
myButton.Content = "Clicked";
}
Step 13
data:image/s3,"s3://crabby-images/3cc24/3cc2496d962383169c6d6007608a78d6d055523f" alt="CustomTextBox (Package)"
Step 14
Once running you will see the Custom TextBox displayed.
Step 15
data:image/s3,"s3://crabby-images/52ead/52eaddf924ce1ebef37c4c0ba84bea84c8f711c7" alt="Close application"