NumericUpDownPage.xaml 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <UserControl xmlns="https://github.com/avaloniaui"
  2. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  3. xmlns:sys="clr-namespace:System;assembly=netstandard"
  4. x:Class="ControlCatalog.Pages.NumericUpDownPage">
  5. <StackPanel Orientation="Vertical" Spacing="4"
  6. MaxWidth="800">
  7. <TextBlock Margin="2" Classes="h2" TextWrapping="Wrap">Numeric up-down control provides a TextBox with button spinners that allow incrementing and decrementing numeric values by using the spinner buttons, keyboard up/down arrows, or mouse wheel.</TextBlock>
  8. <TextBlock Margin="2,5,2,2" FontSize="14" FontWeight="Bold">Features:</TextBlock>
  9. <WrapPanel Margin="-8,0">
  10. <Grid Grid.Row="0" Grid.Column="0" Margin="8" ColumnDefinitions="Auto, Auto" RowDefinitions="Auto,Auto,Auto,Auto,Auto">
  11. <TextBlock Grid.Row="0" Grid.Column="0" VerticalAlignment="Center" Margin="2">ShowButtonSpinner:</TextBlock>
  12. <CheckBox Grid.Row="0" Grid.Column="1" IsChecked="{Binding #upDown.ShowButtonSpinner}" VerticalAlignment="Center" Margin="2"/>
  13. <TextBlock Grid.Row="1" Grid.Column="0" VerticalAlignment="Center" Margin="2">IsReadOnly:</TextBlock>
  14. <CheckBox Grid.Row="1" Grid.Column="1" IsChecked="{Binding #upDown.IsReadOnly}" VerticalAlignment="Center" Margin="2"/>
  15. <TextBlock Grid.Row="2" Grid.Column="0" VerticalAlignment="Center" Margin="2">AllowSpin:</TextBlock>
  16. <CheckBox Grid.Row="2" Grid.Column="1" IsChecked="{Binding #upDown.AllowSpin}" VerticalAlignment="Center" Margin="2"/>
  17. <TextBlock Grid.Row="3" Grid.Column="0" VerticalAlignment="Center" Margin="2">ClipValueToMinMax:</TextBlock>
  18. <CheckBox Grid.Row="3" Grid.Column="1" IsChecked="{Binding #upDown.ClipValueToMinMax}" VerticalAlignment="Center" Margin="2"/>
  19. </Grid>
  20. <Grid Grid.Row="0" Grid.Column="1" Margin="8" ColumnDefinitions="Auto, 120" RowDefinitions="Auto,Auto,Auto,Auto,Auto">
  21. <TextBlock Grid.Row="0" Grid.Column="0" VerticalAlignment="Center" Margin="2">FormatString:</TextBlock>
  22. <ComboBox Grid.Row="0" Grid.Column="1" Items="{Binding Formats}" SelectedItem="{Binding SelectedFormat}"
  23. VerticalAlignment="Center" Margin="2">
  24. <ComboBox.ItemTemplate>
  25. <DataTemplate>
  26. <StackPanel Orientation="Horizontal" Spacing="2">
  27. <TextBlock Text="{Binding Name}"/>
  28. <TextBlock Text="-"/>
  29. <TextBlock Text="{Binding Value}"/>
  30. </StackPanel>
  31. </DataTemplate>
  32. </ComboBox.ItemTemplate>
  33. </ComboBox>
  34. <TextBlock Grid.Row="1" Grid.Column="0" VerticalAlignment="Center" Margin="2">ButtonSpinnerLocation:</TextBlock>
  35. <ComboBox Grid.Row="1" Grid.Column="1" Items="{Binding SpinnerLocations}" SelectedItem="{Binding #upDown.ButtonSpinnerLocation}"
  36. VerticalAlignment="Center" Margin="2"/>
  37. <TextBlock Grid.Row="2" Grid.Column="0" VerticalAlignment="Center" Margin="2">CultureInfo:</TextBlock>
  38. <ComboBox Grid.Row="2" Grid.Column="1" Items="{Binding Cultures}" SelectedItem="{Binding #upDown.CultureInfo}"
  39. VerticalAlignment="Center" Margin="2"/>
  40. <TextBlock Grid.Row="3" Grid.Column="0" VerticalAlignment="Center" Margin="2">Watermark:</TextBlock>
  41. <TextBox Grid.Row="3" Grid.Column="1" Text="{Binding #upDown.Watermark}" VerticalAlignment="Center" Margin="2" />
  42. <TextBlock Grid.Row="4" Grid.Column="0" VerticalAlignment="Center" Margin="2">Text:</TextBlock>
  43. <TextBox Grid.Row="4" Grid.Column="1" Text="{Binding #upDown.Text}" VerticalAlignment="Center" Margin="2" />
  44. </Grid>
  45. <Grid Grid.Row="0" Grid.Column="2" Margin="8" RowDefinitions="Auto,Auto,Auto,Auto,Auto" ColumnDefinitions="Auto, Auto">
  46. <TextBlock Grid.Row="0" Grid.Column="0" VerticalAlignment="Center" Margin="10,2,2,2">Minimum:</TextBlock>
  47. <NumericUpDown Grid.Row="0" Grid.Column="1" Value="{Binding #upDown.Minimum}"
  48. CultureInfo="{Binding #upDown.CultureInfo}" VerticalAlignment="Center" Margin="2" HorizontalAlignment="Center"/>
  49. <TextBlock Grid.Row="1" Grid.Column="0" VerticalAlignment="Center" Margin="10,2,2,2">Maximum:</TextBlock>
  50. <NumericUpDown Grid.Row="1" Grid.Column="1" Value="{Binding #upDown.Maximum}"
  51. CultureInfo="{Binding #upDown.CultureInfo}" VerticalAlignment="Center" Margin="2" HorizontalAlignment="Center"/>
  52. <TextBlock Grid.Row="2" Grid.Column="0" VerticalAlignment="Center" Margin="10,2,2,2">Increment:</TextBlock>
  53. <NumericUpDown Grid.Row="2" Grid.Column="1" Value="{Binding #upDown.Increment}" VerticalAlignment="Center"
  54. Margin="2" HorizontalAlignment="Center"/>
  55. <TextBlock Grid.Row="3" Grid.Column="0" VerticalAlignment="Center" Margin="10,2,2,2">Value:</TextBlock>
  56. <NumericUpDown Grid.Row="3" Grid.Column="1" Value="{Binding DecimalValue}" VerticalAlignment="Center"
  57. Margin="2" HorizontalAlignment="Center"/>
  58. </Grid>
  59. </WrapPanel>
  60. <WrapPanel Margin="2,10,2,2">
  61. <StackPanel Orientation="Vertical" Margin="10">
  62. <Label Target="upDown" FontSize="14" FontWeight="Bold" VerticalAlignment="Center">Usage of decimal NumericUpDown:</Label>
  63. <NumericUpDown Name="upDown" Minimum="0" Maximum="10" Increment="0.5"
  64. VerticalAlignment="Center" Value="{Binding DecimalValue}"
  65. Watermark="Enter text" FormatString="{Binding SelectedFormat.Value}"/>
  66. </StackPanel>
  67. <StackPanel Orientation="Vertical" Margin="10">
  68. <Label Target="DoubleUpDown" FontSize="14" FontWeight="Bold" VerticalAlignment="Center">Usage of double NumericUpDown:</Label>
  69. <NumericUpDown Name="DoubleUpDown" Minimum="0" Maximum="10" Increment="0.5"
  70. VerticalAlignment="Center" Value="{Binding DoubleValue}"
  71. Watermark="Enter text" FormatString="{Binding SelectedFormat.Value}"/>
  72. </StackPanel>
  73. <StackPanel Orientation="Vertical" Margin="10">
  74. <Label Target="ValidationUpDown" FontSize="14" FontWeight="Bold" VerticalAlignment="Center">NumericUpDown with Validation Errors:</Label>
  75. <NumericUpDown x:Name="ValidationUpDown" Minimum="0" Maximum="10" Increment="0.5"
  76. VerticalAlignment="Center"
  77. Watermark="Enter text" FormatString="{Binding SelectedFormat.Value}">
  78. <DataValidationErrors.Error>
  79. <sys:Exception />
  80. </DataValidationErrors.Error>
  81. </NumericUpDown>
  82. </StackPanel>
  83. </WrapPanel>
  84. </StackPanel>
  85. </UserControl>