Windows 10 개발-적응 형 UI

UWP (유니버설 Windows 플랫폼) 애플리케이션은 다양한 장치에서 실행될 수 있으며 각 장치에는 고유 한 입력 형식, 화면 해상도, DPI 밀도 및 기타 고유 한 특성이 있습니다.

Windows 10에서는 새로운 범용 컨트롤, 레이아웃 패널 및 도구를 사용하여 응용 프로그램이 실행될 수있는 장치에 맞게 UI를 쉽게 조정할 수 있습니다. 예를 들어 UWP 응용 프로그램이 데스크톱 컴퓨터, 모바일 장치 또는 태블릿에서 실행중인 경우 UI를 조정하여 다양한 화면 해상도, 화면 크기 및 DPI 밀도를 활용할 수 있습니다.

Windows 10에서는 다음 기능을 사용하여 UI를 여러 장치로 쉽게 타겟팅 할 수 있습니다.

  • 범용 컨트롤 및 레이아웃 패널을 사용하여 다양한 화면 해상도 및 화면 크기에 맞게 UI를 향상시킬 수 있습니다.

  • 공통 입력 처리를 사용하면 터치 패드, 펜, 마우스, 키보드 또는 Microsoft Xbox 컨트롤러와 같은 컨트롤러를 통해 입력을받을 수 있습니다.

  • 도구의 도움으로 다양한 화면 해상도에 적응할 수있는 애플리케이션 UI를 디자인 할 수 있습니다.

  • 적응 형 크기 조정은 장치 간의 해상도 및 DPI 차이에 맞게 조정됩니다.

Windows 10에서는 원하는 방식으로 애플리케이션을 쉽게 정렬, 크기 조정 및 배치 할 수 있습니다. 또한 사용자가 원하는 방식으로 애플리케이션을 사용할 수있는 유연성을 제공합니다. Windows 10에는 UWP 애플리케이션에서 반응 형 기술을 구현하는 다양한 방법이 있으므로 화면이나 창 크기에 관계없이 멋지게 보입니다.

VisualStateManager

Windows 10에서는 VisualStateManager클래스에는 UWP 애플리케이션에서 반응 형 디자인을 구현할 수있는 두 가지 새로운 메커니즘이 있습니다. 새로운VisualState.StateTriggers 개발자가 창 높이 또는 창 너비와 같은 특정 조건을 확인한 다음 VisualState.Setters API는 이러한 특정 조건에 대한 응답으로 시각적 상태를 정의합니다.

스택 패널에 일부 컨트롤이 추가 된 아래의 예를 살펴 보겠습니다.

<Page 
   x:Class = "UWPAdaptiveUI.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "using:UWPAdaptiveUI" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008"
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d"> 
	
   <Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}">
      <VisualStateManager.VisualStateGroups>
		
         <VisualStateGroup>
			
            <VisualState>
				
               <VisualState.StateTriggers>
                  <!-- VisualState to be triggered when window 
                     width is >=720 effective pixels. -->
                  <AdaptiveTrigger MinWindowWidth = "720" />
               </VisualState.StateTriggers>
					
               <VisualState.Setters>
                  <Setter Target = "myPanel.Orientation" Value = "Horizontal" />
               </VisualState.Setters>
					
            </VisualState>
				
         </VisualStateGroup>
			
      </VisualStateManager.VisualStateGroups>
		
      <StackPanel x:Name = "myPanel" Orientation = "Vertical">
		
         <TextBlock Text = "Windows 10 Tutorials: Text block 1. " 
            Style = "{ThemeResource BodyTextBlockStyle}"/>
				
         <TextBlock Text = "Windows 10 Tutorials: Text block 2. " 
            Style = "{ThemeResource BodyTextBlockStyle}"/>
				
         <TextBlock Text = "Windows 10 Tutorials: Text block 3. " 
            Style = "{ThemeResource BodyTextBlockStyle}"/>
				
      </StackPanel> 
		
   </Grid>
	
</Page>

지금 VisualStateManager, 창의 너비에 따라 스택 패널의 방향을 조정합니다. 너비가> = 720이면 방향이 수평이되고 그렇지 않으면 수직으로 유지됩니다. 위의 코드가 컴파일되고 실행되면 다음과 같은 창이 나타납니다. 세 개의 텍스트 블록이 세로 순서로 포함되어 있습니다.

위 창의 너비를 조정하면 다음 창이 표시됩니다.

이제 텍스트 블록이 수평 순서임을 알 수 있습니다.

RelativePanel

RelativePanel요소 간의 공간적 관계를 표현하여 UI 요소를 레이아웃하는 데 사용할 수 있습니다. 상대 패널에 직사각형이 생성되는 예를 들어 보겠습니다.

<Page 
   x:Class = "UWPAdaptiveUI.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "using:UWPAdaptiveUI" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d"> 
	
   <Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}"> 
	
      <VisualStateManager.VisualStateGroups> 
		
         <VisualStateGroup> 
			
            <VisualState> 
				
               <VisualState.StateTriggers> 
                  <AdaptiveTrigger MinWindowWidth = "720" /> 
               </VisualState.StateTriggers> 
					
               <VisualState.Setters> 
                  <Setter Target = "GreenRect.(RelativePanel.RightOf)"
                     Value = "BlueRect" /> 
                  <Setter Target = "GreenRect.(RelativePanel.AlignRightWithPanel)" 
                     Value = "True" /> 
               </VisualState.Setters> 
					
            </VisualState> 
				
         </VisualStateGroup>
			
      </VisualStateManager.VisualStateGroups>
		
      <RelativePanel BorderBrush = "Gray" BorderThickness = "10"> 
         <Rectangle x:Name = "RedRect" Fill = "Red" MinHeight = "100" 
            MinWidth = "100"/> 
				
         <Rectangle x:Name = "BlueRect" Fill = "Blue" MinHeight = "100" 
            MinWidth = "100" RelativePanel.RightOf = "RedRect" /> 
				
         <!-- Width is not set on the green and yellow rectangles. 
            It's determined by the RelativePanel properties. --> 
				
         <Rectangle x:Name = "GreenRect" Fill = "Green" MinHeight = "100" 
            RelativePanel.Below = "BlueRect" RelativePanel.AlignLeftWith = "RedRect" 
            RelativePanel.AlignRightWith = "BlueRect"/> 
				
         <Rectangle Fill = "Yellow" MinHeight = "100" RelativePanel.Below = "GreenRect" 
            RelativePanel.AlignLeftWith = "BlueRect"
            RelativePanel.AlignRightWithPanel = "True"/> 
				
      </RelativePanel> 
		
   </Grid> 
	
</Page>

위의 코드를 컴파일하고 실행하면 다음과 같은 창이 나타납니다.

위 창의 크기를 조정하면 녹색 사각형이 아래 그림과 같이 파란색 사각형의 왼쪽 상단 행에서 조정 된 것을 볼 수 있습니다.