Fluent.Ribbon 禁用图标
Fluent.Ribbon disable icon
我正在使用 fluent:ToggleButton
,但我找不到如何禁用该图标。我不用它,因为它占了我没有的地方。
是否有禁用它的默认方法,或者我需要做一些特殊的事情?
这是我的解决方法:
从属性 Window 您可以将模板转换为新资源并删除 ContentPresenter x:Name="iconImage"
用法
<!--Tabs-->
<Fluent:RibbonTabItem Header="Tab">
<Fluent:RibbonGroupBox Header="Group">
<Fluent:ToggleButton Height="30" x:Name="buttonGreen" VerticalContentAlignment="Center"
VerticalAlignment="Top" Header="NoIcon" Template="{DynamicResource NoIconToggleButtonControlTemplate}" />
使用自动生成的资源(删除图标后)
<fluent:RibbonWindow.Resources>
<ControlTemplate x:Key="NoIconToggleButtonControlTemplate" TargetType="{x:Type fluent:ToggleButton}">
<Border x:Name="border" BorderBrush="{DynamicResource TransparentBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{DynamicResource TransparentBrush}" HorizontalAlignment="Left" Height="Auto" VerticalAlignment="Stretch">
<Grid Height="Auto">
<StackPanel x:Name="stackPanel" Orientation="Vertical" Width="Auto">
<fluent:TwoLineLabel x:Name="controlLabel" Focusable="False" HorizontalAlignment="Stretch" Margin="2,-3,2,1" Style="{DynamicResource TwoLineLabelStyle}" Text="{TemplateBinding Header}" VerticalAlignment="Stretch"/>
</StackPanel>
</Grid>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="Size" Value="Small">
<Setter Property="Orientation" TargetName="stackPanel" Value="Horizontal"/>
<Setter Property="Visibility" TargetName="controlLabel" Value="Collapsed"/>
<Setter Property="HasTwoLines" TargetName="controlLabel" Value="False"/>
<Setter Property="Margin" TargetName="controlLabel" Value="2,-2,2,2"/>
</Trigger>
<Trigger Property="Size" Value="Middle">
<Setter Property="Orientation" TargetName="stackPanel" Value="Horizontal"/>
<Setter Property="Width" TargetName="stackPanel" Value="Auto"/>
<Setter Property="HasTwoLines" TargetName="controlLabel" Value="False"/>
<Setter Property="Margin" TargetName="controlLabel" Value="2"/>
<Setter Property="VerticalAlignment" TargetName="border" Value="Stretch"/>
</Trigger>
<Trigger Property="IsPressed" Value="True">
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonPressedOuterBorderBrush}"/>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonPressedOuterBackgroundBrush}"/>
</Trigger>
<Trigger Property="IsChecked" Value="True">
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonCheckedBrush}"/>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonCheckedBrush}"/>
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Opacity" TargetName="controlLabel" Value="0.5"/>
</Trigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="IsMouseOver" Value="True"/>
<Condition Property="IsPressed" Value="False"/>
</MultiTrigger.Conditions>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonHoverOuterBackgroundBrush}"/>
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonHoverOuterBorderBrush}"/>
</MultiTrigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="IsMouseOver" Value="True"/>
<Condition Property="IsPressed" Value="False"/>
<Condition Property="IsChecked" Value="True"/>
</MultiTrigger.Conditions>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonHoverOuterBackgroundBrush}"/>
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonHoverOuterBorderBrush}"/>
</MultiTrigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</fluent:RibbonWindow.Resources>
我正在使用 fluent:ToggleButton
,但我找不到如何禁用该图标。我不用它,因为它占了我没有的地方。
是否有禁用它的默认方法,或者我需要做一些特殊的事情?
这是我的解决方法:
从属性 Window 您可以将模板转换为新资源并删除 ContentPresenter x:Name="iconImage"
用法
<!--Tabs-->
<Fluent:RibbonTabItem Header="Tab">
<Fluent:RibbonGroupBox Header="Group">
<Fluent:ToggleButton Height="30" x:Name="buttonGreen" VerticalContentAlignment="Center"
VerticalAlignment="Top" Header="NoIcon" Template="{DynamicResource NoIconToggleButtonControlTemplate}" />
使用自动生成的资源(删除图标后)
<fluent:RibbonWindow.Resources>
<ControlTemplate x:Key="NoIconToggleButtonControlTemplate" TargetType="{x:Type fluent:ToggleButton}">
<Border x:Name="border" BorderBrush="{DynamicResource TransparentBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{DynamicResource TransparentBrush}" HorizontalAlignment="Left" Height="Auto" VerticalAlignment="Stretch">
<Grid Height="Auto">
<StackPanel x:Name="stackPanel" Orientation="Vertical" Width="Auto">
<fluent:TwoLineLabel x:Name="controlLabel" Focusable="False" HorizontalAlignment="Stretch" Margin="2,-3,2,1" Style="{DynamicResource TwoLineLabelStyle}" Text="{TemplateBinding Header}" VerticalAlignment="Stretch"/>
</StackPanel>
</Grid>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="Size" Value="Small">
<Setter Property="Orientation" TargetName="stackPanel" Value="Horizontal"/>
<Setter Property="Visibility" TargetName="controlLabel" Value="Collapsed"/>
<Setter Property="HasTwoLines" TargetName="controlLabel" Value="False"/>
<Setter Property="Margin" TargetName="controlLabel" Value="2,-2,2,2"/>
</Trigger>
<Trigger Property="Size" Value="Middle">
<Setter Property="Orientation" TargetName="stackPanel" Value="Horizontal"/>
<Setter Property="Width" TargetName="stackPanel" Value="Auto"/>
<Setter Property="HasTwoLines" TargetName="controlLabel" Value="False"/>
<Setter Property="Margin" TargetName="controlLabel" Value="2"/>
<Setter Property="VerticalAlignment" TargetName="border" Value="Stretch"/>
</Trigger>
<Trigger Property="IsPressed" Value="True">
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonPressedOuterBorderBrush}"/>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonPressedOuterBackgroundBrush}"/>
</Trigger>
<Trigger Property="IsChecked" Value="True">
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonCheckedBrush}"/>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonCheckedBrush}"/>
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Opacity" TargetName="controlLabel" Value="0.5"/>
</Trigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="IsMouseOver" Value="True"/>
<Condition Property="IsPressed" Value="False"/>
</MultiTrigger.Conditions>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonHoverOuterBackgroundBrush}"/>
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonHoverOuterBorderBrush}"/>
</MultiTrigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="IsMouseOver" Value="True"/>
<Condition Property="IsPressed" Value="False"/>
<Condition Property="IsChecked" Value="True"/>
</MultiTrigger.Conditions>
<Setter Property="Background" TargetName="border" Value="{DynamicResource ButtonHoverOuterBackgroundBrush}"/>
<Setter Property="BorderBrush" TargetName="border" Value="{DynamicResource ButtonHoverOuterBorderBrush}"/>
</MultiTrigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</fluent:RibbonWindow.Resources>