如何在UWP中为路径控制创建共享样式?

问题描述 投票:1回答:1

我有下一个XAML代码:

 <Grid>
    <Grid.Resources>
        <ResourceDictionary Source="Styles.xaml"/>
    </Grid.Resources>
    <StackPanel HorizontalAlignment="Center" VerticalAlignment="Center">
        <Path Style="{StaticResource UserIcon}"/>
        <Path Style="{StaticResource UserIcon}"/>
    </StackPanel>
</Grid>

Styles.xaml中的样式:

<Style x:Key="UserIcon"
       TargetType="Path">
    <Style.Setters>
        <Setter Property="Data" Value="M0 58l0 13 70 0 0 -12c-39,-33 -70,-1 -70,-1zm53 -40c0,-10 -8,-18 -18,-18 -9,0 -17,8 -17,18 0,9 8,17 17,17 10,0 18,-8 18,-17z" />
        <Setter Property="Fill" Value="Black"/>
    </Style.Setters>
</Style>

问题:样式只使用一次。第二个路径控件没有来自样式的数据,而在设计器(以及执行)中它看起来像this

c# xaml uwp .net-standard
1个回答
3
投票

我怀疑这里的问题是Data不是依赖属性的事实。我发现重用路径的唯一方法是仅将几何数据重用为一个简单的字符串:

<Page.Resources>
    <x:String x:Key="UserIconGeometry">M0 58l0 13 70 0 0 -12c-39,-33 -70,-1 -70,-1zm53 -40c0,-10 -8,-18 -18,-18 -9,0 -17,8 -17,18 0,9 8,17 17,17 10,0 18,-8 18,-17z</x:String>
</Page.Resources>
<StackPanel>
    <Path Data="{StaticResource UserIconGeometry}" Fill="Red" />
    <Path Data="{StaticResource UserIconGeometry}" Fill="Red" />
</StackPanel>

Properly rendering

© www.soinside.com 2019 - 2024. All rights reserved.