ImageBox Control with Zoom/Pan Capability

Introduction
This control extends the capability of an ImageBox by including scrollbars to pan the image and a method for zooming
 the size of the image. My goal here is to show you two things:
- How to create your own controls that extend the System.Windows.Formscontrols.
- How to add zoom/pan capability to an image display in a simple fashion.
Creating the control
Using Microsoft Visual Studio .NET, the easiest way to create a control is to begin by right-clicking on the project and selecting "Add -> Add User Control".
The Zoom control was created by adding a GroupBox, TrackBar,
 and three Labels for the minimum zoom (25%), center zoom (100%) and maximum zoom (300%). I set the Anchor property
 of the GroupBox and TrackBar to
 "Right, Top, Left" so that resizing the window will resize the width of these controls. To keep the 100% Label aligned
 to the center of the GroupBox, I set the Anchor property
 to "Top".
The Image control with automatic scroll bars was created by dropping a Panel onto
 the control and sizing it to fill the remaining section of the control (below the Zoom control) and setting its Anchor property
 to "Left, Top, Right, Bottom" so that it will resize with the control. Set the AutoScroll property to "true".
 Finally, I dropped an ImageBox inside the panel with Location and 
 = 0,0SizeMode=StretchImage.
The properties must be set with AutoScroll=true and SizeMode=StretchImage in
 order for the zoom and scroll bars to work properly.
 Collapse | Copy
 Collapse | CopyCode
// zoom controls
private System.Windows.Forms.GroupBox groupBox1;
private System.Windows.Forms.TrackBar scrollZoom;
private System.Windows.Forms.Label lblMax;
private System.Windows.Forms.Label lblMin;
private System.Windows.Forms.Label lblCenter;
// image controls
private System.Windows.Forms.Panel imagePanel;
private System.Windows.Forms.PictureBox imgBox;
Developing the code
At this point it becomes very simple. By placing the ImageBox inside a Panel with AutoScroll=true,
 the Panel will automatically add scrollbars when the ImageBox size
 exceeds the size of the Panel. So, all you have to do is to add code to get or set the image and a little bit of code
 to control the zoom.
The image is set by adding a public property. In this case, I chose to make the property available at design
 time by setting Browsable(true).
 I also re-center the zoom scroll when a new image is loaded and disable the zoom scroll if the image is null.
 Finally, I set the size of the ImageBox equal to the size of the Image for
 a zoom factor of 100%.
As mentioned in the comments below by yfoulon, adding scrollZoom.Focus() should allow the use of mousewheel to zoom
 the image. (I don't have a mouse so I was unable to test this.)
 Collapse | Copy
 Collapse | CopyCode
[Browsable(true),
Description("Image loaded into the box.")]
public Image Image
{
get
{
return imgBox.Image;
}
set
{
// Set the image value
imgBox.Image = value; // enable the zoom control if this is not a null image
scrollZoom.Enabled = (value != null); if (scrollZoom.Enabled)
{
// reset zoom control
scrollZoom.Value = this.scrollZoom.Maximum/2; // Initially, the zoom factor is 100% so set the
// ImageBox size equal to the Image size.
imgBox.Size = value.Size;
}
else
{
// If null image, then reset the imgBox size
// to the size of the panel so that there are no
// scroll bars.
imgBox.Size = imagePanel.Size;
}
}
}
The zoom is handled with an EventHandler that calls a method when the user scrolls the zoom TrackBar.
 The zoom factor is currently a hard-coded array with 11 elements which is the same as the number of positions on the TrackBar(min
 = 0, center = 5, max = 10). The ImageBox is then resized by multiplying the Image size
 by the new zoom factor. Because the ImageBox's SizeMode is
 set to "StretchImage", the Image will
 be scaled to fit the new size of theImageBox.
 Collapse | Copy
 Collapse | CopyCode
private double[] zoomFactor =
{.25, .33, .50, .66, .80, 1, 1.25, 1.5, 2.0, 2.5, 3.0}; private void scrollZoom_Scroll(object sender,
System.EventArgs e)
{
setZoom();
} private void setZoom()
{
// The scrollZoom changed so reset the zoom factor
// based on the scrollZoom TrackBar position.
double newZoom = zoomFactor[scrollZoom.Value]; // Set the ImageBox width and height to the new zoom
// factor by multiplying the Image inside the Imagebox
// by the new zoom factor.
imgBox.Width =
Convert.ToInt32 ( imgBox.Image.Width * newZoom);
imgBox.Height =
Convert.ToInt32 ( imgBox.Image.Height * newZoom );
}
Additionally, I also added a KeyDown event handler and some code to allow the user to increase or decrease the zoom
 factor using the Ctrl+ and Ctrl- keys.
 Collapse | Copy
 Collapse | CopyCode
private void ImageBoxPanZoom_KeyDown(object sender, KeyEventArgs e)
{
// Was the key combination that was pressed Ctrl+ or Ctrl-?
// If so, then change the zoom level (but only if the zoom
// is enabled)
if (scrollZoom.Enabled)
{
// Note: The e.KeyData is the combination of all the
// keys currently pressed down. To find out if this is
// the Ctrl key *and* the + key, you "or" the Keys
// together. This is a bitwise "or" rather than the
// || symbol used for boolean logic. if((e.KeyData == (Keys.Oemplus | Keys.Control)) &&
(scrollZoom.Value != scrollZoom.Maximum))
{
scrollZoom.Value++;
setZoom();
}
else if ((e.KeyData == (Keys.OemMinus | Keys.Control)) &&
(scrollZoom.Value != scrollZoom.Minimum))
{
scrollZoom.Value--;
setZoom();
}
}
}
转自:http://www.codeproject.com/Articles/12331/ImageBox-Control-with-Zoom-Pan-Capability
ImageBox Control with Zoom/Pan Capability的更多相关文章
- iphone dev 入门实例6:How To Use UIScrollView to Scroll and Zoom and Page
		http://www.raywenderlich.com/10518/how-to-use-uiscrollview-to-scroll-and-zoom-content Getting Starte ... 
- Scroll Segmented Control(Swift)
		今天用了一个github上一个比较好用的Segmented Control但是发现不是我要效果,我需要支持scrollView.当栏目数量超过一屏幕,需要能够滑动. 由于联系作者没有回复,我就自己在其 ... 
- ZedGraph 柱状图、饼图、折线图演示源码
		http://code1.okbase.net/codefile/ZedGraphControl.ContextMenu.cs_201211225626_97.htm // //This librar ... 
- Pyhton开源框架(加强版)
		info:Djangourl:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 ... 
- Python开源框架
		info:更多Django信息url:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC) ... 
- 【Leafletjs】4.L.Map  中文API
		L.Map API各种类中的核心部分,用来在页面中创建地图并操纵地图. 使用 example // initialize the map on the "map" div with ... 
- 一个优秀的C#开源绘图软件 DrawTools
		1.Extensions to DrawTools Author Mark Miller I develop software for a leading healthcare system in N ... 
- Devexpress VCL Build v2015 vol 15.1.2发布
		2015年马上过半年了.终于第一个大版出来了. What's New in 15.1.2 (VCL Product Line) New Major Features in 15.1 What's ... 
- zedgraph控件的一些比较有用的属性 转
		(1)zedgraph控件属性具体解释: AxisChange()() ->> This performs an axis change command on the graphPane. ... 
随机推荐
- HDU 2553 N皇后问题【棋盘型DFS】
			N皇后问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submi ... 
- Codeforces 691C. Exponential notation
			题目链接:http://codeforces.com/problemset/problem/691/C 题意: 给你一个浮点数,让你把这个数转化为 aEb 的形式,含义为 a * 10b, 其中 a ... 
- 树形DP求树的最小支配集,最小点覆盖,最大独立集
			一:最小支配集 考虑最小支配集,每个点有两种状态,即属于支配集合或者不属于支配集合,其中不属于支配集合时此点还需要被覆盖,被覆盖也有两种状态,即被子节点覆盖或者被父节点覆盖.总结起来就是三种状态,现对 ... 
- SPOJ GSS2 - Can you answer these queries II(线段树 区间修改+区间查询)(后缀和)
			GSS2 - Can you answer these queries II #tree Being a completist and a simplist, kid Yang Zhe cannot ... 
- c程序设计语言 导言
			重在实践!! 1-10 P13 #include <stdio.h> int main() { int c; while((c = getchar()) != EOF) { ; if (c ... 
- 【bzoj1455】【罗马游戏】左偏树+并查集(模板)
			Description 罗马皇帝很喜欢玩杀人游戏. 他的军队里面有n个人,每个人都是一个独立的团.最近举行了一次平面几何测试,每个人都得到了一个分数. 皇帝很喜欢平面几何,他对那些得分很低的人嗤之以鼻 ... 
- 微服务之SpringCloud实战(三):SpringCloud Eureka高可用
			高可用Eureka 高可用我就不再过多解释了,Eureka Server的设计一开始就考虑了高可用的问题,在Eureka的服务治理设计中,所有的节点即是服务提供方也是消费方,注册中心也不例外,上一章中 ... 
- GetAdaptersInfo & GetAdaptersAddresses
			I use GetAdaptersInfo to get MAC addresses of interfaces. GetAdaptersInfo exist on old and new ver ... 
- 直接拿来用!最火的iOS开源项目(二)
			每一次的改变总意味着新的开始.”这句话用在iOS上可谓是再合适不过的了.GitHub上的iOS开源项目数不胜数,iOS每一次的改变,总会引发iOS开源项目的演变,从iOS 1.x到如今的iOS 7,有 ... 
- subprocess使用,进入到某个目录下执行shell命令
			subprocess是用来fork一个子进程的.这个子进程可以运行一个外部程序. 函数: subprocess.call() subprocess.check_output() subprocess. ... 
