Blue Theme Orange Theme Green Theme Red Theme
 
Nevron Chart
Home | Forums | Videos | Advertise | Certifications | Downloads | Blogs | Interviews | Jobs | Beginners | Training
 | Consulting  
Submit an Article Submit a Blog 
 Jump to
Skip Navigation Links
TechnologyExpand Technology
WebsiteExpand Website
DevExpress UI Controls
Search :       Advanced Search »
Home » GDI+ & Graphics » Image Transformation in C# with GDI+

Image Transformation in C# with GDI+

Image transformation is exactly the same as any other transformation process. In this section we will see how to rotate, scale, translate, reflect, and shear images.

Author Rank :
Page Views : 93523
Downloads : 2022
Rating :
 Rate it
Level : Beginner
   Print Read/Post comments Post a comment  Similar Articles  
   Email to a friend  Bookmark  Author's other articles  
Download Files:
ImageTransformationSamp.zip
 
 
DevExpress Free UI Controls
Become a Sponsor
6 Months Free & No Setup Fees ASP.NET Hosting!
Become a Sponsor
 Tag Cloud
 Latest Jobs
More ... 
 Latest Interview Questions
More ... 

Image transformation is exactly the same as any other transformation process. In this section we will see how to rotate, scale, translate, reflect, and shear images. We will create a Matrix object, set the transformation process by calling its methods, set the Matrix object as the Transform property or the transformation methods of the Graphics object, and call DrawImage.

Rotating images is similar to rotating other graphics. Listing 10.16 rotates an image. We create a Graphics object using the CreateGraphics method. Then we create a Bitmap object from a file and call the DrawImage method, which draws the image on the form. After that we create a Matrix object, call its Rotate method, rotate the image by 30 degrees, and apply the resulting matrix to the surface using the Transform property. Finally, we draw the image again using DrawImage.

Listing 10.16: Rotating images

private void RotationMenu_Click(object sender, System.EventArgs e)
{
Graphics g =
this
.CreateGraphics();
g.Clear(
this
.BackColor);
Bitmap curBitmap =
new
Bitmap(@"roses.jpg");
g.DrawImage(curBitmap, 0, 0, 200, 200);
// Create a Matrix object, call its Rotate method,
// and set it as Graphics.Transform
Matrix X = new
Matrix();
X.Rotate(30);
g.Transform = X;
// Draw image
g.DrawImage(curBitmap,
new
Rectangle(205, 0, 200, 200),
0, 0, curBitmap.Width,
curBitmap.Height,
GraphicsUnit.Pixel) ;
// Dispose of objects
curBitmap.Dispose();
g.Dispose();
}

Figure 10.17 shows the output from Listing 10.16. The first image is the original; the second image is rotated.

Now let's apply other transformations. Replacing the Rotate method in Listing 10.16 with the following line scales the image:

X.Scale(2, 1, MatrixOrder.Append);

The scaled image is shown in Figure 10.18.

Replacing the Rotate method in Listing 10.16 with the following line translates the image with 100 offset in the x- and y-directions:

X.Translate(100, 100);

The new output is shown in Figure 10.19.



Replacing the Rotate method in Listing 10.16 with the following line shears the image:

X.Shear(2, 1);

The new output is shown in Figure 10.20.

You have probably noticed that image transformation is really no different from the transformation of other graphics objects. I recommend that you download the source code samples from the book's Web site to see the detailed code listings.

This articles is taken from Chapter 10 "Transformations" of
Graphics Programming with GDI+.

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.
Discover the top 5 tips for understanding .NET
Ricky Leeks presents the top 5 tips for understanding .NET Interoperability. Learn more.
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
Transform image to trapezoid by Eric On March 22, 2006

Hi,

I am developping a control in which I must transform an image.

I want my image to take the trapezoid form (not parallelogram).

Do you have a solution to suggest me?

 

Thanks.

 

Regards

Reply | Email | Modify 
Re: Transform image to trapezoid by Rany On February 13, 2008

Hi Eric,

I have encountered a similar problem where I need to transform an image to take the form of a trapeze.  If you've found a solution for this, I'd appreciate it if you could post or send it to me.

Thanks,

Rany

Reply | Email | Modify 
image clustering by fathima On February 2, 2009
Hi, i am doing my final year project in image processing. Can u help me, how to cluster the input image. Thanking you.
Reply | Email | Modify 
Re: image clustering by Mahesh On April 6, 2009
Please post your questions on C# Corner forums.
Reply | Email | Modify 
hi by Robert On November 3, 2009
Improve ur code to repaint the image, because now image disappears on minimize or when losing focus.
Reply | Email | Modify 
Re: hi by Mahesh On November 4, 2009
On your Form's paint event handler, just call this code. That will make sure the form is repainted.
Reply | Email | Modify 
dragging an image by Abraham On June 21, 2010
Hi, I have a panel on my windows forms that displays an image from a file. I am using GDI+'s Image.FromFile(..) method to read the image. 
The thing is, when I zoom the image some part of the image goes out of the my panel area. And when I zoom out  the image part of the image that has been clipped becomes visible. What I wanted to do is, to use a mouse to drag the image as if it was floating on top of the panel. I will drag the image and bring part of the image that have been hidden to be visible.  How can I do that? I don't want to use scroll bars and I have turned them off deliberately. 

Thanks in advance.
Reply | Email | Modify 
showing clipped parts of an image GDI+ by Abraham On June 21, 2010
Hi, I have a panel on my windows forms that displays an image from a file. I am using GDI+'s Image.FromFile(..) method to read the image. 
The thing is, when I zoom the image some part of the image goes out of the my panel area. And when I zoom out  the image part of the image that has been clipped becomes visible. What I wanted to do is, to use a mouse to drag the image as if it was floating on top of the panel. I will drag the image and bring part of the image that have been hidden to be visible.  How can I do that? I don't want to use scroll bars and I have turned them off deliberately. 

Thanks in advance.
Reply | Email | Modify 
memory game by alvaro On October 2, 2010
in English

hello my name is alvaro javier, I'm from Colombia, and I'm doing some work in C #, but so far I'm Starting at use in environment C #, and I need to make a game that is to make a memory game,
my question is for how to make my images that are a picturebox, has barias face, for example:

is in a state that all displayed the same image, and click, turn and show if the image is hidden behind it, and when you click over and lick it, but if the images are turned are not the same to return to normal, but if they become equal to be erased, or appear opaque,,,

aga Pungo them play my part I have in C # 2010, I hope I can help prompt response to my email, youtube.182 @ hotmail.com

thanks

PS: if I answer in Spanish puedesn aagradeseria them

http://www.gigasize.com/get.php?d=qt6drw1jm2c
Reply | Email | Modify 
Hi,everyone by sarahG On October 4, 2010
I have an assignment of doing these image transformations without using the built in functions like : "x.shear(1,2);" I want the algorithms of these transformations so I can do it myself .... thank in advance
Reply | Email | Modify 
Re: Hi,everyone by Mahesh On November 7, 2010
Search this site for shear. I think I have a sample.
Reply | Email | Modify 
img by lenny On January 14, 2011
thanx it's useful
Reply | Email | Modify 
help in a analog clock in c sharp 2005 by ENRIQUE On July 15, 2011
Hi, I need help making an analog clock in c # 2005. I create 3 hands, that of the hour, minute and second. these are within a circle. In fact, I drew on the form. how hard is to rotate 360 degrees clockwise, in the case of seconds, then turn the minute hand and finally the time. I hope I can help, thank you very much.
Reply | Email | Modify 
Nevron Chart
 © 2012  contents copyright of their authors. Rest everything copyright Mindcracker. All rights reserved.