请我需要在wpf中创建六角形菜单作为面板,但是我不知道如何创建面板为六角形 注意我需要创建它而不是绘制它。 感谢如何创建使用WPF的六角形菜单?
1
A
回答
3
尝试类似的东西:
<Window x:Class="HexagonMenu.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="MainWindow" Height="350" Width="525">
<Window.Resources>
<Style x:Key="ButtonFocusVisual">
<Setter Property="Control.Template">
<Setter.Value>
<ControlTemplate>
<Border>
<Rectangle
Margin="2"
StrokeThickness="1"
Stroke="#60000000"
StrokeDashArray="1 2"/>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<LinearGradientBrush x:Key="NormalBrush" StartPoint="0,0" EndPoint="0,1">
<GradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#FFF" Offset="0.0"/>
<GradientStop Color="#CCC" Offset="1.0"/>
</GradientStopCollection>
</GradientBrush.GradientStops>
</LinearGradientBrush>
<LinearGradientBrush x:Key="HorizontalNormalBrush" StartPoint="0,0" EndPoint="1,0">
<GradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#FFF" Offset="0.0"/>
<GradientStop Color="#CCC" Offset="1.0"/>
</GradientStopCollection>
</GradientBrush.GradientStops>
</LinearGradientBrush>
<LinearGradientBrush x:Key="LightBrush" StartPoint="0,0" EndPoint="0,1">
<GradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#FFF" Offset="0.0"/>
<GradientStop Color="#EEE" Offset="1.0"/>
</GradientStopCollection>
</GradientBrush.GradientStops>
</LinearGradientBrush>
<LinearGradientBrush x:Key="HorizontalLightBrush" StartPoint="0,0" EndPoint="1,0">
<GradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#FFF" Offset="0.0"/>
<GradientStop Color="#EEE" Offset="1.0"/>
</GradientStopCollection>
</GradientBrush.GradientStops>
</LinearGradientBrush>
<LinearGradientBrush x:Key="DarkBrush" StartPoint="0,0" EndPoint="0,1">
<GradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#FFF" Offset="0.0"/>
<GradientStop Color="#AAA" Offset="1.0"/>
</GradientStopCollection>
</GradientBrush.GradientStops>
</LinearGradientBrush>
<LinearGradientBrush x:Key="PressedBrush" StartPoint="0,0" EndPoint="0,1">
<GradientBrush.GradientStops>
<GradientStopCollection>
<GradientStop Color="#BBB" Offset="0.0"/>
<GradientStop Color="#EEE" Offset="0.1"/>
<GradientStop Color="#EEE" Offset="0.9"/>
<GradientStop Color="#FFF" Offset="1.0"/>
</GradientStopCollection>
</GradientBrush.GradientStops>
</LinearGradientBrush>
<SolidColorBrush x:Key="DisabledForegroundBrush" Color="#888" />
<SolidColorBrush x:Key="DisabledBackgroundBrush" Color="#EEE" />
<SolidColorBrush x:Key="WindowBackgroundBrush" Color="#FFF" />
<SolidColorBrush x:Key="SelectedBackgroundBrush" Color="#DDD" />
<Style TargetType="Button">
<Setter Property="SnapsToDevicePixels" Value="true"/>
<Setter Property="OverridesDefaultStyle" Value="true"/>
<Setter Property="FocusVisualStyle" Value="{StaticResource ButtonFocusVisual}"/>
<Setter Property="Height" Value="50"/>
<Setter Property="Width" Value="50"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Grid>
<Path x:Name="Hexagon" Stroke="Black" Stretch="Fill" Fill="{StaticResource NormalBrush}"
HorizontalAlignment="Stretch" VerticalAlignment="Stretch"
Width="{TemplateBinding Width}" Height="{TemplateBinding Height}"
Data="M8.660254,0 L17.320508,5 17.320508,15 8.660254,20 0,15 0,5 8.660254,0 z"/>
<TextBlock Text="{Binding Path=Content, RelativeSource={RelativeSource Mode=TemplatedParent}}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="true">
<Setter TargetName="Hexagon" Property="Fill" Value="{StaticResource DarkBrush}" />
</Trigger>
<Trigger Property="IsPressed" Value="true">
<Setter TargetName="Hexagon" Property="Fill" Value="{StaticResource PressedBrush}" />
</Trigger>
<Trigger Property="IsEnabled" Value="false">
<Setter TargetName="Hexagon" Property="Fill" Value="{StaticResource DisabledBackgroundBrush}" />
<Setter Property="Foreground" Value="{StaticResource DisabledForegroundBrush}"/>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Window.Resources>
<DockPanel>
<WrapPanel x:Name="MyHexagonMenu" DockPanel.Dock="Top">
<Button Content="File" />
<Button Content="Edit" />
<Button Content="About" />
<Button Content="Exit" />
</WrapPanel>
</DockPanel>
</Window>
+0
在此先感谢 – 2012-07-14 18:10:38
1
相关问题
- 1. 如何创建矩形背景的六角形?
- 2. 创建一个三维六角形图
- 3. 在六角形网格中创建六角形按钮的最佳方式
- 4. 如何创建径向菜单在WPF
- 5. 如何设置使用Javascript和六角形瓷砖的六角形地图?
- 6. 如何使用JavaFX创建三角形?
- 7. 如何使用AngularJS创建基于角色的动态菜单
- 8. 如何使用openGL在窗口左上角创建菜单
- 9. 如何在iPhone/iPad上创建六角形
- 10. 如何在famo.us中创建六角形自定义曲面
- 11. 如何为Google地图嵌入创建六角形iFrame?
- 12. 使用jQuery绘制六角形形状
- 13. 如何使用css创建颜色全角圆角导航菜单
- 14. 如何使用JSF创建菜单栏和子菜单
- 15. 如何使用子菜单创建下拉菜单?
- 16. 如何使用子菜单创建浮动菜单
- 17. 如何使用MVC创建菜单/子菜单?
- 18. 如何创建Android应用一个圆形的中央菜单
- 19. 使用MvcSiteMapProvider创建菜单
- 20. 需要建议:如何使用C#(WPF/WinForms)创建全局菜单栏?
- 21. html中的六角形单元格
- 22. 如何用角度js创建响应菜单?
- 23. 如何在WPF中创建类似于Windows 7开始菜单的菜单
- 24. 在WPF中创建一个菜单栏?
- 25. WPF创建窗口弹出菜单
- 26. 绘制六角形使用Java错误
- 27. 如何创建与左侧用WPF标签的一个简单的菜单?
- 28. 如何用Java中的子菜单创建弹出式菜单
- 29. WPF中上下文菜单的圆角矩形
- 30. 非空六边形的六角中心
你有什么试过?也许从[这个问题]开始(http://stackoverflow.com/questions/1443598/creating-grid-of-hexagons),看看你可以做什么,一旦你创建六边形控件? – 2012-07-14 17:31:29
不是这样,它是谈论绘图我需要创建它作为面板。 – 2012-07-14 17:41:08
你能解释一下你想在六角形中控制吗? – ethicallogics 2012-07-14 17:57:02