我们可以使用 Shell 来创建选项卡。 但是,如果我们想在特定部分(例如:网格)中嵌套选项卡会发生什么?,_如果我们想完全自定义每个选项卡怎么办?_。 在这些情况下,到目前为止我们需要一个自定义渲染器......
TabView是一种显示一组选项卡及其各自内容的方法。 TabView 可用于显示多个内容,同时让用户能够自定义大部分内容。
注意: TabView 是一个跨平台视图,它会在原生选项卡达到其极限时接管,例如使用布局定位、样式和非统一样式(如凸起的按钮)。
接下来是一个包含 TabView 属性、事件和视觉状态的列表。
| 物业 | 类型 | 说明 |
|------------|:-------------:|:------------:|
| TabItemsSource | IEnumerable | 用于生成 TabView 的选项卡项的集合。 |
| TabViewItemDataTemplate | 数据模板 | 选项卡视图用于生成选项卡项标题的模板。 |
| TabContentDataTemplate | 数据模板 | 选项卡视图用于生成选项卡项内容的模板。 |
| 是周期性的 | 布尔 | 启用或禁用循环标签导航。 |
| 懒惰 | 布尔 | 启用或禁用延迟选项卡加载。 |
| 精选索引 | 国际| 获取或设置当前选定的选项卡。 默认值为 0。
| TabStripPlacement | TabStripPlacement | TabStrip 位置(顶部或底部)。 |
| TabStripBackground | 刷| TabStrip 背景。 |
| TabIndicatorBrush | 刷| TabIndicator 背景。 |
| TabIndicatorHeight | 双| TabIndicator 高度。 |
| TabIndicatorWidth | 双| TabIndicator 宽度。 |
| TabIndicatorPlacement | TabIndicatorPlacement | |
| TabIndicatorView | 查看 | TabIndicator 内容。 |
| 标签内容背景 | 刷| 选项卡内容背景。 |
| 标签内容高度 | 双| 选项卡内容高度。 |
| TabStripHeight | 双| TabStrip 高度。 |
| 标签内容高度 | 双| 选项卡内容高度。 |
| HasTabStripShadow | 布尔 | 显示或隐藏 TabStrip 阴影效果。 |
| IsTabTransitionEnabled | 布尔 | 启用或禁用选项卡之间的转换。 |
| IsSwipeEnabled | 布尔 | 启用或禁用滑动手势。 |
| 物业 | 类型 | 说明 |
|------------|:-------------:|:------------:|
| 文字 | 字符串 | 选项卡的文本。 |
| 文字颜色 | 颜色 | 选项卡的文本颜色。 |
| 已选择的文本颜色 | 颜色 | 所选选项卡的文本颜色。 |
| 字体大小 | 字体大小 | 标签文本中使用的字体大小。 |
| 字体大小已选择 | 字体大小 | 所选选项卡中使用的字体大小。 |
| 字体家族 | 字符串 | 选项卡中使用的字体系列。 |
| FontFamilySelected | 字符串 | 所选选项卡中使用的字体系列。 |
| 字体属性 | 字体属性 | 选项卡中使用的字体属性。 |
| FontAttributesSelected | 字体属性 | 所选选项卡中使用的字体属性。 |
| 图标 | 图像源 | 选项卡的图标。 |
| 图标已选择 | 图像源 | 在所选选项卡中用作图标的 ImageSource。 |
| 内容 | 查看 | 选项卡的内容。 是View,可以使用任何东西作为内容。 |
| 徽章文本 | 布尔 | 选项卡中使用的徽章文本。 |
| 徽章文本颜色 | 颜色 | 选项卡中使用的徽章文本颜色。 |
| 徽章文本颜色已选择 | 颜色 | 所选选项卡中使用的徽章文本颜色。 |
| 徽章背景颜色 | 颜色 | 选项卡中使用的徽章颜色。 |
| 徽章背景颜色已选择 | 颜色 | 所选选项卡中使用的徽章颜色。 |
| 已选择 | 布尔 | 指示选项卡是否被选中的布尔值。 |
| 点击命令 | ICommand | 当用户点击选项卡时执行的命令。 |
| TapCommandParameter | 对象 | 点击命令参数。 |
| 活动 | 说明 |
|------------|:------------:|
| 选择已更改 | 选定选项卡更改时引发的事件。 |
| 滚动 | 在选项卡之间滑动时引发的事件。 |
| 活动 | 说明 |
|------------|:------------:|
| 标签点击 | 当用户点击选项卡时引发的事件。 |
视觉状态管理器 (VSM) 提供了一种结构化方式,可以通过代码对用户界面进行可视化更改。
VSM 引入了视觉状态的概念。 TabView 可以有几种不同的视觉外观,具体取决于其底层状态。
TabView 有四个特定的VisualStates :
让我们看一些涵盖常见场景的示例。
让我们看一个基本的例子:
<TabView
TabStripPlacement="Bottom"
TabStripBackgroundColor="Blue">
<TabViewItem
Icon="triangle.png"
Text="Tab 1">
<Grid
BackgroundColor="Gray">
<Label
HorizontalOptions="Center"
VerticalOptions="Center"
Text="TabContent1" />
</Grid>
</TabViewItem>
<TabViewItem
Icon="circle.png"
Text="Tab 2">
<Grid>
<Label
HorizontalOptions="Center"
VerticalOptions="Center"
Text="TabContent2" />
</Grid>
</TabViewItem>
</TabView>
使用 TabItemsSource(动态选项卡):
<TabView
TabItemsSource="{Binding Monkeys}"
TabViewItemDataTemplate="{StaticResource TabViewItemTemplate}"
TabContentDataTemplate="{StaticResource TabContentTemplate}" />
每个选项卡的外观都可以自定义:
<ControlTemplate
x:Key="TabItemTemplate">
<Grid>
...
</Grid>
</ControlTemplate>
<TabView>
<TabViewItem
Text="Tab 1"
ControlTemplate="{StaticResource TabItemTemplate}">
</TabViewItem>
</TabView>
您想在选项卡之间循环导航吗?
<TabView
IsCyclical="True">
...
</TabView>
延迟标签加载:
<TabView
IsLazy="True">
...
</TabView>
可以使用 Xamarin.Forms 动画来自定义每个选项卡之间的转换,在出现或消失时为选项卡设置动画,甚至在出现或消失时为徽章设置动画。
<TabView>
<TabView.TabTransition>
<local:CustomTabTransition />
</TabView.TabTransition>
<TabViewItem
Text="Tab 1">
<TabViewItem.TabAnimation>
<local:CustomTabViewItemAnimation />
</TabViewItem.TabAnimation>
<Grid
BackgroundColor="LawnGreen">
<Label
HorizontalOptions="Center"
VerticalOptions="Center"
Text="TabContent1" />
</Grid>
</TabViewItem>
...
</TabView>
可以使用不同的视觉状态来自定义当前选项卡、下一个选项卡等。
<Grid>
<VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="TabViewStates">
<VisualState x:Name="CurrentTab">
<VisualState.Setters>
<Setter Property="Opacity" Value="1" />
</VisualState.Setters>
</VisualState>
<VisualState x:Name="PreviousTab">
<VisualState.Setters>
<Setter Property="Opacity" Value="0.7" />
</VisualState.Setters>
</VisualState>
<VisualState x:Name="NextTab">
<VisualState.Setters>
<Setter Property="Opacity" Value="0.7" />
</VisualState.Setters>
</VisualState>
<VisualState x:Name="DefaultTab">
<VisualState.Setters>
<Setter Property="Opacity" Value="0.9" />
</VisualState.Setters>
</VisualState>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<Label Text="{Binding Index}" HorizontalOptions="Center" VerticalOptions="End" />
</Grid>
可以使用 XAML 或 C# 在 Xamarin.Forms 中创建 UI。 让我们看看如何使用 C# 创建选项卡。
var tabView = new Tabs
{
TabStripPlacement = TabStripPlacement.Bottom,
TabStripBackgroundColor = Color.Blue,
TabStripHeight = 60,
TabIndicatorColor = Color.Yellow,
TabContentBackgroundColor = Color.Yellow
};
var tabViewItem1 = new TabViewItem
{
Icon = "triangle.png",
Text = "Tab 1",
TextColor = Color.White,
TextColorSelected = Color.Yellow,
};
var tabViewItem1Content = new Grid
{
BackgroundColor = Color.Gray
};
var label1 = new Label
{
HorizontalOptions = LayoutOptions.Center,
VerticalOptions = LayoutOptions.Center,
Text = "TabContent1"
};
tabViewItem1Content.Children.Add(label1);
tabViewItem1.Content = tabViewItem1Content;
tabView.TabItems.Add(tabViewItem1);
var tabViewItem2 = new TabViewItem
{
Icon = "circle.png",
Text = "Tab 2",
TextColor = Color.White,
TextColorSelected = Color.Yellow
};
var tabViewItem2Content = new Grid
{
BackgroundColor = Color.OrangeRed
};
var label2 = new Label
{
HorizontalOptions = LayoutOptions.Center,
VerticalOptions = LayoutOptions.Center,
Text = "TabContent2"
};
tabViewItem2Content.Children.Add(label2);
tabViewItem2.Content = tabViewItem2Content;
tabView.TabItems.Add(tabViewItem2);
可以使用XAML样式或CSS自定义选项卡内容、选项卡条、选项卡项等的外观。
使用 XAML:
<Style
x:Key="TabItemStyle"
TargetType="TabViewItem">
<Setter
Property="FontSize"
Value="12" />
<Setter
Property="TextColor"
Value="#979797" />
</Style>
使用 CSS:
.customTabItem {
font-size: medium;
text-color: red;
}
我们可以在 MVU 中看到 C# 示例吗?
如果扩展 TabView 行为,那么对于某些使用场景(例如我的),如果显示足够宽,选项卡将“展开”,这将非常有帮助,也就是说,它们将显示所有选项卡的内容隔着屏幕。 这允许一个整洁的“响应式设计”,它非常适合平板电脑。
在手机或以纵向模式手持的平板电脑上,用户会看到一个选项卡式视图,其中一个窗格显示在屏幕上,其他窗格可通过“切换选项卡”手势访问; 但是当平板电脑旋转到横向模式时(或者如果在具有足够宽屏幕的台式机上),屏幕会同时显示所有窗格,并在屏幕上并排显示。
图标请使用 View 而不是 ImageSource 类型。 我们想要显示通知(通常是选项卡图标顶角的小点)
图标请使用 View 而不是 ImageSource 类型。 我们想要显示通知(通常是选项卡图标顶角的小点)
@MhAllan我相信这可以使用 TabViewItem 属性 BadgeText、BadgeTextColor、BadgeTextColorSelected、BadgeBackgroundColor 和 BadgeBackgroundColorSelected 来完成。
我注意到 BadgeText 似乎列出了错误的类型,我确定它应该是 String,而不是 Bool。
@irongut ,感谢您的注意。 我认为这些也是错误的设计。 不应该有像 BadgeText 这样的东西。
如果我们考虑一个可以满足未来需求的框架,我们不应该限制开发人员使用 String 或 ImageSource 等类型。 如果这样做,那么我们很快就会遇到这样的问题:使徽章角变圆,使徽章变大,变小,阴影,左到图标,向上,向下,向右,在图标前面,在图标后面,动画......等等。人们会因为无法轻松自定义而感到沮丧。 写这篇文章,我目前正在制作一个通知徽章,它会在它稳定之前围绕 X 轴旋转两次。 看看定制有多奇怪?
@MhAllan Syncfusion 的 SfTabview 是一个很好的例子,它可以更动态地完成。
谢谢,但是当操作系统、编程语言和很棒的框架免费时,谁想看看水蛭的作品,这些作品以数千美元的价格出售。
我不是说使用Syncfusion。 只是想说,这是一个很好的例子,可以看到他们是如何做到的并激发他们的灵感。 除此之外,他们为个人客户提供免费服务,仅为收入超过 100 万的大公司付费。 相信我,它们比 Xamarin 本身领先 1-2 步。 我们甚至无法在这里获得合适的 Collection/ListView 数月、数年。
我同意 TabViewItem 作为一个整体应该或多或少只有一个 ContentView,我们可以将我们想要的任何视图放在选项卡项中。 目前这样做,限制了我们以您设想的方式实现选项卡视图,而不是我们想要的方式。 如果您想要一个具有默认外观的“易于使用”的选项卡视图,您只需创建一个SimpleTabItemView
类,人们可以将其用作他们的选项卡项目的视图,同时允许我们实现我们的通过我们自己的自定义视图拥有自己的外观和感觉。
我同意 TabViewItem 作为一个整体应该或多或少只有一个 ContentView,我们可以将我们想要的任何视图放在选项卡项中。 目前这样做,限制了我们以您设想的方式实现选项卡视图,而不是我们想要的方式。 如果您想要一个具有默认外观的“易于使用”的选项卡视图,您只需创建一个
SimpleTabItemView
类,人们可以将其用作他们的选项卡项目的视图,同时允许我们实现我们的通过我们自己的自定义视图拥有自己的外观和感觉。
我认为对稳定运行有一些限制是好的
我认为对稳定运行有一些限制是好的
您仍然可以使用默认的选项卡视图,以方便使用“稳定操作”。 没有理由限制整个视图。
这些现在正在转移到 Xamarin 社区工具包
最有用的评论
@irongut ,感谢您的注意。 我认为这些也是错误的设计。 不应该有像 BadgeText 这样的东西。
如果我们考虑一个可以满足未来需求的框架,我们不应该限制开发人员使用 String 或 ImageSource 等类型。 如果这样做,那么我们很快就会遇到这样的问题:使徽章角变圆,使徽章变大,变小,阴影,左到图标,向上,向下,向右,在图标前面,在图标后面,动画......等等。人们会因为无法轻松自定义而感到沮丧。 写这篇文章,我目前正在制作一个通知徽章,它会在它稳定之前围绕 X 轴旋转两次。 看看定制有多奇怪?