gpt4 book ai didi

c# - 在 WPF 中使用矢量图形作为图标

转载 作者:行者123 更新时间:2023-11-30 15:28:20 27 4
gpt4 key购买 nike

我的 MVVM 应用程序中的 MenuItems 有以下基类

public class StandardMenuItem : MenuItemBase, IExecutableItem
{
...
public Image Icon { get; private set; }
...
}

我最初的想法是使用 Image 来支持我在 MenuItems 上显示的图标。我现在已经到了我开始在我的应用程序前端使用这些 MenuItems 的地步,并且找到了一个我想使用的极好的矢量图形库。

<ResourceDictionary x:Class="resources_icons_xaml"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
<Canvas x:Key="appbar_acorn" Width="48" Height="48" Clip="F1 M 0,0L 48,0L 48,48L 0,48L 0,0">
<Path Width="22.3248" Height="25.8518" Canvas.Left="13.6757" Canvas.Top="11.4012" Stretch="Fill" Fill="{DynamicResource BlackBrush}" Data="F1 M 16.6309,18.6563C 17.1309,8.15625 29.8809,14.1563 29.8809,14.1563C 30.8809,11.1563 34.1308,11.4063 34.1308,11.4063C 33.5,12 34.6309,13.1563 34.6309,13.1563C 32.1309,13.1562 31.1309,14.9062 31.1309,14.9062C 41.1309,23.9062 32.6309,27.9063 32.6309,27.9062C 24.6309,24.9063 21.1309,22.1562 16.6309,18.6563 Z M 16.6309,19.9063C 21.6309,24.1563 25.1309,26.1562 31.6309,28.6562C 31.6309,28.6562 26.3809,39.1562 18.3809,36.1563C 18.3809,36.1563 18,38 16.3809,36.9063C 15,36 16.3809,34.9063 16.3809,34.9063C 16.3809,34.9063 10.1309,30.9062 16.6309,19.9063 Z "/>
</Canvas>
...
<ResourceDictionary/>

我的问题是,通过代码使用这些矢量图形似乎并不直接。我知道如何在 XAML 中包含此类图形

<!-- Include Resource Dictionary -->
<MenuItem Header="Show Difference Details"
ToolTip="Launch the grouped data file and analysis window."
IsEnabled="{Binding GroupedDataIsDifferent}"
Caliburn:Message.Attach="[Event Click] = [Action ShowDifferenceDetailsAsync()]">
<MenuItem.Icon>
<Rectangle Width="16" Height="16">
<Rectangle.Fill>
<VisualBrush Stretch="Uniform" Visual="{StaticResource appbar_column_two}" />
</Rectangle.Fill>
</Rectangle>
</MenuItem.Icon>
</MenuItem>

但这不是我的问题。我的问题是:

  1. 如何在我的 StandardMenuItem 的图标/图像中使用资源字典中的矢量图形?
  2. 如果 1. 的答案是“你不能”,我如何在代码中将矢量图形转换为 Icon

感谢您的宝贵时间。


编辑。我希望能够使用代码获取图形。所以对于我的菜单项,我有一个方法

public StandardMenuItem WithIcon(Assembly source, string path)
{
var manager = IoC.Get<IResourceManager>();
var iconSource = manager.GetBitmap(path, source.GetAssemblyName());
if (source != null)
{
IconSource = path;
}
return this;
}

我现在的问题是获得我想要的矢量图像的正确路径。假设在我的解决方案中,我在“Graphics/Icons.xaml”中有我的矢量图像,资源称为“appbar_acorn”,我如何引用它?

最佳答案

给你

首先将 Icon 属性更改为字符串

例如

public string Icon { get; private set; }

将图标值指定为您要使用的图标的键

Icon = "appbar_acorn";

在资源中定义转换器

<l:StringToResourceConverter x:Key="StringToResourceConverter" />

l:指转换器的命名空间,例如 xmlns:l="clr-namespace:CSharpWPF"

用法

<MenuItem Icon="{Binding Icon,Converter={StaticResource StringToResourceConverter}}"
Header="Menu"/>

结果

result

这是转换器类

namespace CSharpWPF
{
class StringToResourceConverter: IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return Application.Current.FindResource(value);
}

public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}
}

您可能需要调整 Canvas 上的图标大小和位置,在上面的示例中我删除了 Canvas.Left="13.6757"& Canvas.Top="11.4012" 但它仍然很小菜单图标很大

关于c# - 在 WPF 中使用矢量图形作为图标,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25947521/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com