UserControl - Custom Controls
In Wpf a UserControl provides a way to encapsulate a design block with complete functionality. A user control allows you to extend an existing block like Border, Button, etc or to create a design and functionality from scratch.
Start by creating a new Wpf project with C#. The final solution structure will look like:
data:image/s3,"s3://crabby-images/1c412/1c412f2da6add6490b3713899252a6307d0b0128" alt="wpf_customusercontrol_1_structure"
data:image/s3,"s3://crabby-images/1c412/1c412f2da6add6490b3713899252a6307d0b0128" alt="wpf_customusercontrol_1_structure"
The to add a new UserControl right click on the CustomCtrl folder and add new item, then choose the user control item. Save this item as CircleInfo.
data:image/s3,"s3://crabby-images/46320/46320bbc47ef4d3a1be66cf247d1e24647e81fcb" alt="wpf_customusercontrol_3_addItem"
data:image/s3,"s3://crabby-images/46320/46320bbc47ef4d3a1be66cf247d1e24647e81fcb" alt="wpf_customusercontrol_3_addItem"
In the CircleInfo.cs file (of the CircleInfo.xaml file) add 2 new DependencyProperties(!make sure to set the data context in the constructor):
public partial class CircleInfo : UserControl { public static readonly DependencyProperty SizeProperty = DependencyProperty.Register("Size", typeof(double), typeof(CircleInfo)); public static readonly DependencyProperty InfoProperty = DependencyProperty.Register("Info", typeof(string), typeof(CircleInfo)); public double Size { get => (double)GetValue(SizeProperty); set => SetValue(SizeProperty, value); } public string Info { get => (string)GetValue(InfoProperty); set => SetValue(InfoProperty, value); } public CircleInfo() { InitializeComponent(); this.DataContext = this; } }
To create a circle with some text inside you can do that using an ellipse or even simpler (like CSS) provide a high corner radius value (more then 50% of the size).
We want to create the following view into xaml:
data:image/s3,"s3://crabby-images/23762/237626d0f0955f2510c2b53dc954f347be879e26" alt="wpf_customusercontrol_4_CircleInfoViewer"
data:image/s3,"s3://crabby-images/23762/237626d0f0955f2510c2b53dc954f347be879e26" alt="wpf_customusercontrol_4_CircleInfoViewer"
The code to make this is:
<UserControl x:Class="WpfApp1.CustomCtrl.CircleInfo" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WpfApp1.CustomCtrl" mc:Ignorable="d" d:DesignHeight="300" d:DesignWidth="300"> <Grid> <Border Width="{Binding Size, FallbackValue=50}" Height="{Binding Size, FallbackValue=50}" CornerRadius="{Binding Size, FallbackValue=50}" BorderBrush="Blue" BorderThickness="3"> <StackPanel Orientation="Horizontal" HorizontalAlignment="Center" VerticalAlignment="Center"> <Label Content="i:" FontSize="14" Foreground="Gold" /> <TextBlock VerticalAlignment="Center" Foreground="White" Text="{Binding Info, FallbackValue=Info}"/> </StackPanel> </Border> </Grid> </UserControl>
In MainWindow the implementation is straight forward:
First step is to add a reference to the xaml namespace
xmlns:comp="clr-namespace:WpfApp1.CustomCtrl"
Then add the circle info with configured as you want:
<Window x:Class="WpfApp1.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WpfApp1" xmlns:comp="clr-namespace:WpfApp1.CustomCtrl" mc:Ignorable="d" Title="MainWindow" Height="150" Width="150"> <Grid Background="Black"> <comp:CircleInfo Size="75 " Info="Hello"/> </Grid> </Window>
data:image/s3,"s3://crabby-images/b5e9a/b5e9ae9ff978aad908d33bb3d8e7bd1b861e7029" alt="wpf_customusercontrol_2_result"
data:image/s3,"s3://crabby-images/b5e9a/b5e9ae9ff978aad908d33bb3d8e7bd1b861e7029" alt="wpf_customusercontrol_2_result"