Skip to main content
Version: 11.0.x

Input Controls

On this page, you will learn how to add input controls and arrange them in a neatly aligned layout. The aim is to add numerical inputs with labels and an output control following in the row below.

To achieve this layout, you will use the built-in Grid control to create cells and assign our controls to those cells.

The following picture shows the finished application at runtime with the gridlines showing for layout visualization purposes. Normally, these are invisible on a production UI.

Tempature StackPanelTempature StackPanel

To create a layout using the Grid control with 2 columns and 3 rows, follow this procedure:

  • Stop the app if it is running.
  • Locate the empty line in the XAML between <Border> and <Button>
  • Insert a <Grid> tag as shown:
<StackPanel>
<Border Margin="5" CornerRadius="10" Background="LightBlue">
<TextBlock Margin="5"
HorizontalAlignment="Center"
FontSize="24"
Text="Temperature Converter" />
</Border>
<Grid ShowGridLines="True" Margin="5"
ColumnDefinitions="120, 100"
RowDefinitions="Auto, Auto, Auto">
</Grid>
<Button HorizontalAlignment="Center">Calculate</Button>
</StackPanel>

This assigns the number of rows and columns, their sizes, and makes the gridlines visible. Currently, it will show as a straight line because the grid cells are empty. The Auto rows size to their content and will have zero height until content is added.

  • Add <Label> and <TextBox> (text input) controls to the Grid's children as shown:
<Grid ShowGridLines="True" Margin="5"
ColumnDefinitions="120, 100"
RowDefinitions="Auto, Auto, Auto">
<Label Grid.Row="0" Grid.Column="0">Celsius</Label>
<TextBox Grid.Row="0" Grid.Column="1"/>
<Label Grid.Row="1" Grid.Column="0">Fahrenheit</Label>
<TextBox Grid.Row="1" Grid.Column="1"/>
</Grid>

To complete the layout, tidy up the alignment of the controls in the Grid using their Margin property. Also, move the Button inside the Grid.

<Grid ShowGridLines="True"  Margin="5" 
ColumnDefinitions="120, 100"
RowDefinitions="Auto, Auto, Auto">
<Label Grid.Row="0" Grid.Column="0" Margin="10">Celsius</Label>
<TextBox Grid.Row="0" Grid.Column="1" Margin="0 5" Text="0"/>
<Label Grid.Row="1" Grid.Column="0" Margin="10">Fahrenheit</Label>
<TextBox Grid.Row="1" Grid.Column="1" Margin="0 5" Text="0"/>
<Button Grid.Row="2" Grid.Column="1">Calculate</Button>
</Grid>
  • Run the app to see the result
info

For full information about the complete range of Avalonia built-in controls, and their attributes, see the reference section here.

On the next page, you will see how to improve your design-time experience by adjusting the size window when it is shown in the preview pane.