How to zoom an image in C#
By FoxLearn 1/9/2025 8:49:48 AM 15.24K
With C#, you can easily implement image zoom functionality using a PictureBox
control and a few simple methods. This article demonstrates how to zoom an image dynamically based on user input, such as adjusting a TrackBar
for scaling the image.
How to Zoom an Image Using PictureBox in C#?
Open Visual Studio, then click New Project, then select Visual C# on the left, then Windows and then select Windows Forms Application. Name your project "ImageZoom" and then click OK
Drag and drop the Label, TextBox, Button, PictureBox, and TrackBar control from the Visual Toolbox onto your form desinger, then design your form as shown below.
The user can load an image by clicking the btnOpen button. This opens a file dialog, allowing them to select a JPEG image, which is then displayed in the PictureBox.
private void btnOpen_Click(object sender, EventArgs e) { //Open image using (OpenFileDialog ofd = new OpenFileDialog() { Multiselect = false, ValidateNames = true, Filter = "JPEG|*.jpg" }) { if (ofd.ShowDialog() == DialogResult.OK) { pictureBox1.Image = Image.FromFile(ofd.FileName); imgOriginal = pictureBox1.Image; } } }
The zoom functionality is controlled by a TrackBar
. As the user moves the slider, the trackBar1_Scroll
event is triggered, and the image is resized according to the current value of the slider.
// zoom in picturebox c# private void trackBar1_Scroll(object sender, EventArgs e) { if (trackBar1.Value > 0) { // picturebox c# zoom image pictureBox1.Image = Zoom(imgOriginal, new Size(trackBar1.Value, trackBar1.Value)); } }
The Zoom
method takes the original image and a Size
object, which is based on the TrackBar
value. The new size is calculated by adding a percentage of the image's width and height. The zoom is applied using the Graphics
class to ensure the image scaling looks smooth and maintains its visual quality.
// c# zoom image file Image Zoom(Image img, Size size) { Bitmap bmp = new Bitmap(img, img.Width + (img.Width * size.Width / 100), img.Height + (img.Height * size.Height / 100)); Graphics g = Graphics.FromImage(bmp); g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.HighQualityBicubic; return bmp; }
The use of HighQualityBicubic
interpolation mode ensures that the zoomed image maintains high visual quality, reducing the distortion often seen with simple scaling.
The Form1_FormClosing
event ensures that the image resource is properly disposed of when the form is closed, preventing memory leaks.
private void Form1_FormClosing(object sender, FormClosingEventArgs e) { if (pictureBox1.Image != null) pictureBox1.Dispose(); }
Add code to button click event handler as below
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; namespace ImageZoom { public partial class Form1 : Form { Image imgOriginal; public Form1() { InitializeComponent(); } } }
This simple yet powerful C# application demonstrates how to create a dynamic image zoom feature using a PictureBox
and a TrackBar
.
VIDEO TUTORIAL
- How to Create a custom Progress Bar with Percentage in C#
- How to update UI from another thread in C#
- How to Create a Wait Form Dialog in C#
- How to Get all Forms and Open Form with Form Name in C#
- How to use Advanced Filter DataGridView in C#
- How to Print DataGridView with Header & Footer with Landscape in C#
- How to Add Combobox to DataGridView in C#
- How to Hide a WinForm in C#