Xamarin.Forms Shell 浮出控件
Xamarin.Forms Shell 提供的导航体验基于浮出控件和选项卡。 浮出控件是 Shell 应用程序的可选根菜单,可完全自定义。 可以通过图标或从屏幕的一侧轻扫来访问它。 浮出控件由可选标头、浮出控件项、可选菜单项和可选页脚组成:
浮出控件项
可以将一个或多个浮出控件项添加到浮出控件中,每个浮出控件项都由 FlyoutItem
对象表示。 每个 FlyoutItem
对象应是子类化的 Shell
对象的子对象。 当浮出控件标头不存在时,浮出控件项会显示在浮出控件顶部。
以下示例创建包含两个浮出控件项的浮出控件:
<Shell xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:controls="clr-namespace:Xaminals.Controls"
xmlns:views="clr-namespace:Xaminals.Views"
x:Class="Xaminals.AppShell">
<FlyoutItem Title="Cats"
Icon="cat.png">
<Tab>
<ShellContent ContentTemplate="{DataTemplate views:CatsPage}" />
</Tab>
</FlyoutItem>
<FlyoutItem Title="Dogs"
Icon="dog.png">
<Tab>
<ShellContent ContentTemplate="{DataTemplate views:DogsPage}" />
</Tab>
</FlyoutItem>
</Shell>
FlyoutItem.Title
属性,类型为 string
,可定义浮出控件项的标题。 FlyoutItem.Icon
属性,类型为 ImageSource
,可定义浮出控件项的图标:
在此示例中,只能通过浮出控件项访问每个 ShellContent
,而不能通过选项卡进行访问。 这是因为默认情况下,仅当浮出控件项包含多个选项卡时才会显示选项卡。
重要
在 Shell 应用程序中,会按需创建页面以响应导航。 这是通过使用 DataTemplate
标记扩展将每个 ShellContent
对象的 ContentTemplate
属性设置为 ContentPage
对象来实现的。
Shell 具有隐式转换运算符,可以简化 Shell 的视觉层次结构,而无需在可视化树中引入额外的视图。 这是可能的,因为子类化的 Shell
对象只能包含 FlyoutItem
对象或 TabBar
对象,它们只能包含 Tab
对象,而此对象只能包含 ShellContent
对象。 这些隐式转换运算符可用于从前面的示例中删除 FlyoutItem
和 Tab
对象:
<Shell xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:controls="clr-namespace:Xaminals.Controls"
xmlns:views="clr-namespace:Xaminals.Views"
x:Class="Xaminals.AppShell">
<ShellContent Title="Cats"
Icon="cat.png"
ContentTemplate="{DataTemplate views:CatsPage}" />
<ShellContent Title="Dogs"
Icon="dog.png"
ContentTemplate="{DataTemplate views:DogsPage}" />
</Shell>
此隐式转换自动将每个 ShellContent
对象包装在 Tab
对象中,后者包装在 FlyoutItem
对象中。
注意
子类化的 Shell
对象中的所有 FlyoutItem
对象都会自动添加到 Shell.FlyoutItems
集合,该集合定义将在浮出控件中显示的项的列表。
浮出控件显示选项
FlyoutItem.FlyoutDisplayOptions
属性配置浮出控件项及其子级在浮出控件中的显示方式。 应将此属性设置为 FlyoutDisplayOptions
枚举成员:
AsSingleItem
,指示项将作为单个项显示。 这是FlyoutDisplayOptions
属性的默认值。AsMultipleItems
,指示项及其子项将作为一组项显示在浮出控件中。
通过将 FlyoutItem.FlyoutDisplayOptions
属性设置为 AsMultipleItems
,可以显示 FlyoutItem
中每个 Tab
对象的浮出控件项:
<Shell xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:controls="clr-namespace:Xaminals.Controls"
xmlns:views="clr-namespace:Xaminals.Views"
FlyoutHeaderBehavior="CollapseOnScroll"
x:Class="Xaminals.AppShell">
<FlyoutItem FlyoutDisplayOptions="AsMultipleItems">
<Tab Title="Domestic"
Icon="paw.png">
<ShellContent Title="Cats"
Icon="cat.png"
ContentTemplate="{DataTemplate views:CatsPage}" />
<ShellContent Title="Dogs"
Icon="dog.png"
ContentTemplate="{DataTemplate views:DogsPage}" />
</Tab>
<ShellContent Title="Monkeys"
Icon="monkey.png"
ContentTemplate="{DataTemplate views:MonkeysPage}" />
<ShellContent Title="Elephants"
Icon="elephant.png"
ContentTemplate="{DataTemplate views:ElephantsPage}" />
<ShellContent Title="Bears"
Icon="bear.png"
ContentTemplate="{DataTemplate views:BearsPage}" />
</FlyoutItem>
<ShellContent Title="About"
Icon="info.png"
ContentTemplate="{DataTemplate views:AboutPage}" />
</Shell>
在此示例中,将为 Tab
对象(FlyoutItem
对象的子对象)以及 ShellContent
对象(FlyoutItem
对象的子对象)创建浮出控件项。 发生这种情况是因为作为 FlyoutItem
对象子对象的每个 ShellContent
对象自动包装在 Tab
对象中。 此外,将为最终的 ShellContent
对象创建浮出控件项,该对象自动包装在 Tab
对象中,然后包装在 FlyoutItem
对象中。
注意
当 FlyoutItem
包含多个 ShellContent
对象时,将显示选项卡。
这将生成以下浮出控件项:
定义 FlyoutItem 外观
通过将 Shell.ItemTemplate
附加属性设置为 DataTemplate
可自定义每个 FlyoutItem
的外观:
<Shell ...>
...
<Shell.ItemTemplate>
<DataTemplate>
<Grid ColumnDefinitions="0.2*,0.8*">
<Image Source="{Binding FlyoutIcon}"
Margin="5"
HeightRequest="45" />
<Label Grid.Column="1"
Text="{Binding Title}"
FontAttributes="Italic"
VerticalTextAlignment="Center" />
</Grid>
</DataTemplate>
</Shell.ItemTemplate>
</Shell>
此示例以斜体显示每个 FlyoutItem
对象的标题:
Shell.ItemTemplate
是一个附加属性,因此可将不同的模板附加到特定的 FlyoutItem
对象。
注意
Shell 向 ItemTemplate
的 BindingContext
提供 Title
和 FlyoutIcon
属性。
此外,Shell 还包括三个可自动应用于 FlyoutItem
对象的样式类。 有关详细信息,请参阅样式 FlyoutItem 和 MenuItem 对象。
FlyoutItem 的默认模板
用于每个 FlyoutItem
的默认 DataTemplate
如下所示:
<DataTemplate x:Key="FlyoutTemplate">
<Grid x:Name="FlyoutItemLayout"
HeightRequest="{x:OnPlatform Android=50}"
ColumnSpacing="{x:OnPlatform UWP=0}"
RowSpacing="{x:OnPlatform UWP=0}">
<VisualStateManager.VisualStateGroups>
<VisualStateGroupList>
<VisualStateGroup x:Name="CommonStates">
<VisualState x:Name="Normal" />
<VisualState x:Name="Selected">
<VisualState.Setters>
<Setter Property="BackgroundColor"
Value="{x:OnPlatform Android=#F2F2F2, iOS=#F2F2F2}" />
</VisualState.Setters>
</VisualState>
</VisualStateGroup>
</VisualStateGroupList>
</VisualStateManager.VisualStateGroups>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="{x:OnPlatform Android=54, iOS=50, UWP=Auto}" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Image x:Name="FlyoutItemImage"
Source="{Binding FlyoutIcon}"
VerticalOptions="Center"
HorizontalOptions="{x:OnPlatform Default=Center, UWP=Start}"
HeightRequest="{x:OnPlatform Android=24, iOS=22, UWP=16}"
WidthRequest="{x:OnPlatform Android=24, iOS=22, UWP=16}">
<Image.Margin>
<OnPlatform x:TypeArguments="Thickness">
<OnPlatform.Platforms>
<On Platform="UWP"
Value="12,0,12,0" />
</OnPlatform.Platforms>
</OnPlatform>
</Image.Margin>
</Image>
<Label x:Name="FlyoutItemLabel"
Grid.Column="1"
Text="{Binding Title}"
FontSize="{x:OnPlatform Android=14, iOS=Small}"
HorizontalOptions="{x:OnPlatform UWP=Start}"
HorizontalTextAlignment="{x:OnPlatform UWP=Start}"
FontAttributes="{x:OnPlatform iOS=Bold}"
VerticalTextAlignment="Center">
<Label.TextColor>
<OnPlatform x:TypeArguments="Color">
<OnPlatform.Platforms>
<On Platform="Android"
Value="#D2000000" />
</OnPlatform.Platforms>
</OnPlatform>
</Label.TextColor>
<Label.Margin>
<OnPlatform x:TypeArguments="Thickness">
<OnPlatform.Platforms>
<On Platform="Android"
Value="20, 0, 0, 0" />
</OnPlatform.Platforms>
</OnPlatform>
</Label.Margin>
<Label.FontFamily>
<OnPlatform x:TypeArguments="x:String">
<OnPlatform.Platforms>
<On Platform="Android"
Value="sans-serif-medium" />
</OnPlatform.Platforms>
</OnPlatform>
</Label.FontFamily>
</Label>
</Grid>
</DataTemplate>
此模板可用作对现有浮出控件布局进行更改的基础,还显示了为浮出控件项实现的视觉状态。
此外,Grid
、Image
和 Label
元素都具有 x:Name
值,因此它们可作为可视状态管理器的目标。 有关详细信息,请参阅设置多个元素的状态。
注意
还可将同一模板用于 MenuItem
对象。
替换浮出控件内容
浮出项表示浮出控件内容,可以选择将其替换为你自己的内容,方法是将 Shell.FlyoutContent
可绑定属性设置为 object
:
<Shell ...
x:Name="shell">
...
<Shell.FlyoutContent>
<CollectionView BindingContext="{x:Reference shell}"
IsGrouped="True"
ItemsSource="{Binding FlyoutItems}">
<CollectionView.ItemTemplate>
<DataTemplate>
<Label Text="{Binding Title}"
TextColor="White"
FontSize="Large" />
</DataTemplate>
</CollectionView.ItemTemplate>
</CollectionView>
</Shell.FlyoutContent>
</Shell>
在此示例中,将浮出控件内容替换为 CollectionView
,它显示了 FlyoutItems
集合中每个项的标题。
注意
Shell
类中的 FlyoutItems
属性是浮出控件项的只读集合。
此外,可以通过将 Shell.FlyoutContentTemplate
可绑定属性设置为 DataTemplate
来定义浮出控件内容:
<Shell ...
x:Name="shell">
...
<Shell.FlyoutContentTemplate>
<DataTemplate>
<CollectionView BindingContext="{x:Reference shell}"
IsGrouped="True"
ItemsSource="{Binding FlyoutItems}">
<CollectionView.ItemTemplate>
<DataTemplate>
<Label Text="{Binding Title}"
TextColor="White"
FontSize="Large" />
</DataTemplate>
</CollectionView.ItemTemplate>
</CollectionView>
</DataTemplate>
</Shell.FlyoutContentTemplate>
</Shell>
重要
可以选择在浮出控件内容上方显示浮出控件标头,还可以选择在浮出控件内容下显示浮出控件页脚。 如果浮出控件内容可滚动,Shell 将尝试遵循浮出控件标头的滚动行为。
菜单项
可以有选择性地将菜单项添加到浮出控件中,每个菜单项都由 MenuItem
对象表示。 浮出控件上 MenuItem
对象的位置取决于其在 Shell 视觉对象层次结构中的声明顺序。 因此,在 FlyoutItem
对象之前声明的任何 MenuItem
对象都将出现在浮出控件中的 FlyoutItem
对象之前,在 FlyoutItem
对象之后声明的任何 MenuItem
对象都将出现在浮出控件中的 FlyoutItem
对象之后。
MenuItem
类具有 Clicked
事件和 Command
属性。 因此,MenuItem
对象支持以下场景:执行一个操作以响应被点击的 MenuItem
。
可将 MenuItem
对象添加到浮出控件,如下面的示例所示:
<Shell ...>
...
<MenuItem Text="Help"
IconImageSource="help.png"
Command="{Binding HelpCommand}"
CommandParameter="https://learn.microsoft.com/xamarin/xamarin-forms/app-fundamentals/shell" />
</Shell>
此示例在所有浮出控件项下方,向浮出控件添加一个 MenuItem
对象:
MenuItem
对象执行名为 HelpCommand
的 ICommand
,这将在系统 Web 浏览器中打开由 CommandParameter
属性指定的 URL。
注意
每个 MenuItem
的 BindingContext
都继承自子类化的 Shell
对象。
定义 MenuItem 外观
通过将 Shell.MenuItemTemplate
附加属性设置为 DataTemplate
可自定义每个 MenuItem
的外观:
<Shell ...>
<Shell.MenuItemTemplate>
<DataTemplate>
<Grid ColumnDefinitions="0.2*,0.8*">
<Image Source="{Binding Icon}"
Margin="5"
HeightRequest="45" />
<Label Grid.Column="1"
Text="{Binding Text}"
FontAttributes="Italic"
VerticalTextAlignment="Center" />
</Grid>
</DataTemplate>
</Shell.MenuItemTemplate>
...
<MenuItem Text="Help"
IconImageSource="help.png"
Command="{Binding HelpCommand}"
CommandParameter="https://learn.microsoft.com/xamarin/xamarin-forms/app-fundamentals/shell" />
</Shell>
此示例会将 DataTemplate
附加到每个 MenuItem
对象,以斜体显示 MenuItem
对象的标题:
Shell.MenuItemTemplate
是一个附加属性,因此可将不同的模板附加到特定的 MenuItem
对象。
注意
Shell 向 MenuItemTemplate
的 BindingContext
提供 Text
和 IconImageSource
属性。 也可使用 Title
代替 Text
并使用 Icon
代替 IconImageSource
,这样便可对菜单项和浮出控件项重复使用相同的模板。
FlyoutItem
对象的默认模板还可用于 MenuItem
对象。 有关详细信息,请参阅 FlyoutItem 的默认模板。
样式 FlyoutItem 和 MenuItem 对象
Shell 包括三个可自动应用于 FlyoutItem
和 MenuItem
对象的样式类。 样式类名为 FlyoutItemLabelStyle
、FlyoutItemImageStyle
和 FlyoutItemLayoutStyle
。
以下 XAML 演示一个示例,该示例定义了这些样式类的样式:
<Style TargetType="Label"
Class="FlyoutItemLabelStyle">
<Setter Property="TextColor"
Value="Black" />
<Setter Property="HeightRequest"
Value="100" />
</Style>
<Style TargetType="Image"
Class="FlyoutItemImageStyle">
<Setter Property="Aspect"
Value="Fill" />
</Style>
<Style TargetType="Layout"
Class="FlyoutItemLayoutStyle"
ApplyToDerivedTypes="True">
<Setter Property="BackgroundColor"
Value="Teal" />
</Style>
这些样式可自动应用于 FlyoutItem
和 MenuItem
对象,而无需将其 StyleClass
属性设置为样式类名。
此外,还可以定义自定义样式类并将其应用于 FlyoutItem
和 MenuItem
对象。 有关样式类的详细信息,请参阅 Xamarin.Forms 样式类。
浮出控件标头
浮出控件标头是根据需要显示在浮出控件顶部的内容,使用可通过 Shell.FlyoutHeader
可绑定属性设置的 object
定义其外观:
<Shell ...>
<Shell.FlyoutHeader>
<controls:FlyoutHeader />
</Shell.FlyoutHeader>
</Shell>
FlyoutHeader
类型如以下示例所示:
<ContentView xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="Xaminals.Controls.FlyoutHeader"
HeightRequest="200">
<Grid BackgroundColor="Black">
<Image Aspect="AspectFill"
Source="xamarinstore.jpg"
Opacity="0.6" />
<Label Text="Animals"
TextColor="White"
FontAttributes="Bold"
HorizontalTextAlignment="Center"
VerticalTextAlignment="Center" />
</Grid>
</ContentView>
这将生成以下浮出控件标头:
还可以通过将 Shell.FlyoutHeaderTemplate
可绑定属性设置为 DataTemplate
的方式来定义浮出控件标头的外观:
<Shell ...>
<Shell.FlyoutHeaderTemplate>
<DataTemplate>
<Grid BackgroundColor="Black"
HeightRequest="200">
<Image Aspect="AspectFill"
Source="xamarinstore.jpg"
Opacity="0.6" />
<Label Text="Animals"
TextColor="White"
FontAttributes="Bold"
HorizontalTextAlignment="Center"
VerticalTextAlignment="Center" />
</Grid>
</DataTemplate>
</Shell.FlyoutHeaderTemplate>
</Shell>
默认情况下,在浮出控件中,浮出控件标头是固定的,在有足够的项时会滚动其下方的内容。 但是,通过将 Shell.FlyoutHeaderBehavior
可绑定属性设置为 FlyoutHeaderBehavior
枚举成员之一可以更改此行为:
Default
– 指示将使用的平台的默认行为。 这是FlyoutHeaderBehavior
属性的默认值。Fixed
– 指示浮出控件标头始终保持可见且不变。Scroll
– 指示当用户滚动项时,浮出控件标头将卷出视图外。CollapseOnScroll
– 指示当用户滚动项时,浮出控件标头将仅折叠到标题。
以下示例演示如何在用户滚动时折叠浮出控件标头:
<Shell ...
FlyoutHeaderBehavior="CollapseOnScroll">
...
</Shell>
浮出控件页脚
浮出控件页脚是根据需要显示在浮出控件底部的内容,使用可通过 Shell.FlyoutFooter
可绑定属性设置的 object
定义其外观:
<Shell ...>
<Shell.FlyoutFooter>
<controls:FlyoutFooter />
</Shell.FlyoutFooter>
</Shell>
FlyoutFooter
类型如以下示例所示:
<ContentView xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:sys="clr-namespace:System;assembly=netstandard"
x:Class="Xaminals.Controls.FlyoutFooter">
<StackLayout>
<Label Text="Xaminals"
TextColor="GhostWhite"
FontAttributes="Bold"
HorizontalOptions="Center" />
<Label Text="{Binding Source={x:Static sys:DateTime.Now}, StringFormat='{0:MMMM dd, yyyy}'}"
TextColor="GhostWhite"
HorizontalOptions="Center" />
</StackLayout>
</ContentView>
这将生成以下浮出控件页脚:
还可以通过将 Shell.FlyoutFooterTemplate
属性设置为 DataTemplate
的方式来定义浮出控件页脚的外观:
<Shell ...>
<Shell.FlyoutFooterTemplate>
<DataTemplate>
<StackLayout>
<Label Text="Xaminals"
TextColor="GhostWhite"
FontAttributes="Bold"
HorizontalOptions="Center" />
<Label Text="{Binding Source={x:Static sys:DateTime.Now}, StringFormat='{0:MMMM dd, yyyy}'}"
TextColor="GhostWhite"
HorizontalOptions="Center" />
</StackLayout>
</DataTemplate>
</Shell.FlyoutFooterTemplate>
</Shell>
浮出控件页脚固定在浮出控件的底部,可以是任意高度。 此外,页脚永远不会遮挡任何菜单项。
浮出控件宽度和高度
可以通过将 Shell.FlyoutWidth
" 和 Shell.FlyoutHeight
附加属性设置为 double
值来自定义浮出控件的宽度和高度:
<Shell ...
FlyoutWidth="400"
FlyoutHeight="200">
...
</Shell>
这样做可以启用多种方案,例如在整个屏幕上展开浮出控件,或降低浮出控件的高度使其不遮挡选项卡栏。
浮出控件图标
默认情况下,Shell 应用程序具有一个汉堡图标,按该图标时将打开浮出控件。 可以通过设置类型为 ImageSource
的 Shell.FlyoutIcon
可绑定属性来将此图标更改为相应的图标:
<Shell ...
FlyoutIcon="flyouticon.png">
...
</Shell>
浮出控件背景
可以通过 Shell.FlyoutBackgroundColor
可绑定属性设置浮出控件的背景色:
<Shell ...
FlyoutBackgroundColor="AliceBlue">
...
</Shell>
注意
还可以从级联样式表 (CSS) 设置 Shell.FlyoutBackgroundColor
。 有关详细信息,请参阅 Xamarin.Forms Shell 特定属性。
也可以通过将 Shell.FlyoutBackground
可绑定属性设置为 Brush
来指定浮出控件的背景:
<Shell ...
FlyoutBackground="LightGray">
...
</Shell>
在此示例中,浮出控件背景是用浅灰色 SolidColorBrush
绘制的。
以下示例演示如何将浮出控件背景设置为 LinearGradientBrush
:
<Shell ...>
<Shell.FlyoutBackground>
<LinearGradientBrush StartPoint="0,0"
EndPoint="1,1">
<GradientStop Color="#8A2387"
Offset="0.1" />
<GradientStop Color="#E94057"
Offset="0.6" />
<GradientStop Color="#F27121"
Offset="1.0" />
</LinearGradientBrush>
</Shell.FlyoutBackground>
...
</Shell>
若要详细了解画笔,请参阅 Xamarin.Forms 画笔。
浮出控件背景图像
浮出控件可以有一个可选背景图像,该图像显示在浮出控件标头的下方,并且位于任何浮出控件项、菜单项和浮出控件页脚的后面。 可以通过将类型为 ImageSource
的 FlyoutBackgroundImage
可绑定属性设置为文件、嵌入的资源、URI 或流来指定背景图像。
可以通过将类型 Aspect
的 FlyoutBackgroundImageAspect
可绑定属性设置为 Aspect
枚举成员之一来配置背景图像的纵横比:
AspectFill
- 剪裁图像,使其在填充显示区域的同时保持纵横比。AspectFit
- 根据需要对图像上下加框,以使其适合显示区域,并根据图像的宽度或高度,将空白添加到顶部/底部或侧边。 这是FlyoutBackgroundImageAspect
属性的默认值。Fill
- 拉伸图像,使其完整精确地填充显示区域。 这可能会导致图像失真。
以下示例演示如何设置这些属性:
<Shell ...
FlyoutBackgroundImage="photo.jpg"
FlyoutBackgroundImageAspect="AspectFill">
...
</Shell>
这将使背景图像显示在浮出控件中,位于浮出控件标头下方:
浮出控件背景
通过将 Shell.FlyoutBackdrop
附加属性设置为 Brush
,可以指定浮出控件的背景(即浮出控件叠加层的外观):
<Shell ...
FlyoutBackdrop="Silver">
...
</Shell>
在此示例中,浮出控件背景是用银色 SolidColorBrush
绘制的。
重要
可以在任何 Shell 元素上设置 FlyoutBackdrop
附加属性,但仅在 Shell
、FlyoutItem
或 TabBar
对象上设置该属性时才会应用。
以下示例演示了如何将浮出控件背景设置为 LinearGradientBrush
:
<Shell ...>
<Shell.FlyoutBackdrop>
<LinearGradientBrush StartPoint="0,0"
EndPoint="1,1">
<GradientStop Color="#8A2387"
Offset="0.1" />
<GradientStop Color="#E94057"
Offset="0.6" />
<GradientStop Color="#F27121"
Offset="1.0" />
</LinearGradientBrush>
</Shell.FlyoutBackdrop>
...
</Shell>
若要详细了解画笔,请参阅 Xamarin.Forms 画笔。
浮出控件行为
访问浮出控件的方式有两种:按汉堡图标或从屏幕一侧轻扫。 但是,通过将 Shell.FlyoutBehavior
附加属性设置为 FlyoutBehavior
枚举成员之一可以更改此行为:
Disabled
– 指示用户无法打开浮出控件。Flyout
– 指示用户可以打开和关闭浮出控件。 这是FlyoutBehavior
属性的默认值。Locked
– 指示用户无法关闭浮出控件,并且不会重叠内容。
以下示例演示如何禁用浮出控件:
<Shell ...
FlyoutBehavior="Disabled">
...
</Shell>
注意
可以在 Shell
、FlyoutItem
、ShellContent
和页面对象上设置 FlyoutBehavior
附加属性以替代默认浮出控件行为。
浮出控件垂直滚动
默认情况下,当浮出控件中容纳不下浮出控件项时,可以垂直滚动浮出控件。 通过将 Shell.FlyoutVerticalScrollMode
可绑定属性设置为 ScrollMode
枚举成员之一可以更改此行为:
Disabled
– 指示将禁用垂直滚动。Enabled
– 指示将启用垂直滚动。Auto
– 指示当浮出控件中容纳不下浮出控件项时,将启用垂直滚动。 这是FlyoutVerticalScrollMode
属性的默认值。
以下示例演示如何禁用垂直滚动:
<Shell ...
FlyoutVerticalScrollMode="Disabled">
...
</Shell>
FlyoutItem Tab 键顺序
默认情况下,FlyoutItem
对象的 Tab 键顺序与在 XAML 中列出的顺序或以编程方式添加到子集合中的顺序相同。 此顺序是使用键盘导航 FlyoutItem
对象的顺序,通常这种默认顺序是最佳顺序。
可以通过设置 FlyoutItem.TabIndex
属性来更改默认 Tab 键顺序,该属性指示当用户通过按 Tab 键导航项时 FlyoutItem
对象接收焦点的顺序。 属性的默认值是 0,可以将其设置为任何 int
值。
使用默认 Tab 键顺序或设置 TabIndex
属性时,以下规则适用:
FlyoutItem
对象(TabIndex
等于 0)将根据 XAML 或子集合中的声明顺序添加到 Tab 键顺序中。FlyoutItem
对象(TabIndex
大于 0)将根据其TabIndex
值添加到 Tab 键顺序中。FlyoutItem
对象(TabIndex
小于 0)将添加到 Tab 键顺序中,并显示在任何零值之前。TabIndex
中的冲突可通过声明顺序解决。
定义 Tab 键顺序后,按 Tab 键焦点将按升序 TabIndex
顺序循环通过 FlyoutItem
对象,并在到达最后一个对象后绕到开头。
除了设置 FlyoutItem
对象的 Tab 键顺序之外,可能还需要从 Tab 键顺序中排除某些对象。 这可以通过 FlyoutItem.IsTabStop
属性实现,该属性指示 Tab 导航中是否包含 FlyoutItem
。 其默认值是 true
,当它的值是 false
时,Tab 导航基础结构将忽略 FlyoutItem
,而不管是否设置了 TabIndex
。
FlyoutItem 选择
首次运行使用浮出控件的 Shell 应用程序时,Shell.CurrentItem
属性将设置为子类化的 Shell
对象中的第一个 FlyoutItem
对象。 但是,此属性可以设置为另一个 FlyoutItem
,如以下示例所示:
<Shell ...
CurrentItem="{x:Reference aboutItem}">
<FlyoutItem FlyoutDisplayOptions="AsMultipleItems">
...
</FlyoutItem>
<ShellContent x:Name="aboutItem"
Title="About"
Icon="info.png"
ContentTemplate="{DataTemplate views:AboutPage}" />
</Shell>
此示例将 CurrentItem
属性设置为名为 aboutItem
的 ShellContent
对象,这将导致选中并显示该对象。 在此示例中,隐式转换用于将 ShellContent
对象包装在 Tab
对象中,后者包装在 FlyoutItem
对象中。
假设有一个名为 aboutItem
的 ShellContent
对象,则等效的 C# 代码为:
CurrentItem = aboutItem;
在此示例中,CurrentItem
属性是在子类化的 Shell
类中设置的。 或者,可通过 Shell.Current
静态属性在任何类中设置 CurrentItem
属性:
Shell.Current.CurrentItem = aboutItem;
注意
应用程序可能会进入一个状态,在该状态下,选择浮出控件项不是有效操作。 在这种情况下,可以通过将 FlyoutItem
的 IsEnabled
属性设置为 false
来对其进行禁用。 这会阻止用户选择浮出控件项。
FlyoutItem 可见性
浮出项在浮出控件中默认可见。 但是,可以使用 FlyoutItemIsVisible
属性将项隐藏在浮出控件中,并使用 IsVisible
属性将其从浮出控件中删除:
- 类型为
bool
的FlyoutItemIsVisible
指示项是否已隐藏在浮出控件中但仍可以通过GoToAsync
导航方法进行访问。 此属性的默认值为true
。 - 类型为
bool
的IsVisible
指示是否应从可视化树中移除项,从而不在浮出控件中显示。 它的默认值为true
。
以下示例演示如何在浮出控件中隐藏项:
<Shell ...>
<FlyoutItem ...
FlyoutItemIsVisible="False">
...
</FlyoutItem>
</Shell>
注意
还有一个 Shell.FlyoutItemIsVisible
附加属性,可在 FlyoutItem
、MenuItem
、Tab
和 ShellContent
对象上设置该属性。
以编程方式打开和关闭浮出控件
可以通过将 Shell.FlyoutIsPresented
可绑定属性设置为指示浮出控件当前是否处于打开状态的 boolean
值来以编程方式打开和关闭浮出控件:
<Shell ...
FlyoutIsPresented="{Binding IsFlyoutOpen}">
</Shell>
也可以在代码中执行此操作:
Shell.Current.FlyoutIsPresented = false;