【转载】 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交互实现图片的放大和缩小的更多相关文章

  1. Android------实现图片双击放大,缩小,左右滑动的多种方式

    项目中常常有图片浏览功能.像微信朋友圈图片浏览,QQ空间照片浏览 的功能. 实现图片双击放大,缩小,左右滑动等效果. 来看看我的效果图,希望能满足你的要求   前三个button按钮是参考网上的多种实 ...

  2. 实例讲解如何利用jQuery设置图片居中放大或者缩小

    大家有没有见过其他网站的图片只要鼠标放上去就能放大,移出去的时候就能缩小,而且一直保持居中显示!其实jQuery提供一个animate函数可以使图片放大和缩小,只要改变图片的长和高就OK啦!但是ani ...

  3. 使用JavaScript 中的Math对象和勾股定理公式,计算鼠标的位置与页面图片中心点的距离,根据距离对页面上的图片进行放大或缩小处理。距离远时图片放大,距离近时图片缩小

    查看本章节 查看作业目录 需求说明: 使用JavaScript 中的Math对象和勾股定理公式,计算鼠标的位置与页面图片中心点的距离,根据距离对页面上的图片进行放大或缩小处理.距离远时图片放大,距离近 ...

  4. 通过Java代码实现图片的放大和缩小

    本文介绍的例子在Android安卓手机上测试通过. 先看看效果吧.可以看到这个开发好的安卓应用有三个按钮:Zoom In缩小图片,Zoom Out放大图片和Save保存. 初始页面: 可以在左边边框自 ...

  5. JS图片的放大与缩小

    <!doctype html><head><meta charset=utf-8" /><title>javascript控制图片缩小或者放大 ...

  6. JavaScript特效之图片特效放大,缩小,旋转

    效果图如下: 效果代码如下: <!doctype html> <html lang="en"> <head> <meta charset= ...

  7. js 实现图片的放大和缩小

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. [Swift通天遁地]三、手势与图表-(3)通过捏合手势放大和缩小图像视图

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  9. Java界面程序实现图片的放大缩小

    Java界面程序实现图片的放大缩小.这个程序简单地实现了图片的打开.保存.放大一倍.缩小一倍和固定缩放尺寸,但是并没有过多的涵盖对图片的细节处理,只是简单地实现了图片大小的放缩. 思维导图如下: 效果 ...

随机推荐

  1. html、css实现导航栏5种常用下拉效果

    实现的效果:鼠标移入按钮时按钮中的内容就会出现,分别展示不同的出现效果.效果难点:不使用JavaScript,那这个效果的难点就是在于:hover伪类的掌控,以及考验对html的结构掌握. 1. ht ...

  2. 如何使用CSS伪类选择器

    总览 CSS选择器允许你通过类型.属性.位于HTML文档中的位置来选择元素.本教程阐述了三个新选项:is().:where()和:has(). 选择器通常在样式表中使用.下面的示例会找到所有<p ...

  3. liunx系统docker部署.net core3.1

    此篇文章演示基本的基于docker部署.netcore服务,liunx系统腾讯云ubuntu,.net core版本3.1. 1.安装docker apt install docker.io 2.拉取 ...

  4. 【设计模式】Java设计模式 - 动态代理

    [设计模式]Java设计模式 - 动态代理 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 一个有梦有戏的人 @怒放吧德德 最近工作比较忙,没啥时间学习 目录 [设计模 ...

  5. KingbaseES 全局索引是否因为DDL操作而变为Unusable ?

    前言 Oracle 在对分区做DDL操作时,会使分区全局索引失效,需要加上关键字update global indexes.KingbaseES 同样支持全局索引.那么,如果对分区表进行DDL操作,那 ...

  6. KingbaseES 普通表在线改为分区表案例

    对大表进行分区,但避免长时间锁表 假设您有一个应用程序,该应用程序具有一个巨大的表,并且需要始终可用.它变得如此之大,以至于在不对其进行分区的情况下对其进行管理变得越来越困难.但是,您又不能使表脱机以 ...

  7. 【设计模式】Java设计模式 - 适配器模式

    [设计模式]Java设计模式 - 适配器模式 不断学习才是王道 继续踏上学习之路,学之分享笔记 总有一天我也能像各位大佬一样 原创作品,更多关注我CSDN: 一个有梦有戏的人 准备将博客园.CSDN一 ...

  8. 安装配置docker&maven环境

     原文视频:(https://blog.sechelper.com/20220919/code-review/docker-maven-install-guid/) Docker是什么 Docker ...

  9. 6.云原生之Docker容器Registry私有镜像仓库搭建实践

    转载自:https://www.bilibili.com/read/cv15219863/?from=readlist #1.下载registry仓库并设置数据存放的目录(并生成认证账号密码) doc ...

  10. 使用Docker方式部署Mongodb多副本集(replSet)

    linux主机ip:192.168.0.253 1. 创建网络与容器 docker pull mongo docker network create mongo-rs docker run --nam ...