【Emgu.CV教程】5.1、几何变换之平移

图像的几何变换对于图像处理来说,也是最基础的那一档次,包括平移、旋转、缩放、透视变换等等,也就是对图像整理形状的改变,用到的函数都比较简单,理解起来也很容易。但是为了凑字数,还是一个函数一个函数的讲。

今天先讲图像平移,就是将原始图像左右、上下移动一段距离,图像平移有两种方式,下面一一介绍。以素材 榴莲.jpg举例,有三种方式。

1、平移后图像大小不变,原始图像丢失信息

原始图像 榴莲.jpg,宽度675,高度458。如果想让他向右平移50,再向下平移100,那么可以这样写代码:

cs 复制代码
Mat tempMat = srcMat.Clone();
int xOffset = Convert.ToInt32(TextBoxX.Text.Trim().ToString());
int yOffset = Convert.ToInt32(TextBoxY.Text.Trim().ToString());
int dstRows = tempMat.Rows;
int dstCols = tempMat.Cols;
Image<Bgr, Byte> dstImage = new Image<Bgr, Byte>(dstCols, dstRows);
ImageTranslation(tempMat.ToImage<Bgr, byte>(), dstImage, xOffset, yOffset);
Mat dstMat = dstImage.Mat;
dstMat.ConvertTo(dstMat, DepthType.Cv8U);
CvInvoke.Imshow("Result Mat, " + dstMat.Size.ToString(), dstMat);

平移函数ImageTranslation()代码如下:

cs 复制代码
/// <summary>
/// 图像平移实现函数.
/// </summary>
/// <param name="srcImg">源图像.</param>
/// <param name="dstImg">输出图像.</param>
/// <param name="xOffset">X轴偏移量,正数是向右偏移.</param>
/// <param name="yOffset">Y轴偏移量,正数是向下偏移.</param>
private void ImageTranslation(Image<Bgr, Byte> srcImg, Image<Bgr, Byte> dstImg, int xOffset, int yOffset)
{
    for (int i = 0; i < srcImg.Rows; i++)
    {
        for (int j = 0; j < srcImg.Cols; j++)
        {
            int x = j + xOffset;
            int y = i + yOffset;
            if (x >= 0 && x < dstImg.Cols && y >= 0 && y < dstImg.Rows)
            {
                dstImg[y, x] = srcImg[i, j];
            }
        }
    }
}

代码运行效果如下图所示:平移后的图片宽度还是675,高度还是458 。平移后原始图像少了一部分,平移区域用黑色补充。

2、平移后改变图像大小,原始图像信息不丢失

代码稍微改一下,把dstRows和dstCols加上偏移量:

cs 复制代码
Mat tempMat = srcMat.Clone();
int xOffset = Convert.ToInt32(TextBoxX.Text.Trim().ToString());
int yOffset = Convert.ToInt32(TextBoxY.Text.Trim().ToString());
int dstRows = tempMat.Rows + Math.Abs(yOffset);
int dstCols = tempMat.Cols + Math.Abs(xOffset);
Image<Bgr, Byte> dstImage;

// 这样平移后的图片,背景是绿色,否则默认是黑色的。
Mat backgroundMat = new Mat(new System.Drawing.Size(dstCols, dstRows), Emgu.CV.CvEnum.DepthType.Cv8U, 3);
backgroundMat.SetTo(new MCvScalar(0, 255, 0));
dstImage = backgroundMat.ToImage<Bgr, Byte>();
ImageTranslation(tempMat.ToImage<Bgr, byte>(), dstImage, xOffset, yOffset);
Mat dstMat = dstImg.Mat;
CvInvoke.Imshow("Result Mat, " + dstMat.Size.ToString(), dstMat);

代码运行效果如下图所示:平移后的图片宽度变成725,高度变成558 。原始的那一部分还在,多出来的用绿颜色补充。

3、WarpAffine()仿射变换函数实现平移

前两个都是自己的函数实现平移,其实Emgu.CV中有这么一个函数,叫WarpAffine()仿射变换函数也能实现。具体用法稍后会专门开一篇来介绍。

原创不易,请勿抄袭。共同进步,相互学习。

相关推荐
金蝶软件小李3 小时前
深度学习和图像处理
图像处理·深度学习·计算机视觉
慕容复之巅3 小时前
基于MATLAB的条形码的识别图像处理报告
开发语言·图像处理·matlab
Mr.简锋4 小时前
opencv常用api
人工智能·opencv·计算机视觉
liyuanbhu4 小时前
Halcon HImage 与 Qt QImage 的相互转换(修订版)
qt·计算机视觉·halcon
可均可可4 小时前
C++之OpenCV入门到提高005:005 图像操作
c++·图像处理·opencv·图像操作
Envyᥫᩣ5 小时前
深入浅出C#编程语言
开发语言·c#
春末的南方城市5 小时前
开源音乐分离器Audio Decomposition:可实现盲源音频分离,无需外部乐器分离库,从头开始制作。将音乐转换为五线谱的程序
人工智能·计算机视觉·aigc·音视频
phoenix@Capricornus5 小时前
矩阵的对角化&特征值分解
图像处理·线性代数·机器学习·矩阵
Make_magic6 小时前
Git学习教程(更新中)
大数据·人工智能·git·elasticsearch·计算机视觉
goomind6 小时前
深度学习模型评价指标介绍
人工智能·python·深度学习·计算机视觉