Value Converters
The ActiproSoftware.UI.Avalonia.Controls.Converters namespace contains numerous value converters that can be used in XAML for working with data.
BorderChildClipConverter
The BorderChildClipConverter is a multi-value converter that can be applied to a Border.Child element's Clip property to ensure the child element is properly clipped based on the Border.CornerRadius value.
This converter is useful when the Border.Child element or another element within its hierarchy has a background that renders into the portion of the parent Border that is normally rounded off by the corner radius.

A side-by-side example of a child with and without clipping to the containing border
To use this converter, simply set the BorderChildClipConverter.ClipToContainingBorderattached property to true for any control within a Border. The attached property automatically configures the control's Clip property to bind to the appropriate values using the converter.
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<Border BorderBrush="Black" BorderThickness="1" CornerRadius="8">
	<Grid actipro:BorderChildClipConverter.ClipToContainingBorder="True">
		<!-- Grid child controls here -->
	</Grid>
</Border>
ColorOpacityConverter
The ColorOpacityConverter represents a value convert that can alter the opacity of a color.
| Specification | Details | 
|---|---|
| Original value | A UIColor, Color,HslColor,HsvColor, or anyObjectwhose string representation can be parsed as a UIColor. | 
| Converted result | The original value but with an alpha channel defined by the desired opacity. | 
| Parameter | A Doubleor anyObjectthat can be converted to aDouble.  The value represents a percentage of opacity from0.0to1.0. | 
| Target type | Defines the Typeof the converted result.  When the target type isObject, the converted result will match theTypeof the original value. Otherwise, an attempt will be made to convert the result to the desiredType. | 
| Culture | Not used. | 
| Can convert back | No. | 
ComparisonConverter
The ComparisonConverter represents a value converter that applies comparison logic on the value being converted and can return a different converted value based on the result of the comparison.
| Specification | Details | 
|---|---|
| Original value | An Objectthat will be compared to another value (based on theOperator) to determine the converted result. | 
| Converted result | An Objectdefined by TrueResult if the comparison evaluates totrue, or FalseResult if the comparison evaluates tofalse. | 
| Parameter | An Objectthat is compared with the original value. This value is ignored when the Operator isDefaultOrEmptyorNotDefaultOrEmpty. | 
| Target type | Not used. | 
| Culture | Not used. | 
| Can convert back | No. | 
The following instance properties are available for the converter:
| Property | Description | 
|---|---|
| FalseResult | The value of the converted result when the comparison evaluates to false. The default value isfalse(Boolean). | 
| Operator | The ComparisonConverterOperator used to compare values. The default value is NotDefaultOrEmpty. | 
| TrueResult | The value of the converted result when the comparison evaluates to true. The default value is booleantrue(Boolean). | 
The following example demonstrates how to use the converter with a non-default operator:
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<UserControl.Resources>
	<actipro:ComparisonConverter x:Key="EqualToComparisonConverter" Operator="EqualTo" />
</UserControl.Resources>
...
<!--
Show the 'Clear' button of a TextBox when 'Allow Clear' is selected from a ComboBox
by using a binding which reads as "ComboBox.SelectedItem EqualTo 'Allow Clear'".
-->
<TextBox ...
	Classes.has-clear-button="{Binding #optionsComboBox.SelectedItem, Converter={StaticResource EqualToComparisonConverter}, ConverterParameter='Allow Clear'}"
	/>
IconControlConverter
The IconControlConverter value converter can create a Control for a bound value that represents image data.  This is useful when data-binding a MenuItem control's Icon property to an image value like IImage, and the MenuItem.Icon must be a control.
The following example demonstrates how to use the converter when binding to a view model's ImageSource property (which is assumed to be a value of type IImage):
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<UserControl.Resources>
	<actipro:IconControlConverter x:Key="IconControlConverter" />
</UserControl.Resources>
...
<MenuItem Icon="{Binding ImageSource, Converter={StaticResource IconControlConverter}}" ... />
By default, the IconControlConverter creates a ContentControl whose template is configured to use an IconPresenter for displaying the bound value.  The IconPresenter.DefaultContentTemplate determines which IDataTemplate will be used for the bound value.
See the Icon Presenter topic for additional details.
ImageKeyToImageSourceConverter
The ImageKeyToImageSourceConverter represents a value converter that uses an ImageProvider to lookup an IImage associated with a specified key.
| Specification | Details | 
|---|---|
| Original value | A Stringkey that identifies the image. Non-Stringvalues are automatically converted usingObject.ToString(). The key value must be recognized by ImageProvider.GetImageSource.  Built-in keys are defined by SharedImageSourceKeys. | 
| Converted result | An IImageornullif the key is not found. | 
| Parameter | An ImageProvider instance or nullto use ImageProvider.Default. | 
| Target type | Not used. | 
| Culture | Not used. | 
| Can convert back | No. | 
The following example demonstrates how to use the converter with the key constants defined by the SharedImageSourceKeys class:
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<UserControl.Resources>
	<actipro:ImageKeyToImageSourceConverter x:Key="ImageKeyToImageSourceConverter" />
</UserControl.Resources>
...
<SampleControl Image="{Binding Source={x:Static actipro:SharedImageSourceKeys.Warning}, Converter={StaticResource ImageKeyToImageSourceConverter}}" ... />
MathConverter
The MathConverter represents a single or multi-value converter that can perform basic mathematic calculations.
| Specification | Details | 
|---|---|
| Original value 0 | A DoubleorStringvalue to be parsed as aDouble. This value corresponds toxorp0in the expression. | 
| Original value 1 | (Optional) A DoubleorStringvalue to be parsed as aDouble. This value corresponds toyorp1in the expression. | 
| Original value 2 | (Optional) A DoubleorStringvalue to be parsed as aDouble. This value corresponds tozorp2in the expression. | 
| Original value 3 | (Optional) A DoubleorStringvalue to be parsed as aDouble. This value corresponds top3in the expression. | 
| Original value N | (Optional) A DoubleorStringvalue to be parsed as aDouble. This value corresponds topNin the expression where N is the zero-based index of the value passed to the converter. | 
| Converted result | The Stringreturned by callingToLowerInvariant()on the original value. | 
| Parameter | A Stringthat defines the mathematical expression, e.g.,"x + 2".  See Mathematical Expressions details below. | 
| Target type | Used to define the converted result. Doubleparses the result as aDouble.Int64,Int32, andInt16will round theDouble-based result to the nearest whole number.Stringwill convert the result usingObject.ToString(). Other target types are not used and will return the result as a nullableObject. | 
| Culture | Ignored. InvariantCultureis always used. | 
| Can convert back | No. | 
Important
All numeric values in an expression are parsed using InvariantCulture where comma (,) is the thousands separator, and decimal point (.) is the decimal separator.
Mathematical Expressions
A mathematical expression uses variables to represent the values passed to the converter.  The variables "x", "y", and "z" represent the first, second, and third values, respectively. Alternatively, values can be referenced by their position where "p0", "p1", and "p2" also represent the first, second, and third values but can also use "p3", "p4", and so on for additional values beyond the first three.
The following binary operators are supported:
| Operator | Description | 
|---|---|
| + | Addition | 
| - | Subtraction | 
| * | Multiplication | 
| / | Division | 
Standard order of operation and parenthetical grouping are supported reading from left-to-right. Parentheses are evaluated first, then multiplication & division, and finally addition & subtraction.
The following functions are available to perform operations upon one or more values:
| Function | Description | 
|---|---|
| max(value1, value2) | Returns the larger of two numbers. | 
| min(value1, value2) | Returns the smaller of two numbers. | 
| round(value) | Returns the value rounded to the nearest whole number. | 
The following example demonstrates using a MathConverter to calculate the perimeter of a rectangle using the formula perimeter = 2 * (width + height):
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<UserControl.Resources>
	<actipro:MathConverter x:Key="MathConverter" />
</UserControl.Resources>
...
<TextBox IsReadOnly="True">
	<TextBox.Text>
		<MultiBinding
			Converter="{StaticResource MathConverter}"
			ConverterParameter="2 * (x + y)">
			<!-- X Value (Width) -->
			<Binding Path="WidthValue" />
			<!-- Y Value (Height) -->
			<Binding Path="HeightValue" />
		</MultiBinding>
	</TextBox.Text>
</TextBox>
StringConverters
The static StringConverters class defines the following converters and, since they are static properties, can be consumed without first defining an instance as a resource:
ToLowerInvariant
The StringConverters.ToLowerInvariant property represents a value converter that can be used to change the character casing of a string to lowercase.
| Specification | Details | 
|---|---|
| Original value | A Stringvalue. Non-Stringvalues are automatically converted usingObject.ToString(). | 
| Converted result | The Stringreturned by callingToLowerInvariant()on the original value. | 
| Parameter | Not used. | 
| Target type | Not used. | 
| Culture | Not used. | 
| Can convert back | No. | 
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<TextBox Text="{Binding Path=OriginalValue, Converter={x:Static actipro:StringConverters.ToLowerInvariant}, Mode=OneWay}" />
ToPercent
The StringConverters.ToPercent property represents a value converter that converts between a number and a formatted percentage.  The percentage is simply the number multiplied by 100 with a percent indicator.
| Specification | Details | 
|---|---|
| Original value | A Double,Single, orInt32. Other types will attempt to parse theirObject.ToString()value as aDouble. | 
| Converted result | The original numeric value multiplied by 100with a percent indicator.  For example, the value0.25will convert to"25%". | 
| Parameter | Not used. | 
| Target type | Not used. | 
| Culture | Ignored. CurrentCultureis always used. | 
| Can convert back | No. | 
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<TextBox Text="{Binding Path=OriginalValue, Converter={x:Static actipro:StringConverters.ToPercent}, Mode=OneWay}" />
ToUpperInvariant
The StringConverters.ToUpperInvariant property represents a value converter that can be used to change the character casing of a string to uppercase.
| Specification | Details | 
|---|---|
| Original value | A Stringvalue. Non-Stringvalues are automatically converted usingObject.ToString(). | 
| Converted result | The Stringreturned by callingToUpperInvariant()on the original value. | 
| Parameter | Not used. | 
| Target type | Not used. | 
| Culture | Not used. | 
| Can convert back | No. | 
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<TextBox Text="{Binding Path=OriginalValue, Converter={x:Static actipro:StringConverters.ToUpperInvariant}, Mode=OneWay}" />
ThicknessConverter
The ThicknessConverter represents a value converter that converts numeric or Thickness values into a new Thickness, optionally filtering which sides of the Thickness are converted.
| Specification | Details | 
|---|---|
| Original value | A ThicknessorDouble. Other types will attempt to parse theirObject.ToString()value as aDouble.Thicknessvalues will be applied to the corresponding sides of the converted result.Doublevalues will be applied uniformly to all sides of the converted result. | 
| Converted result | A Thickness.  The Filter property determines which sides are populated. The BaseThickness property determines the default value for sides excluded by the filter. | 
| Parameter | Not used. | 
| Target type | Not used. | 
| Culture | Not used. | 
| Can convert back | No. | 
The following instance properties are available for the converter:
| Property | Description | 
|---|---|
| BaseThickness | A Thicknessthat defines the value to use for the converted result for anySidesexcluded by the Filter. | 
| Filter | The Sidesto include in the converted result.  By default, all sides are populated from the original value. | 
The following examples show how to use the converter:
xmlns:actipro="http://schemas.actiprosoftware.com/avaloniaui"
...
<UserControl.Resources>
	<actipro:ThicknessConverter x:Key="AllSidesThicknessConverter" />
	<actipro:ThicknessConverter x:Key="LeftTopSidesThicknessConverter" Filter="Left, Top" BaseThickness="0,0,5,5" />
</UserControl.Resources>
...
<!-- Set all four sides -->
<SampleControl Margin="{Binding Path=OriginalValue, Converter={StaticResource AllSidesThicknessConverter}}" ... />
<!-- Only set the Left and Top sides, Right and Bottom will use BaseThickness -->
<SampleControl Margin="{Binding Path=OriginalValue, Converter={StaticResource LeftTopSidesThicknessConverter}}" ... />
WindowIconConverter
The WindowIconConverter value converter can create a WindowIcon for a bound value that represents image data.  This is useful when data-binding a Window.Icon property to non-Bitmap values.
An IDataTemplate for the icon can be passed as the converter parameter.  Otherwise, the converter will use the IconPresenter.DefaultContentTemplate to determine the IDataTemplate.  The control generated by the IDataTemplate will be rendered to a Bitmap that is used to create the WindowIcon.
See the Icon Presenter topic for additional details.