다음을 통해 공유


x:Bind with Windows App SDK의 함수

참고

{x:Bind}을(를) 사용하여 앱에서 데이터 바인딩을 사용하는 방법에 대한 일반적인 정보(와 {x:Bind}{Binding} 간의 전체 비교)는 심층적인 데이터 바인딩{x:Bind} 태그 확장을 참조하세요.

Windows 앱 SDK 앱에서 {x:Bind}는 바인딩 경로의 리프 단계로 함수 사용을 지원합니다. 그러면 다음을 활성화할 수 있습니다.

  • 간단한 값 변환 방법
  • 둘 이상의 매개 변수를 사용하는 바인딩 방식

다음 예제에서는 항목의 백그라운드와 포그라운드가 색 매개 변수에 따라 변환을 수행하는 함수에 바인딩됩니다.

<DataTemplate x:DataType="local:ColorEntry">
    <Grid Background="{x:Bind local:ColorEntry.Brushify(Color), Mode=OneWay}" Width="240">
        <TextBlock Text="{x:Bind ColorName}" Foreground="{x:Bind TextColor(Color)}" Margin="10,5" />
    </Grid>
</DataTemplate>
public class ColorEntry
{
    public string ColorName { get; set; }
    public Color Color { get; set; }

    public static SolidColorBrush Brushify(Color c)
    {
        return new SolidColorBrush(c);
    }

    public SolidColorBrush TextColor(Color c)
    {
        return new SolidColorBrush(((c.R * 0.299 + c.G * 0.587 + c.B * 0.114) > 150) ? Colors.Black : Colors.White);
    }
}

XAML 특성 사용

<object property="{x:Bind pathToFunction.FunctionName(functionParameter1, functionParameter2, ...), bindingProperties}" ... />

함수 경로

함수 경로는 다른 속성 경로처럼 지정되며 (.), 인덱서 또는 함수를 찾을 캐스트를 포함할 수 있습니다.

정적 함수는 XMLNamespace:ClassName.MethodName 구문을 사용하여 지정할 수 있습니다. 예를 들어, 다음 구문을 사용하여 코드 숨김에서 정적 함수에 바인딩합니다.

<Window 
     xmlns:local="using:MyNamespace">
     ...
    <StackPanel>
        <TextBlock x:Name="BigTextBlock" FontSize="20" Text="Big text" />
        <TextBlock FontSize="{x:Bind local:MyHelpers.Half(BigTextBlock.FontSize)}" 
                   Text="Small text" />
    </StackPanel>
</Window>
namespace MyNamespace
{
    static public class MyHelpers
    {
        public static double Half(double value) => value / 2.0;
    }
}

태그에서 직접 시스템 함수를 사용하여 날짜 형식 지정, 텍스트 서식 지정, 텍스트 연결과 같은 간단한 시나리오를 수행할 수도 있습니다. 예를 들면 다음과 같습니다.

<Window 
     xmlns:sys="using:System"
     xmlns:local="using:MyNamespace">
     ...
     <CalendarDatePicker Date="{x:Bind sys:DateTime.Parse(TextBlock1.Text)}" />
     <TextBlock Text="{x:Bind sys:String.Format('{0} is now available in {1}', local:MyPage.personName, local:MyPage.location)}" />
</Window>

모드가 OneWay/TwoWay인 경우 함수 경로에 수행된 변경 검색이 포함되고 이러한 개체가 변경된 경우 바인딩이 다시 평가됩니다.

바인딩할 함수는 다음을 수행해야 합니다.

  • 코드 및 메타데이터에 액세스할 수 있어야 합니다. 그러므로 internal/private은 C#에서 작업하지만 C++에는 public WinRT 메서드가 필요합니다.
  • 오버로드는 형식이 아닌 인수 개수를 기반으로 하며 해당 개수의 인수를 사용하는 첫 번째 오버로드와 일치시키려고 합니다.
  • 인수 형식은 전달 중인 데이터와 일치해야 합니다. 변환은 축소하지 않습니다.
  • 함수의 반환 형식은 바인딩을 사용 중인 속성의 형식과 일치해야 합니다.

바인딩 엔진은 함수 이름을 사용하여 실행된 속성 변경 알림에 반응하고 필요에 따라 바인딩을 다시 평가합니다. 예:

<DataTemplate x:DataType="local:Person">
   <StackPanel>
      <TextBlock Text="{x:Bind FullName}" />
      <Image Source="{x:Bind IconToBitmap(Icon, CancellationToken), Mode=OneWay}" />
   </StackPanel>
</DataTemplate>
public class Person : INotifyPropertyChanged
{
    //Implementation for an Icon property and a CancellationToken property with PropertyChanged notifications
    ...

    //IconToBitmap function is essentially a multi binding converter between several options.
    public Uri IconToBitmap (Uri icon, Uri cancellationToken)
    {
        var foo = new Uri(...);        
        if (isCancelled)
        {
            foo = cancellationToken;
        }
        else 
        {
            if (fullName.Contains("Sr"))
            {
               //pass a different Uri back
               foo = new Uri(...);
            }
            else
            {
                foo = icon;
            }
        }
        return foo;
    }

    //Ensure FullName property handles change notification on itself as well as IconToBitmap since the function uses it
    public string FullName
    {
        get { return fullName; }
        set
        {
            fullName = value;
            OnPropertyChanged();
            OnPropertyChanged("IconToBitmap"); 
            //this ensures Image.Source binding re-evaluates when FullName changes in addition to Icon and CancellationToken
        }
    }
}

x:Bind에서 함수를 사용하여 WPF에서 변환기 및 MultiBinding을 통해 지원되는 것과 동일한 시나리오를 구현할 수 있습니다.

함수 인수

함수 인수를 여러 개 지정할 경우 쉼표(,)를 사용하여 구분합니다.

  • 바인딩 경로 – 해당 개체에 직접 바인딩할 때와 동일한 구문입니다.
    • 모드가 OneWay/TwoWay인 경우 변경 검색이 수행되고 개체가 변경될 때 바인딩이 다시 평가됩니다.
  • 따옴표로 묶인 상수 문자열 – 문자열로 지정하려면 따옴표가 필요합니다. 문자열에서 따옴표를 이스케이프할 때는 캐럿(^)을 사용합니다.
  • 상수 - 예: 123.456
  • 부울 – 'x:True' 또는 'x:False'로 지정합니다.

양방향 함수 바인딩

양방향 바인딩 시나리오에서는 두 번째 함수를 바인딩의 반대 방향으로 지정해야 합니다. 이는 BindBack 바인딩 속성을 사용하여 수행됩니다. 아래 예제에서 함수는 모델로 다시 푸시해야 하는 값을 하나의 인수로 사용합니다.

<TextBlock Text="{x:Bind a.MyFunc(b), BindBack=a.MyFunc2, Mode=TwoWay}" />

참고 항목