Практическое руководство. Создание привязки к методу
В следующем примере показывается способ создания привязки к методу с помощью ObjectDataProvider.
Пример
В этом примере TemperatureScale является классом, имеющим метод ConvertTemp, который принимает два параметра (один double, а другой enum типа TempType) и преобразует данное значение из одной шкалы температуры в другую. В следующем примере ObjectDataProvider используется для создания экземпляра объекта TemperatureScale. Метод ConvertTemp вызывается с двумя заданными параметрами.
<Window.Resources>
<ObjectDataProvider ObjectType="{x:Type local:TemperatureScale}"
MethodName="ConvertTemp" x:Key="convertTemp">
<ObjectDataProvider.MethodParameters>
<system:Double>0</system:Double>
<local:TempType>Celsius</local:TempType>
</ObjectDataProvider.MethodParameters>
</ObjectDataProvider>
<local:DoubleToString x:Key="doubleToString" />
</Window.Resources>
Теперь метод доступен в качестве ресурса и можно привязаться к его результатам. В следующем примере свойства Text TextBox и SelectedValue ComboBox связаны с двумя параметрами метода. Это дает пользователям возможность указывать температуру для преобразования и шкалу температуры для преобразования. Обратите внимание, что BindsDirectlyToSource присвоено значение true, так как выполняется привязка свойства MethodParameters экземпляра ObjectDataProvider, а не свойства в объекта, перезаписанного ObjectDataProvider (объект TemperatureScale).
Content из последнего Label обновляется, когда пользователь изменяет содержимое TextBox или осуществляет выбор из ComboBox.
<Label Grid.Row="1" HorizontalAlignment="Right">Enter the degree to convert:</Label>
<TextBox Grid.Row="1" Grid.Column="1" Name="tb">
<TextBox.Text>
<Binding Source="{StaticResource convertTemp}" Path="MethodParameters[0]"
BindsDirectlyToSource="true" UpdateSourceTrigger="PropertyChanged"
Converter="{StaticResource doubleToString}">
<Binding.ValidationRules>
<local:InvalidCharacterRule/>
</Binding.ValidationRules>
</Binding>
</TextBox.Text>
</TextBox>
<ComboBox Grid.Row="1" Grid.Column="2"
SelectedValue="{Binding Source={StaticResource convertTemp},
Path=MethodParameters[1], BindsDirectlyToSource=true}">
<local:TempType>Celsius</local:TempType>
<local:TempType>Fahrenheit</local:TempType>
</ComboBox>
<Label Grid.Row="2" HorizontalAlignment="Right">Result:</Label>
<Label Content="{Binding Source={StaticResource convertTemp}}"
Grid.Row="2" Grid.Column="1" Grid.ColumnSpan="2"/>
Преобразователь DoubleToString принимает значение типа Double и преобразует его в строку в соответствие с Convert (от источника привязки к цели привязки, которая является свойством Text) и преобразует string в double в соответствии с ConvertBack.
InvalidationCharacterRule является ValidationRule, которое проверяет наличие недопустимых знаков. Шаблон ошибки по умолчанию в виде красной границы вокруг TextBox появляется для уведомления пользователей, если вводимое значение не является значением типа Double.
См. также
Задачи
Практическое руководство. Привязка к перечислению