点击其他地方的时候不要关闭RadialMenu

时间:2021-07-12 03:30:55

原文:UWP Composition API - RadialMenu

用Windows 8.1的童鞋应该知道OneNote里面有一个RadialMenu。如下图,下图是WIn10应用Drawboard PDF的RadialMenu,Win8.1的机器欠好找了。哈哈,由于整个文章对照长,大家可以放《给我一首歌的时间》 边听边看。<风趣>

点击其他地方的时候不要关闭RadialMenu

从设计到开发包孕修复一些bug,概略用了不持续的2个月,想看源代码的童鞋可以先到 RadialMenu 检察效果和代码。

先放上项目里面的最终效果

点击其他地方的时候不要关闭RadialMenu

下面说下整个的过程

1.构造

首先,可以看到这个控件一个圆盘形状的东东,在点击子菜单的时候,菜单变革,并且带有duangduangduang的特效。

先来看看RadialMenu的ControlTemplate

<ControlTemplate TargetType="local:RadialMenu"> <!--<Popup x:Name="Popup" IsLightDismissEnabled="False" IsOpen="{TemplateBinding IsOpen}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch">--> <Grid x:Name="Root" Width="{TemplateBinding Width}" Height="{TemplateBinding Height}"> <Grid x:Name="ContentGrid"> <Ellipse Fill="{TemplateBinding Background}" StrokeThickness="{TemplateBinding ExpandAreaThickness}" VerticalAlignment="Stretch" HorizontalAlignment="Stretch"/> <local:RadialMenuItemsPresenter x:Name="CurrentItemPresenter" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" ItemsSource="{Binding CurrentItem.Items,RelativeSource={RelativeSource TemplatedParent}}" > <local:RadialMenuItemsPresenter.ItemsPanel> <ItemsPanelTemplate> <local:RadialMenuPanel/> </ItemsPanelTemplate> </local:RadialMenuItemsPresenter.ItemsPanel> </local:RadialMenuItemsPresenter> </Grid> <local:RadialMenuNavigationButton x:Name="NavigationButton" Width="{TemplateBinding RadialMenuNavigationButtonSize}" Height="{TemplateBinding RadialMenuNavigationButtonSize}" VerticalAlignment="Center" HorizontalAlignment="Center"/> </Grid> <!--</Popup>--> </ControlTemplate>

View Code

一共三个对象,

1)Ellipse -整个RadialMenu的外形以及配景

2)RadialMenuItemsPresenter-用来展示各个菜单

3)RadialMenuNavigationButton-中间阿谁导航的按钮

1,3应该对照好理解,大家看看代码就能大白。

我着重讲下2,这个也是开发一个自界说控件对照重要的操纵,就是知道怎么按本身的想法去构造。

RadialMenuItemsPresenter 担任ItemsControl,它的ItemsPanel是RadialMenuPanel。

<local:RadialMenuItemsPresenter x:Name="CurrentItemPresenter" ItemsSource="{Binding CurrentItem.Items,RelativeSource={RelativeSource TemplatedParent}}" > <local:RadialMenuItemsPresenter.ItemsPanel> <ItemsPanelTemplate> <local:RadialMenuPanel/> </ItemsPanelTemplate> </local:RadialMenuItemsPresenter.ItemsPanel> </local:RadialMenuItemsPresenter>

RadialMenuPanel 就是我们最重要控制怎么展示RadialMenuItemsPresenter 的Items。

重写过的Panel 同学必然知道MeasureOverride ,ArrangeOverride 这2个对象。如果不清楚的必然要去看看葡萄城控件技术团队的2篇文章 Measure,Arrange。看过之后你将对这2个要领有新的了解,对控件的构造越发清晰。

下面请看我优(丑)美(陋)的手画图

点击其他地方的时候不要关闭RadialMenu

A菜单将它Arrange到图中位置,B菜单也放到同样的位置,但是给它做必然的旋转。按做这种道理,把全部的菜单都Arrange到控件的中上位置,并且给他们都做必然的旋转,这样就构成了整个的圆弧,这个递增的角度就是 360°除以菜单的个数。

具体的代码,请看ArrangeChildren要领。

2.每个菜单的设计

RadialMenuItem -最根本的显示文字,图片等等

RadialColorMenuItem-用于显示颜色

RadialNumericMenuItem-用于显示数字,它的子集是RadialNumericMenuChildrenItem,是一个内部的类。

下来还是从我优(丑)美(陋)的手画图开始介绍布局吧

点击其他地方的时候不要关闭RadialMenu

蓝色的线是整个item的最外边,黄色是展开子菜单的按钮的中线。