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);

}

运行效果如下图所示:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值