Blue Theme Orange Theme Green Theme Red Theme
 
6 Months Free & No Setup Fees ASP.NET Hosting!
Home | Forums | Videos | Photos | Blogs | Beginners | Advertise with Us
 | Consulting  
Submit an Article Submit a Blog 
 Jump to
Skip Navigation Links
TechnologyExpand Technology
WebsiteExpand Website
6 Months Free & No Setup Fees ASP.NET Hosting!
Search :       Advanced Search »
Home » XAML » XAML ImageBrush

XAML ImageBrush

ImageBrush uses an image as fill color for the graphics objects. This article shows how to use images to fill graphics objects.

Author Rank :
Page Views : 18034
Downloads : 0
Rating :
 Rate it
Level : Beginner
   Print Read/Post comments Post a comment  Similar Articles  
   Email to a friend  Bookmark  Author's other articles  
 
Team Foundation Server Hosting
Become a Sponsor
 Tag Cloud
 Latest Jobs
More ... 
 Latest Interview Questions
More ... 

An image brush uses an image as fill color to fill graphics objects such as a recntagle, ellipse, and path. The <ImageBrush/> represents the image brush in XAML.  The BitmapSource property represents the image used to fill the brush.

The following code creates a brush with sunset.jpg. Once a brush is created, you can use it to fill graphics objects.

<ImageBrush BitmapSource="C:\sunset.jpg" />

For example, the following code fills a rectangle with an ImageBrush.

<Window xmlns="http://schemas.microsoft.com/winfx/avalon/2005"
  xmlns:x="
http://schemas.microsoft.com/winfx/xaml/2005">

  <Rectangle Width="200" Height="100" Stroke="Black" StrokeThickness="3"> 
      <Rectangle.Fill>
         <ImageBrush BitmapSource="C:\sunset.jpg" />
      </Rectangle.Fill>
  </Rectangle>

</Window>

The output looks like Figure 1.

Image 1. Rectangle filled with image brush.

The Stretch Enumeration

The Stretch enumeration specifies the stretch of the image. The Stretch attribute of ImageBrush is used to set the stretch of the brush. It has four values - None, Fill, Uniform, and UniformToFill.

None does not stretch image. The following code uses None stretch.

<Rectangle Width="200" Height="100" Stroke="Black" StrokeThickness="3"> 
 <Rectangle.Fill>
         <ImageBrush Stretch="None" BitmapSource="C:\ButterFly.jpg" />
 </Rectangle.Fill>
</Rectangle>

The output is a rectangle filled with original image size.

Fill fill image in the whole brush. The following code uses Fill stretch.

<Rectangle Width="200" Height="100" Stroke="Black" StrokeThickness="3"> 
 <Rectangle.Fill>
         <ImageBrush Stretch="Fill" BitmapSource="C:\ButterFly.jpg" />
 </Rectangle.Fill>
</Rectangle>

The output is a rectangle fully filled with the image.

Uniform fills brush with the native aspect ration. The following code uses Uniform stretch.

<Rectangle Width="200" Height="100" Stroke="Black" StrokeThickness="3"> 
 <Rectangle.Fill>
         <ImageBrush Stretch="Uniform" BitmapSource="C:\ButterFly.jpg" />
 </Rectangle.Fill>
</Rectangle>

The output is a rectangle filled with image but kept the original aspect ratio.

UniformToFill fills brush with the native aspect ration. The following code uses UniformToStretch stretch.

<Rectangle Width="200" Height="100" Stroke="Black" StrokeThickness="3"> 
 <Rectangle.Fill>
         <ImageBrush Stretch="UniformToFill" BitmapSource="C:\ButterFly.jpg" />
 </Rectangle.Fill>
</Rectangle>

The output is a rectangle filled with but also kept the original aspect ratio.

 

Comment Request!
Thank you for reading this post. Please post your feedback, question, or comments about this post Here.
Login to add your contents and source code to this article
 [Top] Rate this article
 
 About the author
 
Mahesh Chand
Mahesh is the founder of C# Corner and Mindcracker Network, an author of several .NET programming books and a Microsoft MVP for 6 consecutive years. In his day to day work, Mahesh is a Senior Software Consultant with over 14 years of IT industry experience building systems for Financial and Banking, Engineering & Architectural, Imaging, Construction, Biological & Pharmaceuticals, Healthcare and Education industries. His expertise is Windows Forms, ASP.NET, Silverlight, WPF, WCF, Visual Studio 2010, SQL Server, and Oracle.  If you are looking for a Sharepoint, Windows Forms, ASP.NET, WPF, Silverlight, C#, VB.NET, Oracle, and SQL Server Consultant in Philadelphia area or remote location, drop me a line at MAHESH [AT] C-SHARPCORNER [DOT] COM.
Looking for C# Consulting?
C# Consulting is founded in 2002 by the founders of C# Corner. Unlike a traditional consulting company, our consultants are well-known experts in .NET and many of them are MVPs, authors, and trainers. We specialize in Microsoft .NET development and utilize Agile Development and Extreme Programming practices to provide fast pace quick turnaround results. Our software development model is a mix of Agile Development, traditional SDLC, and Waterfall models.
Click here to learn more about C# Consulting.
 
Introducing MaxV - one click. infinite control. Hyper-V Hosting from MaximumASP.
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.
Dynamic PDF
ceTE software specializes in components for dynamic PDF generation and manipulation. The DynamicPDF™ product line allows you to dynamically generate PDF documents, merge PDF documents and new content to existing PDF documents from within your applications.
Nevron Chart for .NET 2010.1 Now Available
The leading .NET charting control now features PDF, Flash and Silverlight export, visualization of large datasets and more. Deliver true charting functionality to your BI, Scorecard, Presentation or Scientific apps. Download evaluation now.
ASP.NET 4 Hosting
Get 2 Months Free of ASP.NET Hosting for Only $4.95/month! Receive FREE MS SQL and MySQL Databases Including ASP.NET 4/3.5, MVC 3.0, Silverlight 4, Windows 2008/IIS 7.0 Plus FREE IIS 7 Modules. Host UNLIMITED ASP.NET Web Sites – Click Here!
 
 Post a Feedback, Comment, or Question about this article
Subject:
Comment:
Team Foundation Server Hosting
Become a Sponsor
 Comments
Image from XML by Viswanand On November 14, 2005

Hi Mahesh

I want to display in an image in XAML. How can I get the Image path from an XML file display it using Imagebrush

Regards

Viswanand

Reply | Email | Modify 
Re: Image from XML by Mahesh On November 15, 2005

Are you talking about XML or XAML? These both are two different things. To get a file name from an XML file, you need to load XML into some object say XmlDocument and using XmlDocument methods, you can get a particular node and its value. See XML section of C# Corner for more sample code on how to read XML documents in C#.

Reply | Email | Modify 
use the path of the picture that the user appointed to show the picture by yang On February 20, 2006

hello mahesh:

    First,i want to use XAML to set up a Image controler in UI,then use the path of the picture that the user appointed to show the picture in the Image controler which set up in the First.Please tell me how to realize this plan? Thank you!

Reply | Email | Modify 
use the path of the picture that the user appointed to show the picture by yang On February 20, 2006

VS2005 as empolder tool use C# and XAML.   First,i want to use XAML to set up a Image controler in UI,then use the path of the picture that the user appointed to show the picture in the Image controler which set up in the First.Please tell me how to realize this plan? Thank you!

Reply | Email | Modify 
How to use ImageBrush to create an image puzzle by Kiril On June 19, 2007
Let's say I have one image na 20 little rectangles on my root canvas. How to use ImageBrush in order to create an image puzzle. In other words, how to assign different parts of the image to different rectangles. When put together, the rectangles has to be able to display the initial image. Any help or suggestions would be greatly appreciated. Kiril
Reply | Email | Modify 
gollo by I got you On December 7, 2010

Good reading.

Reply | Email | Modify 
Team Foundation Server Hosting
 © 2012  contents copyright of their authors. Rest everything copyright Mindcracker. All rights reserved.