scatterview项目的四舍五入 - Microsoft Surface SDK

时间:2010-11-01 19:59:44

标签: wpf xaml pixelsense scatterview

我在scatterview项目上覆盖了一个图像。 scatterview项包含stackpanel和很少的文本块。在叠加并将主窗口的背景显示为透明时,我仍然可以看到与图像不能很好地融合的角落。

我使用surfaceusercontrol在scatterview中添加表面项。代码如下:

<s:SurfaceUserControl x:Class="Models.ModelItemControl"
  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:s="http://schemas.microsoft.com/surface/2008" Width="110" Background="Transparent">

  <Grid>
    <Grid.Background>
      <ImageBrush ImageSource="pack://application:,,,/Resources/models_card_150-01.png" Opacity="1.0" Stretch="Fill" />
    </Grid.Background>
    <Viewbox >
    <StackPanel MaxWidth="250" MinHeight="300">
    <TextBlock Name="ItemTitle" Margin="5,5,5,5" TextWrapping="Wrap" Visibility="Visible" Padding="2" />
    <Image Name="ItemImage" Margin="5,5,5,5"  Visibility="Visible" MaxHeight="100"/>
    <TextBlock Name="ItemDesc"  Margin="5,5,5,0" TextWrapping="Wrap" Visibility="Visible" Padding="2" />
    <s:SurfaceToggleButton Checked="ItemInfo_Checked" Unchecked="ItemInfo_Unchecked" Margin="5,0,5,0" HorizontalAlignment="Center" VerticalAlignment="Center">Display more info</s:SurfaceToggleButton>
    </StackPanel>
    </Viewbox>
    </Grid>
</s:SurfaceUserControl>

我想要一种方法将角切成圆形而不是矩形。

2 个答案:

答案 0 :(得分:1)

您看到的可能是ScatterViewItems阴影,而不是您的UserControl。您可以使用以下命令删除代码隐藏中的阴影:

item.ApplyTemplate();
item.Background = new SolidColorBrush(Colors.Transparent);
item.ShowsActivationEffects = false;
Microsoft.Surface.Presentation.Generic.SurfaceShadowChrome ssc;
ssc = item.Template.FindName("shadow", item) as Microsoft.Surface.Presentation.Generic.SurfaceShadowChrome;
ssc.Visibility = Visibility.Hidden;

这假定项目是您的ScatterViewItem。查看SDK中的ScatterViewPuzzle,了解如何为ScatterViewItem创建自定义形状。

答案 1 :(得分:0)

在MSDN上也发布了,答案的链接发布在下面:

Rounding corners of scatterview item-MSDN Forums