C#和Halcon交互实现图片的放大和缩小
【转载】 C#和halcon实现图片的放大和缩小
e.Delta>0表示鼠标向上滚动,e.Delta<0表示向下滚动
要拖动的图像为Measure.currentImageL,可以更换。
#region 鼠标实现放大缩小,移动图片
//鼠标滚动事件:实现放大和缩小图像
private void WinHandle_HMouseWheel(object sender, HalconDotNet.HMouseEventArgs e)
{
try
{
HWindowControl WinHandle = sender as HWindowControl;
HObject ho_currentImage = null;
HOperatorSet.GenEmptyObj(out ho_currentImage);
if (WinHandle.Name == "WinHandle_Left")
{
ho_currentImage = Measure.ho_CurrentImageL;
}
if (WinHandle.Name == "WinHandle_Right")
{
ho_currentImage = Measure.ho_CurrentImageR;
}
//放大倍数,当前鼠标选择的图像点坐标Row, Col,按下鼠标的左键还是右键:o-没按下,1-左键,2-中键,4-右键
HTuple Zoom, Row, Col, Button;
HTuple RowLeftUpper, ColumnLeftUpper, RowRightLower, ColumnRightLower, Ht, Wt, ImagePartRowLeftUp, ImagePartColLeftUp, ImagePartRowRightLow, ImagePartColRightLow;
//鼠标向上滚动表示放大
if (e.Delta > 0)
{
Zoom = 1.5;
}
//向下滚动缩小
else
{
Zoom = 0.5;
}
//返回输出窗口中鼠标指针和鼠标按钮所按下的像素精确图像坐标,输出当前鼠标指针点的图像坐标以及按下的是鼠标左键还是右键,0是鼠标左键
HOperatorSet.GetMposition(WinHandle.HalconWindow, out Row, out Col, out Button);
//Get part返回窗口中显示的图像部分的左上角和右下角 //得到当前的窗口坐标,Row0:图像部分左上角的行索引,Column0:图像部分左上角的列索引,Row00:图像部分右下角的行索引,Column00:图像部分右下角的列索引
HOperatorSet.GetPart(WinHandle.HalconWindow, out RowLeftUpper, out ColumnLeftUpper, out RowRightLower, out ColumnRightLower);
//显示的部分图像的高
Ht = RowRightLower - RowLeftUpper;
//显示的部分图像的宽
Wt = ColumnRightLower - ColumnLeftUpper;
//普通版halcon能处理的图像最大尺寸是32K*32K。如果无限缩小原图像,导致显示的图像超出限制,则会造成程序崩溃
if (Ht * Wt < 32000 * 32000 || Zoom == 1.5)
{
//显示的放大或者缩小部分图像的左上角和右下角坐标
ImagePartRowLeftUp = (RowLeftUpper + ((1 - (1.0 / Zoom)) * (Row - RowLeftUpper)));
ImagePartColLeftUp = (ColumnLeftUpper + ((1 - (1.0 / Zoom)) * (Col - ColumnLeftUpper)));
ImagePartRowRightLow = ImagePartRowLeftUp + (Ht / Zoom);
ImagePartColRightLow = ImagePartColLeftUp + (Wt / Zoom);
//设置部分显示图像
HOperatorSet.SetPart(WinHandle.HalconWindow, ImagePartRowLeftUp, ImagePartColLeftUp, ImagePartRowRightLow, ImagePartColRightLow);
HOperatorSet.ClearWindow(WinHandle.HalconWindow);
if (ho_currentImage != null)
{
HOperatorSet.DispObj(ho_currentImage, WinHandle.HalconWindow);
}
}
}
catch (Exception)
{ }
} //【1】鼠标按下,准备拖动图像
private void WinHandle_HMouseDown(object sender, HalconDotNet.HMouseEventArgs e)
{
HWindowControl WinHandle = sender as HWindowControl;
if (WinHandle.Name == "WinHandle_Left")
{
if (Measure.ho_CurrentImageL == null)
{
return;
}
}
if (WinHandle.Name == "WinHandle_Right")
{
if (Measure.ho_CurrentImageR == null)
{
return;
}
}
HTuple Row, Column, Button;
//返回鼠标当前按下点的图像坐标
HOperatorSet.GetMposition(WinHandle.HalconWindow, out Row, out Column, out Button);
RowDown = Row; //鼠标按下时的行坐标
ColDown = Column; //鼠标按下时的列坐标
} //【2】鼠标移动,开始拖动图像
private void WinHandle_HMouseMove(object sender, HMouseEventArgs e)
{
try
{
HWindowControl WinHandle = sender as HWindowControl;
HObject ho_currentImage = null;
HOperatorSet.GenEmptyObj(out ho_currentImage);
if (WinHandle.Name == "WinHandle_Left")
{
ho_currentImage = Measure.ho_CurrentImageL;
}
if (WinHandle.Name == "WinHandle_Right")
{
ho_currentImage = Measure.ho_CurrentImageR;
}
HTuple Row = new HTuple(), Column = new HTuple(), Button = new HTuple(), pointGray = new HTuple();
HTuple hv_Width = new HTuple();
HTuple hv_Height = new HTuple();
if (ho_currentImage != null)
{
HOperatorSet.GetImageSize(ho_currentImage, out hv_Width, out hv_Height);
}
//bug
HOperatorSet.GetMposition(WinHandle.HalconWindow, out Row, out Column, out Button);
////获取当前鼠标的坐标值
if (hv_Height != null && (Row > 0 && Row < hv_Height) && (Column > 0 && Column < hv_Width))//设置3个条件项,防止程序崩溃。
{
HOperatorSet.GetGrayval(ho_currentImage, Row, Column, out pointGray); //获取当前点的灰度值
}
else
{
pointGray = "_";
}
String str = String.Format("Row:{0} Column:{1} Gray:{2}", Row, Column, pointGray);
ts_Grval.Text = str;
}
catch (HalconException )
{ } } //【3】鼠标抬起,完成拖动图像
private void WinHandle_HMouseUp(object sender, HalconDotNet.HMouseEventArgs e)
{
try
{
HWindowControl WinHandle = sender as HWindowControl;
HObject ho_currentImage = null;
HOperatorSet.GenEmptyObj(out ho_currentImage);
if (WinHandle.Name == "WinHandle_Left")
{
ho_currentImage = Measure.ho_CurrentImageL;
}
if (WinHandle.Name == "WinHandle_Right")
{
ho_currentImage = Measure.ho_CurrentImageR;
}
HTuple row1, col1, row2, col2, Row, Column, Button;
////获取当前鼠标的坐标值
HOperatorSet.GetMposition(WinHandle.HalconWindow, out Row, out Column, out Button);
double RowMove = Row - RowDown; //鼠标弹起时的行坐标减去按下时的行坐标,得到行坐标的移动值
double ColMove = Column - ColDown;//鼠标弹起时的列坐标减去按下时的列坐标,得到列坐标的移动值
//得到当前的窗口坐标
HOperatorSet.GetPart(WinHandle.HalconWindow, out row1, out col1, out row2, out col2);
//移动后的左上角和右下角坐标,这里可能有些不好理解。以左上角原点为参考点
HOperatorSet.SetPart(WinHandle.HalconWindow, row1 - RowMove, col1 - ColMove, row2 - RowMove, col2 - ColMove);
HOperatorSet.ClearWindow(WinHandle.HalconWindow);
if (ho_currentImage!=null)
HOperatorSet.DispObj(ho_currentImage, WinHandle.HalconWindow);
}
catch (Exception)
{
} }
#endregion
原图显示
private void btn_FullWindowLeft_Click(object sender, EventArgs e)
{
HOperatorSet.SetPart(WinHandle_Left.HalconWindow, 0, 0, measure.hv_HeightL - 1, measure.hv_WidthL - 1);
HOperatorSet.ClearWindow(WinHandle_Left.HalconWindow);
HOperatorSet.DispObj(Measure.ho_CurrentImageL, WinHandle_Left.HalconWindow);
if (Measure.ho_CurrentImageL != null)
HOperatorSet.DispObj(Measure.ho_CurrentImageL, WinHandle_Left.HalconWindow);
} private void btn_FullWindowRight_Click(object sender, EventArgs e)
{
HOperatorSet.SetPart(WinHandle_Right.HalconWindow, 0, 0, measure.hv_HeightR - 1, measure.hv_WidthR - 1);
HOperatorSet.ClearWindow(WinHandle_Right.HalconWindow);
HOperatorSet.DispObj(measure.ho_ImageRectifiedR, WinHandle_Right.HalconWindow);
HOperatorSet.DispObj(Measure.ho_CurrentImageR, WinHandle_Right.HalconWindow);
if (Measure.ho_CurrentImageR != null)
HOperatorSet.DispObj(Measure.ho_CurrentImageR, WinHandle_Right.HalconWindow);
}
C#和Halcon交互实现图片的放大和缩小的更多相关文章
- Android------实现图片双击放大,缩小,左右滑动的多种方式
项目中常常有图片浏览功能.像微信朋友圈图片浏览,QQ空间照片浏览 的功能. 实现图片双击放大,缩小,左右滑动等效果. 来看看我的效果图,希望能满足你的要求 前三个button按钮是参考网上的多种实 ...
- 实例讲解如何利用jQuery设置图片居中放大或者缩小
大家有没有见过其他网站的图片只要鼠标放上去就能放大,移出去的时候就能缩小,而且一直保持居中显示!其实jQuery提供一个animate函数可以使图片放大和缩小,只要改变图片的长和高就OK啦!但是ani ...
- 使用JavaScript 中的Math对象和勾股定理公式,计算鼠标的位置与页面图片中心点的距离,根据距离对页面上的图片进行放大或缩小处理。距离远时图片放大,距离近时图片缩小
查看本章节 查看作业目录 需求说明: 使用JavaScript 中的Math对象和勾股定理公式,计算鼠标的位置与页面图片中心点的距离,根据距离对页面上的图片进行放大或缩小处理.距离远时图片放大,距离近 ...
- 通过Java代码实现图片的放大和缩小
本文介绍的例子在Android安卓手机上测试通过. 先看看效果吧.可以看到这个开发好的安卓应用有三个按钮:Zoom In缩小图片,Zoom Out放大图片和Save保存. 初始页面: 可以在左边边框自 ...
- JS图片的放大与缩小
<!doctype html><head><meta charset=utf-8" /><title>javascript控制图片缩小或者放大 ...
- JavaScript特效之图片特效放大,缩小,旋转
效果图如下: 效果代码如下: <!doctype html> <html lang="en"> <head> <meta charset= ...
- js 实现图片的放大和缩小
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- [Swift通天遁地]三、手势与图表-(3)通过捏合手势放大和缩小图像视图
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- Java界面程序实现图片的放大缩小
Java界面程序实现图片的放大缩小.这个程序简单地实现了图片的打开.保存.放大一倍.缩小一倍和固定缩放尺寸,但是并没有过多的涵盖对图片的细节处理,只是简单地实现了图片大小的放缩. 思维导图如下: 效果 ...
随机推荐
- 第七十七篇:ref引用(在vue中引用组件实例)
好家伙, 为方便理解, 我们先来写一个经典自增一按钮, 再加上一个count清零按钮, Left.vue组件中: <template> <div > <h1>我是L ...
- 第五十篇: webpack中的loader(一) --css-loader
好家伙, 1.webpack配置中devServer节点的常用配置项 devServer:{ //首次打包完成后,自动打开浏览器 open:ture, //在http协议中,如果端口号是80,则可以被 ...
- Shell第四章《正则表达式》
一.前言 1.1.名词解释 正则表达式(regular expression, RE)是一种字符模式,用于在查找过程中匹配指定的字符.在大多数程序里,正则表达式都被置于两个正斜杠之间:例如/l[oO] ...
- Windows Server体验之管理
安装了只有命令行界面的Windows Server之后怎么去管理,对于传统的Windows管理员来说确实是比较棘手的.因为没有了图形化的管理界面,需要更多的去依赖Powershell或者cmd命令去做 ...
- LVGL 模拟仿真(Windows+CodeBlocks)
一.准备材料 Code Blocks官网:https://www.codeblocks.org/ Code Blocks 汉化包:链接: https://pan.baidu.com/s/12zB5bD ...
- CentOS7部署FastDFS+nginx模块
软件下载 # 已经事先把所需软件下载好并上传到/usr/local/src目录了 https://github.com/happyfish100/libfastcommon/archive/V1.0. ...
- Elasticsearch实现类Google高级检索
文章转载自: https://mp.weixin.qq.com/s?__biz=MzI2NDY1MTA3OQ==&mid=2247483914&idx=1&sn=436f814 ...
- Elasticsearch:同步 MongoDB 数据到 Elasticsearch
转载自:https://elasticstack.blog.csdn.net/article/details/114639152 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写 ...
- prettierrc格式化常用配置
#最大长度 printWidth: 140 #单引号 singleQuote: true tabWidth: 2 useTabs: false # 句尾添加分号 semi: false # js an ...
- js对象结构赋值const {XXX } =this
样例1: const { xxx } = this.state; 上面的写法是es6的写法,其实就相当于: const xxx = this.state.xxx 样例2: const {comment ...