검색결과 리스트
MVVM에 해당되는 글 1건
- 2008.09.24 WPF 데이터 바인딩 MSDN 정리한 것
데이터 바인딩의 정의
데이터 바인딩은 응용프로그램 UI와 비지니스 논리를 서로 연결하는 프로세스이다. 바인딩 설정이 올바르고 데이터가 적절한 알림을 제공하는 경우에는 데이터의 값이 변경될때
데이터에 바인딩된 요소에 변경 내용이 자동으로 반영된다.
일반적인 용도는 서버 또는 로컬 구성 데이터를 폼이나 기타 UI 콘트롤에 배치하는 것.
기본 바인딩 개념
바인딩하려는 요소 및 데이터 소스의 특성에 관계 없이 각 바인딩은 항상 다름 그림에 나타나는 모델을 따릅니다.
<이미지 출처 : msdn https://msdn.microsoft.com/en-us/library/hh848246.aspx
소스 업데이트를 트리거하는 항목
TwoWay, OneWayToSource인 바인딩은 대상 속성의 변경 내용을 수신하고 해당 변경 내용을 다시 소스로 전파합니다. 이것을 소스 업데이트라고 한다.
텍스트를 편집하고 있을때나 텍스트 편집을 마치고 마우스를 TextBox 외부로 움직였을때 소스 값이 업데이트 될까요? 소스 업데이트는 바인딩의 UpdateSourceTrigger속성에 따라 결정된다.
UpdateSourceTrugger 값이 PropertyChanged이면 대상 속성이 변경되는 즉시 업데이트가 일어나고 LostFocus 이면 대상 속성이 포커스를 잃었을때에만 해당 값이 업데이트 된다.
바인딩 만들기
바인딩 소스 지정 - 여러 속성을 같은 소스에 바인딩할때 부모요소에 DataContext속성을 사용하는 방법이 유용하다. 개별적인 경우 DataContext 대신 Source속성을 이용할수도 있다.
값에 대한 경로 지정 - 바인딩 소스가 개체일때는 Path속성을 사용하여 바인딩에 사용할 값을 지정합니다.
데이터 변환
[ValueConversion(typeof(Color), typeof(SolidColorBrush))]
public class ColorBrushConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
Color color = (Color)value;
return new SolidColorBrush(color);
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return null;
}
}
바인딩하는 형식에 있는 형식 변환기때문에 기본변환을 사용할수 있다. 형식변환기를 직접 구현하는 경우는
컬렉션에 바인딩.
바인딩 소스 개체는 속성에서 데이터를 포함하는 단일 개체 또는 함께 그룹화되는 경우가 많은 다형성 개체의 데이터 컬렉션으로 취급될수 있다.
컬렉션 구현방법
IEnumberable 인터페이스를 구현하는 모든 컬렉션을 열거할수 있다. 그러나 컬렉션에 삽입이나 삭제를 수행할때 UI가 자동으로 업데이트되도록 동적 바인딩을 설정하려면
컬렉션에서 INotifyCollectionChanged 인터페이스를 구현해야 한다. 이 인터페이스는 내부컬렉션이 변경될때마다 발생해야 하는 이벤트를 노출한다.
WPF에서는 INotifyCollectionChanged 인터페이스를 노출하는 데이터 컬렉션에 대한 기본 제공 구현인 ObservableCollection(T) 클래스를 제공한다.
컬렉션뷰의 정의
컬렉셔뷰는 기본 소스 컬렉션 자체를 조작할 필요없이 필터, 정렬, 그룹화 쿼리를 기반으로 소스 콜력션을 탐색하고 표시하는 사용할수 있는 바인딩 소스 콜렉션의 최상위 계층으로 간주할수 있다.INOtifyCOllectionChanged 페이스가 소스 콜렉션에서 구현될 경우 CollectionChanged이벤트에서 발생되는 변경내용은 뷰로 전파됩니다.
뷰는 기본 소스 컬렉션을 변경하지 않으므로 각 소스 컬렉션에 여러개의 뷰를 연결하여 사용할수 있다.
뷰 사용법 중에 하나는 뷰 개체를 직접 인스턴스화한 다음 이를 바인딩 소 스로 사용하는 방법이다.
정렬
ex.
private void AddSorting(object sender, RoutedEventArgs args)
{
listingDataView.SortDescriptions.Add(
new SortDescription("Category", ListSortDirection.Ascending));
listingDataView.SortDescriptions.Add(
new SortDescription("StartDate", ListSortDirection.Ascending));
}
필터
ex.
listingDataView.Filter += new FilterEventHandler(ShowOnlyBargainsFilter);
private void ShowOnlyBargainsFilter(object sender, FilterEventArgs e)
{
AuctionItem product = e.Item as AuctionItem;
if (product != null)
{
// Filter out products with price 25 or above
if (product.CurrentPrice < 25)
{
e.Accepted = true;
}
else
{
e.Accepted = false;
}
}
}
그룹화 - 뷰에서 그룹화 기능을 지원하므로 사용자는 컬렉션 뷰의 컬렉션을 놀리 그룹으로 분할할수 있다. 사용자가 그룹 목록을 제공할 경우 그룹은 명시적이며 그룹이 데이터에 따라 동적으로 생성될 경우 그룹은 암시적이다.
ex.// This groups the items in the view by the property "Category"
PropertyGroupDescription groupDescription = new PropertyGroupDescription();
groupDescription.PropertyName = "Category";
listingDataView.GroupDescriptions.Add(groupDescription);
현재 레코드 포인터
컬렉션 뷰에서 개체를 탐색할수 있다. 탐색할때 레코드 포인터를 이동하여 컬렉션의 특정 위치에 있는 개체를 검색할수 있다.
현재 레코드 포인터 이동은 컬렉션에 적용되는 정렬 똔느 필터링과 몇 가지 상호 작용을 한다. 정렬이 적용되는 경우에는 선택한 마지막 레코드에 현재 레코드 포인터가 유지되지만
해당 레코드 주위에서 컬력센 뷰가 재구성됩니다.
마스터-세부 바인딩 시나리오
데이터 템플릿
ex.
<DataTemplate DataType="{x:Type src:AuctionItem}">
<Border BorderThickness="1" BorderBrush="Gray"
Padding="7" Name="border" Margin="3" Width="500">
<Grid>
<Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition/>
<RowDefinition/>
<RowDefinition/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="20"/>
<ColumnDefinition Width="86"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<Polygon Grid.Row="0" Grid.Column="0" Grid.RowSpan="4"
Fill="Yellow" Stroke="Black" StrokeThickness="1"
StrokeLineJoin="Round" Width="20" Height="20"
Stretch="Fill"
Points="9,2 11,7 17,7 12,10 14,15 9,12 4,15 6,10 1,7 7,7"
Visibility="Hidden" Name="star"/>
<TextBlock Grid.Row="0" Grid.Column="1" Margin="0,0,8,0"
Name="descriptionTitle"
Style="{StaticResource smallTitleStyle}">Description:</TextBlock>
<TextBlock Name="DescriptionDTDataType" Grid.Row="0" Grid.Column="2"
Text="{Binding Path=Description}"
Style="{StaticResource textStyleTextBlock}"/>
<TextBlock Grid.Row="1" Grid.Column="1" Margin="0,0,8,0"
Name="currentPriceTitle"
Style="{StaticResource smallTitleStyle}">Current Price:</TextBlock>
<StackPanel Grid.Row="1" Grid.Column="2" Orientation="Horizontal">
<TextBlock Text="$" Style="{StaticResource textStyleTextBlock}"/>
<TextBlock Name="CurrentPriceDTDataType"
Text="{Binding Path=CurrentPrice}"
Style="{StaticResource textStyleTextBlock}"/>
</StackPanel>
</Grid>
</Border>
<DataTemplate.Triggers>
<DataTrigger Binding="{Binding Path=SpecialFeatures}">
<DataTrigger.Value>
<src:SpecialFeatures>Color</src:SpecialFeatures>
</DataTrigger.Value>
<DataTrigger.Setters>
<Setter Property="BorderBrush" Value="DodgerBlue" TargetName="border" />
<Setter Property="Foreground" Value="Navy" TargetName="descriptionTitle" />
<Setter Property="Foreground" Value="Navy" TargetName="currentPriceTitle" />
<Setter Property="BorderThickness" Value="3" TargetName="border" />
<Setter Property="Padding" Value="5" TargetName="border" />
</DataTrigger.Setters>
</DataTrigger>
<DataTrigger Binding="{Binding Path=SpecialFeatures}">
<DataTrigger.Value>
<src:SpecialFeatures>Highlight</src:SpecialFeatures>
</DataTrigger.Value>
<Setter Property="BorderBrush" Value="Orange" TargetName="border" />
<Setter Property="Foreground" Value="Navy" TargetName="descriptionTitle" />
<Setter Property="Foreground" Value="Navy" TargetName="currentPriceTitle" />
<Setter Property="Visibility" Value="Visible" TargetName="star" />
<Setter Property="BorderThickness" Value="3" TargetName="border" />
<Setter Property="Padding" Value="5" TargetName="border" />
</DataTrigger>
</DataTemplate.Triggers>
</DataTemplate>
데이터 템플릿을 사용하면 데이터를 컨트롤에 넣을수 있을뿐 아니라 데이터를 시각적으로 뛰어나게 표현할수 있다.
데이터 유효성 검사
사용자 입력을 받는 대부분의 응용프로그램은 사용자가 올바른 정보를 입력했는지 확인하기 위한 유효성 검사 논리가 필요하다 유효성 검사는 형식, 범위, 서식 또는 기타 응용프로그램별
요규사항을 기반으로 할수 있다.
ex 유효성 검사 규칙을 바인딩과 연결
<TextBox Name="StartPriceEntryForm" Grid.Row="2" Grid.Column="1"
Style="{StaticResource textStyleTextBox}" Margin="8,5,0,5">
<TextBox.Text>
<Binding Path="StartPrice" UpdateSourceTrigger="PropertyChanged">
<Binding.ValidationRules>
<ExceptionValidationRule />
</Binding.ValidationRules>
</Binding>
</TextBox.Text>
</TextBox>
WPF 데이터 바인딩 모델을 사용하면 ValidationRules를 Binding 객체와 연결할수 있다.
시각적 피드백 제공
ex.
<ControlTemplate x:Key="validationTemplate">
<DockPanel>
<TextBlock Foreground="Red" FontSize="20">!</TextBlock>
<AdornedElementPlaceholder/>
</DockPanel>
</ControlTemplate>
유효성 검사 프로세스
UpdateSourceExceptionFilter 콜백을 사용하여 예외 처리를 위한 사용자 지정 처리기를 제공할수 있다. Binding에서 UpdateSourceExceptionFilter가 지정되지 않은 경우 바인딩 엔진은 예외가 있는 ValidationError를 만들어 바인딩된 요소의 Validation.Errors컬렉션에 추가합니다.
이 글은 스프링노트에서 작성되었습니다.
RECENT COMMENT