Silverlight 2 프로젝트에서 컨트롤의 스킨 만들기
정적 리소스를 사용하여 컨트롤에 적용되는 템플릿을 정의하는 방식으로 Microsoft Silverlight 2에서 시스템 컨트롤 모양을 사용자 지정할 수 있습니다. 예를 들어 사각형 대신 이미지를 사용하여 단추의 모양을 구성한 단추 템플릿을 만들 수 있습니다.
여러 컨트롤 템플릿 간에 또는 여러 사용자 정의 컨트롤 간에 공통된 모양을 만들려면 개별 속성을 정적 리소스로 변환한 다음 템플릿 및 사용자 정의 컨트롤에 적용할 수 있습니다. 예를 들어 단추 템플릿의 테두리 색을 리소스로 변환한 다음 해당 색 리소스를 확인란(CheckBox) 템플릿 또는 사용자 정의 컨트롤의 테두리 속성에 적용할 수 있습니다.
템플릿과 리소스를 다른 프로젝트에 다시 사용하려면 리소스를 App.xaml 파일로 이동한 다음 다른 프로젝트의 App.xaml 파일에 붙여 넣을 수 있습니다. 리소스를 App.xaml 파일로 이동하면 해당 파일은 응용 프로그램 스킨의 리포지토리가 됩니다.
컨트롤의 템플릿 만들기
컨트롤의 템플릿을 사용자 지정하려면 다양한 상태의 시스템 컨트롤 모양 수정 및 시스템 컨트롤의 상태 변경 간 전환 시간 수정에서 설명하는 절차를 사용할 수 있습니다.
템플릿은 리소스 패널에 나열되는 리소스가 됩니다. 리소스를 만든 후 수정하는 방법에 대한 자세한 내용은 리소스 수정을 참조하십시오.
사용자 정의 컨트롤 만들기
- 처음부터 새로 디자인할 수 있는 사용자 정의 컨트롤을 만들려면 Silverlight 2 프로젝트에서 새 사용자 정의 컨트롤 만들기에서 설명하는 절차를 사용할 수 있습니다.
속성을 정적 리소스로 변환
아트보드에서 다른 컨트롤에 다시 사용할 속성 값이 있는 개체를 선택합니다.
속성 패널의 속성 보기에서 다시 사용할 속성을 찾습니다.
팁: 속성 패널의 검색 텍스트 상자를 사용하여 속성 이름에 있는 문자를 기준으로 속성을 빠르게 찾을 수 있습니다.
입력한 텍스트에 따라 속성 목록이 필터링됩니다.
속성 패널을 복원하려면 검색 텍스트 상자 옆의 지우기 단추를 클릭하십시오.
다음 작업 중 하나를 수행합니다.
브러시를 다시 사용하려면 브러시를 선택한 다음 브러시를 리소스로 변환 단추를 클릭합니다.
브러시에 적용되는 색을 다시 사용하려면 단색 브러시 인 경우에는 브러시를, 그라데이션 브러시 인 경우에는 다시 사용할 색의 그라데이션 중지점 을 선택합니다. 그런 다음 색을 리소스로 변환 단추를 클릭합니다.
숫자 또는 기타 값 형식을 다시 사용하려면 속성 옆의 고급 속성 옵션 단추를 클릭한 다음 새 리소스로 변환을 클릭합니다.
<type> 리소스 만들기 대화 상자가 나타나면 의미 있는 리소스 이름을 입력한 다음 확인을 클릭합니다.
리소스가 만들어져 리소스 패널에 나열됩니다.
리소스를 만든 후 수정하는 방법에 대한 자세한 내용은 리소스 수정을 참조하십시오.
리소스를 다른 리소스에 적용
여러 가지 방식으로 리소스를 속성에 적용할 수 있습니다.
리소스 패널에서 끌어 놓아 리소스 적용
리소스 패널에 있는 리소스를 아트보드의 컨트롤에 끌어 놓습니다.
글꼴 패밀리 리소스를 확인란(CheckBox) 컨트롤에 끌어 놓기
드롭다운 메뉴가 나타나면 리소스를 적용할 컨트롤 속성을 선택합니다.
글꼴 패밀리 리소스를 CheckBox의 FontFamily 속성에 적용
고급 속성 옵션 메뉴를 사용하여 리소스 적용
속성 패널의 속성 보기에서 리소스로 설정할 속성을 찾습니다.
고급 속성 옵션 단추를 클릭하고 로컬 리소스를 가리킨 다음 드롭다운 목록이 나타나면 리소스 이름을 선택합니다.
브러시 리소스 적용
속성 패널의 속성 보기에서 리소스로 설정할 브러시를 선택합니다.
브러시 리소스 탭에서 리소스 이름을 선택합니다.
색 리소스 적용
속성 패널의 속성 보기에서 리소스로 설정할 색이 있는 브러시를 선택합니다. 그라데이션 브러시 인 경우에는 색의 그라데이션 중지점 을 선택합니다.
색 리소스 탭에서 리소스 이름을 선택합니다.
템플릿을 동일한 형식의 다른 컨트롤에 적용
여러 가지 방식으로 템플릿을 컨트롤에 적용할 수 있습니다.
자산 라이브러리에서 선택하고 새 컨트롤을 그려 템플릿 적용
도구 상자에서 자산 라이브러리 를 엽니다.
자산 라이브러리의 로컬 스타일 탭에서 직접 만든 템플릿을 선택합니다.
아트보드에서 마우스 포인터를 사용하여 경계 상자를 그립니다.
선택한 템플릿과 일치하는 컨트롤이 새로 그려지고 템플릿이 자동으로 적용됩니다.
리소스 패널에서 끌어 놓아 템플릿 적용
리소스 패널에 있는 템플릿 리소스를 아트보드의 컨트롤에 끌어 놓습니다.
드롭다운 메뉴가 나타나면 Style 속성을 선택합니다.
고급 속성 옵션 메뉴를 사용하여 템플릿 적용
템플릿을 적용할 개체를 선택합니다.
속성 패널의 속성 보기에서 Style 속성을 찾습니다.
Style 속성 옆의 고급 속성 옵션 단추를 클릭하고 로컬 리소스를 가리킨 다음 드롭다운 목록이 나타나면 템플릿 이름을 선택합니다.
리소스를 App.xaml 파일로 이동
리소스를 만들 때 App.xaml 파일에서 정의하지 않은 경우 리소스 패널에서 리소스를 끌어 App.xaml 파일로 이동할 수 있습니다.
팁: 리소스가 표시되지 않으면 문서 노드(대개 Page.xaml) 아래의 노드를 확장해야 할 수 있습니다.
리소스를 다른 프로젝트에 복사
프로젝트 패널에서 App.xaml 파일을 두 번 클릭하여 아트보드에 엽니다.
디자인 보기에서 App.xaml 파일을 볼 수 없으므로 아트보드 오른쪽의 XAML 탭을 선택합니다.
리소스는 <Application.Resources> 태그 사이에서 정의됩니다.
<Application.Resources> </Application.Resources>
이러한 태그 내에서는 속성 형식을 나타내는 태그 사이에 속성 리소스가 정의됩니다. Key 특성은 리소스에 제공한 이름을 나타냅니다.
<FontFamily x:Key="ApplicationFont">Segoe UI</FontFamily> <LinearGradientBrush x:Key="BorderBrush" EndPoint="0.5,1" StartPoint="0.5,0"> <GradientStop Color="#FF000000"/> <GradientStop Color="#FFC64545" Offset="1"/> </LinearGradientBrush>
템플릿은 <Style> 태그 사이에서 정의됩니다. Key 특성은 템플릿에 제공한 이름을 나타냅니다.
<Style x:Key="ImageButton" TargetType="Button"> <Setter Property="Background" Value="#FF1F3B53"/> <Setter Property="Template"> ... </Setter> </Style>
다른 프로젝트로 이동할 리소스를 나타내는 XAML을 강조 표시한 다음 Ctrl+C를 눌러 복사합니다.
Expression Blend에서 다른 프로젝트를 열고 아트보드에서 XAML 보기로 App.xaml 파일을 연 다음 <Application.Resources> 태그 바로 뒤에 포인터를 삽입한 후 Ctrl+V를 눌러 리소스를 붙여 넣습니다.
기존 리소스에 중복된 키 이름이 없어야 합니다.
프로젝트를 빌드(Ctrl+Shift+B)하여 새 리소스가 올바르게 복사되었는지 확인합니다.
팁: 또는 전체 App.xaml 파일을 새 프로젝트에 복사한 다음 x:Class 특성에 있는 이름을 새 프로젝트 이름으로 변경할 수 있습니다.
<Application
xmlns="https://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="https://schemas.microsoft.com/winfx/2006/xaml"
x:Class="ProjectName.App" ...
다음 단계
- Expression 커뮤니티 웹 사이트에서 제공되는 "작업 방법(How Do I?)" 비디오 자습서를 통해 단추(Button)와 확인란(CheckBox)의 컨트롤 스킨을 만드는 방법을 참조할 수 있습니다.