Windows 10-Entwicklung - Adaptive Benutzeroberfläche

Eine Universal Windows Platform (UWP) -Anwendung kann auf vielen verschiedenen Geräten ausgeführt werden. Jedes Gerät verfügt über eine eigene Eingabeform, Bildschirmauflösung, DPI-Dichte und andere einzigartige Merkmale.

In Windows 10 können Sie mithilfe neuer universeller Steuerelemente, Layoutfelder und Tools Ihre Benutzeroberfläche problemlos an die Geräte anpassen, auf denen Ihre Anwendung möglicherweise ausgeführt wird. Wenn Ihre UWP-Anwendung beispielsweise entweder auf einem Desktop-Computer, einem mobilen Gerät oder einem Tablet ausgeführt wird, können Sie die Benutzeroberfläche so anpassen, dass unterschiedliche Bildschirmauflösungen, Bildschirmgrößen und DPI-Dichte genutzt werden.

In Windows 10 können Sie Ihre Benutzeroberfläche mit den folgenden Funktionen problemlos auf mehrere Geräte ausrichten:

  • Sie können Ihre Benutzeroberfläche für verschiedene Bildschirmauflösungen und Bildschirmgrößen verbessern, indem Sie universelle Steuerelemente und Layoutfelder verwenden.

  • Mit der allgemeinen Eingabeverarbeitung können Sie Eingaben über ein Touchpad, einen Stift, eine Maus, eine Tastatur oder einen Controller wie einen Microsoft Xbox-Controller empfangen.

  • Mithilfe von Tools können Sie die Benutzeroberfläche Ihrer Anwendung so gestalten, dass sie sich an unterschiedliche Bildschirmauflösungen anpassen lässt.

  • Die adaptive Skalierung passt sich an die Auflösung und die DPI-Unterschiede zwischen den Geräten an.

In Windows 10 können Sie Anwendungen einfach nach Belieben anordnen, in der Größe ändern und positionieren. Es gibt dem Benutzer auch eine gewisse Flexibilität, um Ihre Anwendung so zu verwenden, wie er es möchte. In Windows 10 gibt es verschiedene Möglichkeiten, um reaktionsschnelle Techniken in Ihrer UWP-Anwendung zu implementieren, sodass es unabhängig von der Bildschirm- oder Fenstergröße großartig aussieht.

VisualStateManager

In Windows 10 wird die VisualStateManagerclass verfügt über zwei neue Mechanismen, mit deren Hilfe Sie ein responsives Design in Ihren UWP-Anwendungen implementieren können. Das neueVisualState.StateTriggers ermöglicht es dem Entwickler, bestimmte Bedingungen wie die Fensterhöhe oder -breite und dann die zu überprüfen VisualState.Setters APIs definieren visuelle Zustände als Reaktion auf diese bestimmten Bedingungen.

Schauen wir uns das folgende Beispiel an, in dem einige Steuerelemente im Stapelfenster hinzugefügt werden.

<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>

Jetzt VisualStateManager, passt die Ausrichtung des Stapelfelds basierend auf der Fensterbreite an. Wenn die Breite> = 720 ist, wird die Ausrichtung horizontal, andernfalls bleibt sie vertikal. Wenn der obige Code kompiliert und ausgeführt wird, wird das folgende Fenster angezeigt, das drei Textblöcke in vertikaler Reihenfolge enthält.

Lassen Sie uns die Breite des obigen Fensters ändern und Sie werden das folgende Fenster sehen -

Jetzt können Sie sehen, dass die Textblöcke in horizontaler Reihenfolge sind.

RelativePanel

RelativePanelkann verwendet werden, um die UI-Elemente anzuordnen, indem räumliche Beziehungen zwischen den Elementen ausgedrückt werden. Nehmen wir ein Beispiel, in dem einige Rechtecke im relativen Bereich erstellt werden.

<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>

Wenn der obige Code kompiliert und ausgeführt wird, wird das folgende Fenster angezeigt.

Wenn Sie die Größe des obigen Fensters ändern, sehen Sie, dass das grüne Rechteck jetzt in der oberen Reihe links vom blauen Rechteck wie unten gezeigt angepasst wird.