2012-06-19 19 views
4

如何将XAML代码(代表一组形状)更改为由PATH提供的单个图形?XAML中从形状到路径的转换

比方说,我们有XAML代码,如:

<Ellipse Fill="#FF0A0A0E" HorizontalAlignment="Left" Margin="192,184,0,0" 
      Stroke="Black" Width="8" Height="8" VerticalAlignment="Top"/> 
    <Rectangle Fill="Black" HorizontalAlignment="Left" Margin="152,187.5,0,0" 
      Stroke="Black" Width="89.5" Height="1" VerticalAlignment="Top"/> 

,并需要将其转换成一个单一的路径对象?

我试图用混合4它允许你转换塑造成路径,但然后上面的代码转化为:

<Path Data="M7.5,4 C7.5,5.9329966 5.9329966,7.5 4,7.5 C2.0670034,7.5 0.5,5.9329966 0.5,4 C0.5,2.0670034 2.0670034,0.5 4,0.5 C5.9329966,0.5 7.5,2.0670034 7.5,4 z" 
     Fill="#FF0A0A0E" HorizontalAlignment="Left" Height="8" Margin="192,184,0,0" 
     Stretch="Fill" Stroke="Black" VerticalAlignment="Top" Width="8"/> 
<Path Data="M0.5,0.5 L89,0.5 z" Fill="Black" HorizontalAlignment="Left" Height="1" 
     Margin="152,187.5,0,0" Stretch="Fill" Stroke="Black" VerticalAlignment="Top" 
     Width="89.5" /> 

的原因,我提出这个问题,是因为我只可以定义只有一个路径。如我错了请纠正我。如果是这样,那么我怎样才能在一种风格中嵌入2个或更多路径?

回答

2

您可以通过按住Ctrl两种形状组合成一个Path与Expression Blend的4

要做到这一点,选择这两个奥姆或切换

enter image description here

之后,选择对象 - >合并 - >团结

而在你的情况下,它会输出这个

<Path Data="M44,0.5 C45.932995,0.50000024 47.5,2.0670036 47.5,4.0000002 L89,4.0000002 89,4.0100003 47.499496,4.0100003 47.48193,4.3578544 C47.302696,6.122751 45.812183,7.5000002 44,7.5000002 42.187817,7.5000002 40.697304,6.122751 40.51807,4.3578544 L40.500504,4.0100003 0.5,4.0100003 0.5,4.0000002 40.5,4.0000002 C40.5,2.0670036 42.067005,0.50000024 44,0.5 z" 
     Fill="Black" 
     HorizontalAlignment="Left" 
     Height="8" 
     Margin="152,184,0,0" 
     Stretch="Fill" 
     Stroke="Black" 
     VerticalAlignment="Top" 
     Width="89.5"/> 

请注意,如果矩形Height恰好为1,则存在此错误。然后它会消失。要解决这个刚刚成立Height喜欢的东西1.00001

<Rectangle Fill="Black" HorizontalAlignment="Left" Margin="152,187.5,0,0" 
     Stroke="Black" Width="89.5" Height="1.00001" VerticalAlignment="Top"/> 
+0

事实上,这是一个很大的帮助。谢谢!!! –

0

可以用一个数据字段来执行多个单独的路径。例如:

<Path Data="M0,0 L 10,10 L 20, 10 L 20,0 z M 100,5 L 110,15 L 120,15 L 120,5 z" 
     Stroke="Black" Fill="Red" /> 

但是,假设你想的一样FillStroke等两件,这是不是在你的榜样的情况。