java使用opcv截取两张图片中间黄色圈然后对比偏移量


要使用 Java 和 OpenCV 截取两张图片中黄色圈的部分并对比偏移量,可以按照以下步骤进行: 1. 导入 OpenCV 库 首先,确保您已经正确地在 Java 项目中导入了 OpenCV 库。 2. 图像读取与预处理 使用 OpenCV 的函数读取两张图片,并进行必要的预处理,例如颜色空间转换等,以便更好地识别黄色部分。 3. 黄色区域提取 通过颜色阈值或其他图像处理方法,提取出两张图片中的黄色区域。 4. 轮廓检测 对提取出的黄色区域进行轮廓检测,找到黄色圈的轮廓。 5. 计算中心位置 对于检测到的轮廓,计算其中心位置。 6. 对比偏移量 计算两张图片中黄色圈中心位置的偏移量。 以下是一个简单的示例代码框架,展示了一些关键步骤,您需要根据实际情况完善和调整代码: ```java import org.opencv.core.Core; import org.opencv.core.CvType; import org.opencv.core.Mat; import org.opencv.core.MatOfPoint; import org.opencv.core.Point; import org.opencv.core.Scalar; import org.opencv.core.Size; import org.opencv.imgcodecs.Imgcodecs; import org.opencv.imgproc.Imgproc; public class ImageOffsetComparison { static { System.loadLibrary(Core.NATIVE_LIBRARY_NAME); } public static void main(String[] args) { // 读取两张图片 Mat image1 = Imgcodecs.imread("image1.jpg"); Mat image2 = Imgcodecs.imread("image2.jpg"); // 颜色空间转换为 HSV 以便提取黄色 Mat hsvImage1 = new Mat(); Mat hsvImage2 = new Mat(); Imgproc.cvtColor(image1, hsvImage1, Imgproc.COLOR_BGR2HSV); Imgproc.cvtColor(image2, hsvImage2, Imgproc.COLOR_BGR2HSV); // 设定黄色的 HSV 范围 Scalar lowerYellow = new Scalar(20, 100, 100); Scalar upperYellow = new Scalar(30, 255, 255); // 提取黄色区域 Mat yellowMask1 = new Mat(); Mat yellowMask2 = new Mat(); Core.inRange(hsvImage1, lowerYellow, upperYellow, yellowMask1); Core.inRange(hsvImage2, lowerYellow, upperYellow, yellowMask2); // 形态学操作去除噪声 Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_ELLIPSE, new Size(5, 5)); Imgproc.morphologyEx(yellowMask1, yellowMask1, Imgproc.MORPH_OPEN, kernel); Imgproc.morphologyEx(yellowMask2, yellowMask2, Imgproc.MORPH_OPEN, kernel); // 查找轮廓 MatOfPoint contours1 = new MatOfPoint(); MatOfPoint contours2 = new MatOfPoint(); Imgproc.findContours(yellowMask1, contours1, new Mat(), Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE); Imgproc.findContours(yellowMask2, contours2, new Mat(), Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE); // 计算中心位置 Point center1 = calculateCenter(contours1); Point center2 = calculateCenter(contours2); // 对比偏移量 double offsetX = center2.x - center1.x; double offsetY = center2.y - center1.y; System.out.println("偏移量 X: " + offsetX + ", 偏移量 Y: " + offsetY); } public static Point calculateCenter(MatOfPoint contour) { Moments moments = Imgproc.moments(contour); double centerX = moments.m10 / moments.m00; double centerY = moments.m01 / moments.m00; return new Point(centerX, centerY); } } ``` 这只是一个基本的示例框架,实际应用中可能需要更复杂的图像处理和错误处理来适应不同的图像情况。 [2024-08-10 10:14:11 | AI写代码神器 | 1012点数解答]
- import javax.swing.*; import java.awt.*; import java.awt.datatransfer.clipboard; import java.awt.datatransfer.stringselection; import java.awt.datatransfer.transferable; import java.awt.event.*; import java.io.*; import java.nio.file.files; import java.nio.file.path; import java.nio.file.paths; import java.time.localdatetime; import java.util.hashmap; import java.util.list; import java.util.map; import java.util.random; public class copy { static private final jtextarea textarea = new jtext(1497点数解答 | 2024-08-25 09:40:33)296
- 编写一个嫌疑人车辆预警的程序。 公安系统在追捕嫌疑人时,嫌疑人驾车逃跑,据目击群众描述,由于天色较暗,只能确定部分信息: ● 嫌疑人a车辆牌照信息:绿色,鲁,车牌最后三位是111 ● 嫌疑人b车辆牌照信息:黄色,苏,车牌前三是苏fc 公安系统中有一个车牌识别预警系统,可以根据车牌信息进行识别预警。我们要设计一个程序模拟这个车牌识别预警系统,为了模拟程序需要输入车牌颜色和车牌号,输出预警提示信息: ● 疑似嫌疑人a车辆 ● 疑似嫌疑人b车辆 ● 无嫌疑车辆 【相关信息】 车牌颜色只有三种,用三个单词代表: ● 绿色:green ● 蓝色:blue ● 黄色:yellow(458点数解答 | 2024-05-05 18:31:11)223
- dm.jdbc.driver.dmexception: 数据溢出 at dm.jdbc.driver.dberror.throwexception(dberror.java:636) at dm.jdbc.c.b.p.s(msg.java:225) at dm.jdbc.c.b.p.p(msg.java:185) at dm.jdbc.c.b.p.o(msg.java:166) at dm.jdbc.c.a.a(dbaccess.java:776) at dm.jdbc.c.a.a(dbaccess.java:327) at dm.jdbc.c.a.a(dbaccess.java:435) at dm.jdbc.driver.dmdbpreparedstatement.executeinner(dmdbpreparedstatement.java:284) at dm.jdbc.driver.dmdbpreparedstatement.do_executequery(dmdbpreparedstatement.java:383) at dm.jdbc.driver.(598点数解答 | 2024-10-15 15:48:38)199
- 问题排查:dm.jdbc.driver.dmexception: 数据溢出 at dm.jdbc.driver.dberror.throwexception(dberror.java:636) at dm.jdbc.c.b.p.s(msg.java:225) at dm.jdbc.c.b.p.p(msg.java:185) at dm.jdbc.c.b.p.o(msg.java:166) at dm.jdbc.c.a.a(dbaccess.java:776) at dm.jdbc.c.a.a(dbaccess.java:327) at dm.jdbc.c.a.a(dbaccess.java:435) at dm.jdbc.driver.dmdbpreparedstatement.executeinner(dmdbpreparedstatement.java:284) at dm.jdbc.driver.dmdbpreparedstatement.do_executequery(dmdbpreparedstatement.java:383) at dm.jdbc.dr(403点数解答 | 2024-10-15 15:48:41)852
- 商品展示模块 前端页面:productlist.jsp、productdetail.jsp 后端逻辑:productservlet 处理获取商品列表与详情请求 实现商品分页显示、按类别或关键词搜索功能 前端页面渲染与交互 使用 jsp、el、jstl 渲染商品数据 使用 css 优化页面样式,确保用户界面美观统一 使用 javascript 实现简单的前端交互,如商品图片切换、下拉菜单 搜索与过滤功能 在 productlist.jsp 实现搜索栏,允许用户输入关键词进行搜索 后端根据搜索条件查询数据库,返回符合条件的商品列表 使用 jstl 循环输出商品数据,并实现价格或类别过滤选项(19点数解答 | 2024-12-13 15:00:43)194
- public static void main(string[] args) { string imgpath = "d:\ruoyi\uploadpath\upload\shuyoubi\20240726192938460.jpg"; double rate = imagecompareutils.compareimage(imgpath); double focallength = 4; // 焦距,单位:毫米 double actualsize = 9.6; // 物体实际尺寸,单位:厘米 double pixelsize = 298.8999938964844*2; // 物体在图片中的像素尺寸 double distance = calculatedistance(focallength, actualsize, pixelsize); system.out.println("物体与相机之间的距离为: " + distance + " 厘米"); system.out.println("偏移量:" + rate); // double(253点数解答 | 2024-07-27 09:18:40)178
- import com.opencsv.csvreader; import com.opencsv.exceptions.csvvalidationexception; import java.io.filereader; import java.io.ioexception; import java.text.parseexception; import java.text.simpledateformat; import java.util.*; public class stockstatistics { public static void main(string[] args) { string filepath = "stocks.csv"; // 请确保csv文件与此java文件在同一目录下,或提供完整路径 simpledateformat sdf = new simpledateformat("yyyy-mm-dd"); map<string, stockdata> monthlydata = new has(66点数解答 | 2024-11-13 15:31:04)163
- 1至10,10个号码每个号码对应单元格颜色为 1= rgb(255, 255, 0) ' 黄色 2= rgb(0, 102, 204) ' 海蓝色 3= rgb(0, 0, 0) ' 黑色 4= rgb(255, 128, 0) ' 橘红色 5= rgb(0, 255, 255) ' 青绿色 6= rgb(0, 0, 255) ' 蓝色 7= rgb(128, 128, 128) ' 灰色 8= rgb(255, 0, 0) ' 红色 9= rgb(128, 0, 0) ' 深红色 10= rgb(128, 128, 0) ' 橄榄色。 双击c3单元格,则数据区c5至l30000内的内容,大于等于6的为大,且按照每个号码的颜色进行标色。 双击d3单元格,则数据区c5至l30000内的内容,小于等于5的为小,且按照每个号码的颜色进行标色。 双击e3单元格,则数据区c5至l30000内的内容,等于单数的为单,且按照每个号码的颜色进行标色。 双击f3单元格,则数据区c5至l30000内的内容,等于偶数的为双,且按照每个号码的颜色进行标色。 双击g3单元格,则数据区c5至l30000内的内容,(942点数解答 | 2024-12-07 18:07:56)211
- 题目:按照以下步骤在 pycharm 中进行自动化测试脚本编写,并执行脚本。 步骤: (1)从 selenium 中引入 webdriver; (2)使用 selenium 模块的 webdriver 打开谷歌浏览器; (3)在谷歌浏览器中通过 get 方法发送网址eshop测试平台登录页面; (4)增加智能时间等待 5 秒; (5)查看登录页面中的用户名输入框元素,通过 css_selector 属性定位用户名输入框,并输入用户名(用自己注册的用户); (6)查看登录页面中的密码输入框元素,通过 xpath 属性定位密码输入框,并输入密码(用自己注册的用户对应密码) ; (7)查看登录页面中的登录按钮元素,通过 class_name 方法定位登录按钮,使用 click()方法点击登录按钮进入eshop测试平台首页; (8)在eshop测试平台首页通过 link_text 方法对“我的订单”按钮进行定位,使用 click()方法点击“我的订单”(304点数解答 | 2024-11-06 15:38:30)269
- 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1(452点数解答 | 2024-12-02 09:49:52)153
- 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入 2 4 3 1(613点数解答 | 2024-12-02 09:50:35)191
- 使用c语言代码 题目描述 给出一颗二叉树,请把它左右翻转。超级简单吧,max howell竟然不会写,然后被google直接拒掉。(然后,然后...自己上网查吧) 比如下面的树这样翻转,然后输出翻转后先序遍历顺序。 4 / \ 2 6 / \ / \ 1 3 5 7 (转换前先序遍历顺序为 4 2 1 3 6 5 7) 4 / \ 6 2 / \ / \ 7 5 3 1 (转换后先序遍历顺序为 4 6 7 5 2 3 1) 输入 第一行一个整数t(<=10),表示有t组测试数据。 对于每组测试数据: 第一行两个整数n(<=8191)和d(1<=d<=13),表示这棵树有n个结点(结点标号为1~n),树有d层。 接下来d行: 第i行有2^(i-1)个整数,其中i行第j个a[i][j]的左儿子结点为a[i+1][j*2-1]右儿子为a[i+1][j*2](-1表示不存在该结点) 输出 对于每组数据输出一行为这颗树翻转后的先序遍历顺序。整数之间用空格隔开,最后一个整数后面没有空格。 样例输入(1053点数解答 | 2024-12-02 09:51:45)139