zoukankan      html  css  js  c++  java
  • 2018-8-10-win10-uwp-使用-Geometry-resources-在-xaml

    title author date CreateTime categories
    win10 uwp 使用 Geometry resources 在 xaml
    lindexi
    2018-08-10 19:17:19 +0800
    2018-2-13 17:23:3 +0800
    Win10 UWP

    经常会遇到在 xaml 使用矢量图,对于 svg 的矢量图,一般都可以拿出来写在 Path 的 Data ,所以可以写为资源,但是写出来的是字符串,如何绑定 Geometry 到字符串资源?

    假如在资源写一个图片,看起来就是下面的代码

    <Page.Resources>
        <x:String x:Key="HomeIconGeometry">F1 M 24.0033,56.0078L 24.0033,38.0053L 22.0031,40.0056L 19.0027,35.0049L 38.0053,20.0028L 45.0063,25.5299L 45.0063,21.753L 49.0068,21.0029L 49.0068,28.6882L 57.008,35.0049L 54.0075,40.0056L 52.0073,38.0053L 52.0073,56.0078L 24.0033,56.0078 Z M 38.0053,26.9204L 27.0038,36.005L 27.0038,53.0074L 33.0046,53.0074L 33.0046,42.006L 43.006,42.006L 43.006,53.0074L 49.0068,53.0074L 49.0068,36.005L 38.0053,26.9204 Z</x:String>
    </Page.Resources>

    然后发现使用的是 string ,如果这时创建了一个用户控件,里面写了一个属性,请看代码

    public Geometry IconData
    {
        get { return (Geometry)GetValue(IconDataProperty); }
        set { SetValue(IconDataProperty, value); }
    }
    
    public static readonly DependencyProperty IconDataProperty = 
        DependencyProperty.Register(nameof(IconData), typeof(Geometry), typeof(Header), new PropertyMetadata(null);

    界面直接使用代码

    <local:Header x:Name="HeaderPanel" IconData="{StaticResource HomeIconGeometry}" />

    就会在运行出现无法从string转换,但是如何把用户控件改为 Path ,就可以运行

    那么如何在用户控件使用资源的字符串

    可以使用绑定,如果无法转换,可以写一个转换

    先创建一个转换类

    public class GeometryConvert : IValueConverter
    {
        public object Convert(object value, Type targetType, object parameter, string language)
        {
            if (value is string str)
            {
                var geometry = (Geometry) XamlReader.Load(
                    "<Geometry xmlns='http://schemas.microsoft.com/winfx/2006/xaml/presentation'>"
                    + str + "</Geometry>");
                return geometry;
            }
            return null;
        }
    
        public object ConvertBack(object value, Type targetType, object parameter, string language)
        {
            throw new NotImplementedException();
        }
    }

    然后在使用绑定的地方使用转换

    <local:GeometryConvert x:Key="GeometryConvert"></local:GeometryConvert>
    
    <local:Header x:Name="HeaderPanel" IconData="{Binding Source={StaticResource HomeIconGeometry},Converter={StaticResource GeometryConvert}}" />

    可以看到,这个方法可以显示图片

    所以,需要绑定字符串,可以使用这个方法。

    有人说,绑定到字符串可以不使用转换,他可以做到,直接使用绑定,但是我暂时没法

    https://stackoverflow.com/a/45142555/6116637

    博客园博客只做备份,博客发布就不再更新,如果想看最新博客,请到 https://blog.lindexi.com/

    知识共享许可协议
    本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。欢迎转载、使用、重新发布,但务必保留文章署名[林德熙](http://blog.csdn.net/lindexi_gd)(包含链接:http://blog.csdn.net/lindexi_gd ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我[联系](mailto:lindexi_gd@163.com)。
  • 相关阅读:
    careercup-C和C++ 13.6
    C++中名字隐藏,名字查找优先于类型检查
    careercup-C和C++ 13.5
    careercup-C和C++ 13.4
    careercup-C和C++ 13.3
    careercup-C和C++ 13.2
    careercup-C和C++
    careercup-排序和查找 11.7
    RMAN Catalog创建、配置和管理
    Linux一块网卡添加多个IP地址
  • 原文地址:https://www.cnblogs.com/lindexi/p/12086463.html
Copyright © 2011-2022 走看看