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;
    }

}
相关推荐
点云侠2 小时前
二维椭圆拟合算法及推导过程
开发语言·c++·算法·计算机视觉·matlab
大凝的IC进阶之路5 小时前
ISP——你可以从这里起步
图像处理·算法·isp
howard20056 小时前
1.2 图像处理基本操作
opencv·读取图像·显示图像·保存图像
jndingxin14 小时前
OpenCV视觉分析之目标跟踪(12)找到局部的最大值函数meanShift()的使用
人工智能·opencv·目标跟踪
王哈哈^_^15 小时前
【数据集】【YOLO】【目标检测】树木倒塌识别数据集 9957 张,YOLO道路树木断裂识别算法实战训练教程!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
美狐美颜sdk16 小时前
直播美颜SDK开发指南:实时美颜技术的架构与优化策略
人工智能·深度学习·计算机视觉·音视频·美颜sdk·视频美颜sdk·美颜api
深度学习lover16 小时前
<项目代码>YOLOv7 草莓叶片病害识别<目标检测>
人工智能·yolo·目标检测·计算机视觉·草莓叶片病害识别
胡狼FPGA17 小时前
FPGA图像处理.从认识噪声到去噪算法
图像处理·算法·fpga开发
好喜欢吃红柚子17 小时前
【目标检测】目标检测中全连接层(Fully Connected Layer)
人工智能·pytorch·python·目标检测·计算机视觉
9分钟带帽19 小时前
opencv_相关的问题
人工智能·opencv·计算机视觉