SIGN UP MEMBER LOGIN:    
ARTICLE

Brushes with Opacity Mask in WPF

Posted by Raj Kumar Articles | Learn .NET August 28, 2008
In this sample i will describe how to use Brushes with Opacity Mask in WPF(Windows Presentation Foundation).
Reader Level:
Download Files:
 

This articles describes that how to use brushes as Opacity Mask in WPF. All drawing group have Opacity property that affects the entire object evenly they also have an OpacityMask that can be used to apply custom opacity effects. This property uses the alpha channel value for the supplied Brush. The other channels of the brush content (Red, Green, or Blue) are ignored.

The most typical Brush for this purpose is an ImageBrush, which can be used for a variety of photo masking techniques such as vignettes. However, any defined Brush (such as LinearGradientBrush) can be used. All brushes require a Brush-derived object element to fill property element syntax in XAML, as shown in the XAML syntax earlier in this topic. 

<Window x:Class="WpfApplication7.Window1"

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

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

    Title="LinearGradientBrush with OpacityMask" Height="300" Width="300">

    <Window.Background>

        <LinearGradientBrush>

            <GradientStop Offset="0" Color="Red"></GradientStop>

            <GradientStop Offset="1" Color="Green"></GradientStop>

        </LinearGradientBrush>

    </Window.Background>

    <Button Margin="40" FontSize="80">RAJ

        <Button.OpacityMask>

            <LinearGradientBrush EndPoint="0.1,0.1" SpreadMethod="Reflect">

                <GradientStop Offset="0" Color="Gray"></GradientStop>

                <GradientStop Offset="1" Color="Transparent"></GradientStop>

            </LinearGradientBrush>

        </Button.OpacityMask>

    </Button>  

</Window>

 

Output looks like this:

Figure 1. A Button with LinearGradientBrush applied to OpacityMask

<Window x:Class="WpfApplication7.Window2"

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

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

    Title="Window2" Height="300" Width="300">

    <Grid>

        <Image Source="ais245a.jpg" Height="200">

            <Image.OpacityMask>

                <RadialGradientBrush Center="0.5,0.5">

                    <GradientStop Color="#00000000" Offset="1" />

                    <GradientStop Color="#20000000" Offset="0.8" />

                    <GradientStop Color="#FF000000" Offset="0" />

                </RadialGradientBrush>

            </Image.OpacityMask>

        </Image>

    </Grid>

</Window>

Output:

Figure 2. RadialGradientBrush applied to OpacityMask of an image

Login to add your contents and source code to this article
share this article :
post comment
 

think you!!!!!
my english is pool,so write here.

Posted by aleku Apr 10, 2010
6 Months Free & No Setup Fees ASP.NET Hosting!
Become a Sponsor
PREMIUM SPONSORS
  • Finally – a virtual platform that delivers next-generation Windows Server 2008 Hyper-V virtualization technology from a managed hosting partner you can truly depend on. Visit www.maximumasp.com/max for a FREE 30 day trial. Hurry offer ends soon. Climb aboard the MaxV platform and take advantage of High Availability, Intelligent Monitoring, Recurrent Backups, and Scalability – with no hassle or hidden fees. As a managed hosting partner focused solely on Microsoft technologies since 2000, MaximumASP is uniquely qualified to provide the superior support that our business is built on. Unparalleled expertise with Microsoft technologies lead to working directly with Microsoft as first to offer IIS 7 and SQL 2008 betas in a hosted environment; partnering in the Go Live Program for Hyper-V; and product co-launches built on WS 2008 with Hyper-V technology.
    Finally – a virtual platform that delivers next-generation Windows Server 2008 Hyper-V virtualization technology from a managed hosting partner you can truly depend on. Visit www.maximumasp.com/max for a FREE 30 day trial. Hurry offer ends soon. Climb aboard the MaxV platform and take advantage of High Availability, Intelligent Monitoring, Recurrent Backups, and Scalability – with no hassle or hidden fees. As a managed hosting partner focused solely on Microsoft technologies since 2000, MaximumASP is uniquely qualified to provide the superior support that our business is built on. Unparalleled expertise with Microsoft technologies lead to working directly with Microsoft as first to offer IIS 7 and SQL 2008 betas in a hosted environment; partnering in the Go Live Program for Hyper-V; and product co-launches built on WS 2008 with Hyper-V technology.
Nevron Gauge for SharePoint
Become a Sponsor