java使用opcv截取两张图片中间黄色圈然后对比计算出图片一比图片二偏移百分比


要使用 OpenCV(在 Java 中)截取两张图片中的黄色圆圈,并计算偏移百分比,您可以按照以下大致步骤进行操作: 1. 读取图片:使用 OpenCV 的 `imread` 方法读取两张图片。 2. 颜色空间转换:将图片从 BGR(默认的 OpenCV 颜色空间)转换到 HSV 颜色空间,以便更方便地检测黄色。 3. 黄色阈值设定:根据 HSV 中黄色的范围设定阈值,来提取黄色区域。 4. 形态学操作:可能需要进行一些形态学操作,如膨胀、腐蚀,来优化提取的黄色区域。 5. 轮廓检测:找到黄色区域的轮廓。 6. 确定圆形轮廓:通过一些算法判断哪个轮廓是圆形的(例如计算轮廓的周长和面积,根据圆形的特性来判断)。 7. 计算圆心坐标:对于检测到的圆形轮廓,计算其圆心坐标。 8. 计算偏移:比较两张图片中圆形的圆心坐标,计算偏移量。 9. 计算偏移百分比:根据图片的尺寸和偏移量计算偏移百分比。 以下是一个简单的示例代码框架,仅包含了一些关键步骤的示意,实际应用中还需要根据具体情况进行调整和完善: ```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 ImageComparison { 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); // 设定黄色阈值 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 dilatedMask1 = new Mat(); Mat dilatedMask2 = new Mat(); Imgproc.dilate(yellowMask1, dilatedMask1, new Mat()); Imgproc.dilate(yellowMask2, dilatedMask2, new Mat()); // 轮廓检测 Mat hierarchy1 = new Mat(); Mat hierarchy2 = new Mat(); List<MatOfPoint> contours1 = new ArrayList<>(); List<MatOfPoint> contours2 = new ArrayList<>(); Imgproc.findContours(dilatedMask1, contours1, hierarchy1, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE); Imgproc.findContours(dilatedMask2, contours2, hierarchy2, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE); // 确定圆形轮廓并计算圆心 Point center1 = findCenterOfCircle(contours1); Point center2 = findCenterOfCircle(contours2); // 计算偏移和偏移百分比 double offsetX = center2.x - center1.x; double offsetY = center2.y - center1.y; double percentageX = (offsetX / image1.width()) * 100; double percentageY = (offsetY / image1.height()) * 100; System.out.println("X 方向偏移百分比: " + percentageX + "%"); System.out.println("Y 方向偏移百分比: " + percentageY + "%"); } public static Point findCenterOfCircle(List<MatOfPoint> contours) { for (MatOfPoint contour : contours) { double area = Imgproc.contourArea(contour); double perimeter = Imgproc.arcLength(contour, true); double circularity = 4 * Math.PI * area / (perimeter * perimeter); if (circularity > 0.8) { // 大致判断为圆形 Moments moments = Imgproc.moments(contour); int x = (int) (moments.m10 / moments.m00); int y = (int) (moments.m01 / moments.m00); return new Point(x, y); } } return null; } } ``` 这只是一个简单的示例,实际的图像处理可能会更加复杂,需要根据图片的质量、黄色区域的特征和准确性要求进行更多的优化和调整。 [2024-08-10 10:15:40 | AI写代码神器 | 1248点数解答]
- 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
- 百分比 缩写(66点数解答 | 2025-07-30 13:26:19)35
- 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