Java+opencv3.2.0之重映射

本文介绍了一种使用OpenCV库实现图像重映射的方法。通过不同的映射函数,可以实现图像的各种变形效果。具体介绍了映射函数的形式及其参数,并给出了四种不同的重映射示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过重映射来表达每个像素的位置(x,y) :g(x,y)=f(h(x,y)),h(x,y)是映射方法函数。当h(x,y) = (I.cols()-x,y),表示按照x轴方向发生偏转。

函数: Imgproc.remap(Mat src, Mat dst, Mat map1, Mat map2, int interpolation, int borderMode, Scalar borderValue)
参数说明:
src:源图像
dst:目标图像
map1:它有两种可能表示的对象,一种是表示点(x,y)的第一个映射,另一种是CV_16SC2、CV_32FC1、CV_32FC2类型的X值
map2:它有两种可能表示的对象,一种是当map1表示点(x,y)的第一个映射时,不代表任何值,另一种是CV_16UC1、CV_32FC1类型的Y值
interpolation:插值方式,不支持INTER_AREA
borderMode:边界模式,默认BORDER_CONTANT
borderValue:当有常数边界时使用的值,默认为0

示例代码:

public static void main(String[] args)
    {
        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

        Mat src = Imgcodecs.imread("F:\\t0105b07b97736d453d.jpg");

        Mat dst = src.clone();
        Mat map_x = new Mat(src.size(), CvType.CV_32FC1);
        Mat map_y = new Mat(src.size(), CvType.CV_32FC1);

        int key = 1; // key取值1、2、3、4
        for (int i = 0; i < src.rows(); i++)
        {
            for (int j = 0; j < src.cols(); j++)
            {
                switch (key)
                {
                case 1: // 重映射1
                    if (j > src.cols() * 0.25 && j < src.cols() * 0.75 && i > src.rows() * 0.25
                            && i < src.rows() * 0.75)
                    {
                        map_x.put(i, j, 2 * (j - src.cols() * 0.25) + 0.5);
                        map_y.put(i, j, 2 * (i - src.rows() * 0.25) + 0.5);
                    }
                    else
                    {
                        map_x.put(i, j, 0.0);
                        map_y.put(i, j, 0.0);
                    }
                    break;
                case 2: // 重映射2
                    map_x.put(i, j, j);
                    map_y.put(i, j, src.rows() - i);
                    break;
                case 3: // 重映射3
                    map_x.put(i, j, src.cols() - j);
                    map_y.put(i, j, i);
                    break;
                case 4: // 重映射4
                    map_x.put(i, j, src.cols() - j);
                    map_y.put(i, j, src.rows() - i);
                    break;
                default:
                    break;
                }
            }
        }
        Imgproc.remap(src, dst, map_x, map_y, Imgproc.INTER_LINEAR, Core.BORDER_CONSTANT,
                new Scalar(0, 0, 0));

        Imgcodecs.imwrite("F:\\dst.jpg", dst);
    }

源图像:
这里写图片描述

第一种映射:
这里写图片描述

第二种映射:
这里写图片描述

第三种映射:
这里写图片描述

第四种映射:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值