Практическое руководство. Создание значений на основе списка связанных элементов

Возможности класса MultiBinding позволяют связать свойство объекта привязки со списком свойств источника и затем применить логику для получения значения с заданными входными данными. В этом примере демонстрируется использование класса MultiBinding.

Пример

В следующем примере объект NameListData ссылается на коллекцию объектов PersonName, которые содержат свойства firstName и lastName. В следующем примере создается экземпляр класса TextBlock, который используется для отображения имени и фамилии человека (сначала указывается фамилия).

<Window
  xmlns="https://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="https://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:c="clr-namespace:SDKSample"
  x:Class="SDKSample.Window1"
  Width="400"
  Height="280"
  Title="MultiBinding Sample">
    
  <Window.Resources>
    <c:NameList x:Key="NameListData"/>
    <c:NameConverter x:Key="myNameConverter"/>


...


</Window.Resources>


...


<TextBlock Name="textBox2" DataContext="{StaticResource NameListData}">
  <TextBlock.Text>
    <MultiBinding Converter="{StaticResource myNameConverter}"
                  ConverterParameter="FormatLastFirst">
      <Binding Path="FirstName"/>
      <Binding Path="LastName"/>
    </MultiBinding>
  </TextBlock.Text>
</TextBlock>


...


</Window>

Чтобы понять, как получается формат «фамилия-имя», просмотрите реализацию NameConverter:

Public Class NameConverter
    Implements IMultiValueConverter

Public Function Convert1(ByVal values() As Object, _
                         ByVal targetType As System.Type, _
                         ByVal parameter As Object, _
                         ByVal culture As System.Globalization.CultureInfo) As Object _
                         Implements System.Windows.Data.IMultiValueConverter.Convert
    Select Case CStr(parameter)
        Case "FormatLastFirst"
            Return (values(1) & ", " & values(0))
    End Select
    Return (values(0) & " " & values(1))
End Function

Public Function ConvertBack1(ByVal value As Object, _
                             ByVal targetTypes() As System.Type, _
                             ByVal parameter As Object, _
                             ByVal culture As System.Globalization.CultureInfo) As Object() _
                             Implements System.Windows.Data.IMultiValueConverter.ConvertBack
    Return CStr(value).Split(New Char() {" "c})
End Function
End Class
public class NameConverter : IMultiValueConverter
{
    public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
    {
        string name;

        switch ((string)parameter)
        {
            case "FormatLastFirst":
                name = values[1] + ", " + values[0];
                break;
            case "FormatNormal":
            default:
                name = values[0] + " " + values[1];
                break;
        }

        return name;
    }

    public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture)
    {
        string[] splitValues = ((string)value).Split(' ');
        return splitValues;
    }
}

Интерфейс NameConverter реализует интерфейс IMultiValueConverter. NameConverter принимает значения от отдельных привязок и сохраняет их в массиве объектов значений. Порядок, в котором отображаются элементы Binding в элементе MultiBinding, соответствует порядку хранения этих значений в массиве. На значение атрибута ConverterParameter ссылается аргумент параметра метода Converter, который переключается на параметр для определения способа форматирования имени.

См. также

Задачи

Практическое руководство. Преобразование привязанных данных

Основные понятия

Общие сведения о связывании данных

Другие ресурсы

Практические руководства по привязке данных