Java OpenCV 图像处理40 图形图像 图片裁切ROI

Java OpenCV 图像处理40 图形图像 图片裁切

在 OpenCV 中,Rect 类是用来表示矩形的数据结构,通常用于定义图像处理中的感兴趣区域(Region of Interest,ROI),或者指定图像中的某个区域的位置和大小。Rect 类位于 org.opencv.core 包中。

java 复制代码
package com.xu.opencv.image;

import java.io.File;

import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Size;
import org.opencv.highgui.HighGui;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

/**
 * @author hyacint
 */
public class Cropping {

    static {
        String os = System.getProperty("os.name");
        String type = System.getProperty("sun.arch.data.model");
        if (os.toUpperCase().contains("WINDOWS")) {
            File lib;
            if (type.endsWith("64")) {
                lib = new File("lib\\opencv\\x64\\" + System.mapLibraryName("opencv_java490"));
            } else {
                lib = new File("lib\\opencv\\x86\\" + System.mapLibraryName("opencv_java490"));
            }
            System.load(lib.getAbsolutePath());
        }
    }

    public static void main(String[] args) {
        // 图片路径
        String path = "C:\\Users\\xuyq\\Desktop\\1.png";
        // 读取图片
        Mat src = Imgcodecs.imread(path);
        // 定义裁剪区域
        Rect rect = new Rect(100, 100, 300, 200);
        // 执行裁剪
        Mat dst = new Mat(src, rect);
        // 输出裁剪后的图片
        HighGui.imshow("src", resize1(src));
        HighGui.imshow("dst", dst);
        HighGui.waitKey();
    }

    /**
     * 图像缩放
     *
     * @param src 原始图片
     * @return 新图片
     */
    public static Mat resize(Mat src) {
        // 图像中心
        Point center = new Point((double) src.cols() / 4, (double) src.rows() / 4);
        // 获取 旋转 矩阵
        Mat dst = Imgproc.getRotationMatrix2D(center, 0, 0.5);
        // 进行 图像缩放
        Mat image = new Mat();
        Imgproc.warpAffine(src, image, dst, src.size());
        return image;
    }

    /**
     * 图像缩放
     *
     * @param src 原始图片
     * @return 新图片
     */
    public static Mat resize1(Mat src) {
        Size size = new Size((double) src.width() / 4, (double) src.height() / 4);
        // 执行缩小操作
        Mat dst = new Mat();
        Imgproc.resize(src, dst, size, 0, 0, Imgproc.INTER_AREA);
        return dst;
    }

}
相关推荐
FL16238631298 小时前
[cmake]基于C++使用纯opencv部署ppocrv5v6的onnx模型
开发语言·c++·opencv
Dick50711 小时前
ROS2 视觉感知、目标检测与 TF 控制闭环复盘:从 /camera/image_raw 到 /cmd_vel 的机器人目标跟随实现
人工智能·计算机视觉·目标跟踪
搏博11 小时前
多传感器融合基础之一图像空间(Image Space)全面解析
图像处理·python·图像空间·融合感知
DXM052112 小时前
第14期|高阶分割模型:Transformer/SegFormer遥感应用
人工智能·python·神经网络·算法·计算机视觉·cnn·ageo
chase_my_dream12 小时前
LeGO-LOAM 详细源码流程解读
c++·计算机视觉·自动驾驶
2401_8856651913 小时前
基于OpenCV的模板匹配OCR实战:银行卡与身份证数字识别完整教程
人工智能·python·opencv·计算机视觉·ocr
再一次等风来14 小时前
YOLO26 实测记录:从模型下载、预测验证到 ONNX Runtime 推理部署
yolo·计算机视觉·onnx·yolo26
大奎帝国14 小时前
Segearth-R2-02
人工智能·机器学习·计算机视觉
大奎帝国16 小时前
Segearth-R2-03
深度学习·机器学习·计算机视觉
YOLO数据集集合16 小时前
无人机航拍RGBT双模态行人检测数据集 | 可见光红外对齐 低空小目标检测 多模态计算机视觉基准数据
人工智能·深度学习·目标检测·计算机视觉·无人机