WPF中绘画和动画(4)

 接下来我们看一个VisualBrush的例子。为了简单起见,目标控件是一个Button,实际工作中换成复杂控件的效果也一样。程序的XAML代码如下:

<Window x:Class="WpfApplication1.Window2"

        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"

        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"

        Title="VisualBrush" Height="300" Width="400"Background="Orange">

    <Grid Margin="10">

        <Grid.ColumnDefinitions>

            <ColumnDefinition Width="160"/>

            <ColumnDefinition Width="*"/>

            <ColumnDefinition Width="160"/>

        </Grid.ColumnDefinitions>       

        <StackPanel x:Name="stackPanelLeft" Background="White">

            <Button x:Name="realButton" Content="OK" Height="40"/>

        </StackPanel>       

        <Button Content=">>>" Grid.Column="1" Margin="5,0" Click="Button_Click" />       

        <StackPanel x:Name="stackPanelRight" Background="White" Grid.Column="2"/>

    </Grid>

</Window>

中间Button的Click事件处理器代码如下:

doubleo=1.0; //不透明度计数器

 

        privatevoidButton_Click(objectsender, RoutedEventArgse)

        {

            VisualBrushvBrush=newVisualBrush(this.realButton);

            Rectanglerect=newRectangle();

            rect.Width=realButton.ActualWidth;

            rect.Height=realButton.ActualHeight;

            rect.Fill=vBrush;

            rect.Opacity=o;

            o-=0.2;

 

            this.stackPanelRight.Children.Add(rect);

        }

运行效果如下图所示:

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值