Android OpenCv4如何实现边缘检测及轮廓绘制出图像最大边缘
发表于:2025-11-10 作者:千家信息网编辑
千家信息网最后更新 2025年11月10日,本篇内容介绍了"Android OpenCv4如何实现边缘检测及轮廓绘制出图像最大边缘"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!
千家信息网最后更新 2025年11月10日Android OpenCv4如何实现边缘检测及轮廓绘制出图像最大边缘
本篇内容介绍了"Android OpenCv4如何实现边缘检测及轮廓绘制出图像最大边缘"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
Canny边缘检测
基于Canny算法的边缘检测主要有5个步骤,依次是
高斯滤波、像素梯度计算、非极大值像素梯度抑制、滞后阈值处理和孤立弱边缘抑制。Canny在有噪声的情况下表现好不好,取决于前面的降噪过程,可以手动做高斯处理提高识别率。
/** image 输入图像,必须是CV_8U的单通道或者三通道图像。 edges 输出图像,与输入图像具有相同尺寸的单通道图像,且数据类型为CV_8U。 threshold1 第一个滞后阈值。 threshold2 第二个滞后阈值。 apertureSize Sobel算子的直径。 L2gradient 计算图像梯度幅值方法的标志。默认为false**/public static void Canny(Mat image, Mat edges, double threshold1, double threshold2, int apertureSize, boolean L2gradient)使用
/** * canny算法,边缘检测 */ public static Mat canny(Bitmap bitmap) { Mat mSource = new Mat(); Utils.bitmapToMat(bitmap, mSource); Mat grayMat = new Mat(); Imgproc.cvtColor(mSource,grayMat,Imgproc.COLOR_BGR2GRAY);//转换成灰度图 Mat mat = mSource.clone(); Imgproc.Canny(mSource, mat, 75, 200); return mat; }获取图像最大矩形
/** * 返回边缘检测之后的最大矩形,并返回 * * @param cannyMat * Canny之后的mat矩阵 * @return */ public Rect findMaxRect(Mat cannyMat) { Mat tmp = mSource.clone(); List contours = new ArrayList(); Mat hierarchy = new Mat(); // 寻找轮廓 Imgproc.findContours(cannyMat, contours, hierarchy, Imgproc.RETR_EXTERNAL, Imgproc.CHAIN_APPROX_SIMPLE); int index = 0; double perimeter = 0; // 找出匹配到的最大轮廓 for (int i = 0; i < contours.size(); i++) { // 最大面积// double area = Imgproc.contourArea(contours.get(i)); //最大周长 MatOfPoint2f source = new MatOfPoint2f(); source.fromList(contours.get(i).toList()); double length = Imgproc.arcLength(source,true); if(length>perimeter){ perimeter = length; index = i; } } /** * 参数一:image,待绘制轮廓的图像。 * * 参数二:contours,待绘制的轮廓集合。 * * 参数三:contourIdx,要绘制的轮廓在contours中的索引,若为负数,表示绘制全部轮廓。 * * 参数四:color,绘制轮廓的颜色。 * * 参数五:thickness,绘制轮廓的线条粗细。若为负数,那么绘制轮廓的内部。 * * 参数六:lineType,线条类型。FILLED LINE_4 4连通 LINE_8 8连通 LINE_AA 抗锯齿 */ Imgproc.drawContours( tmp, contours, index, new Scalar(0.0, 0.0, 255.0), 9, Imgproc.LINE_AA ); Rect rect = Imgproc.boundingRect(contours.get(index));// Imgproc.rectangle(tmp, rect, new Scalar(0.0, 0.0, 255.0), 4, Imgproc.LINE_8); showImg(tmp); return rect; } /** * 显示图像 * @param mat */ private void showImg(Mat mat){ Bitmap bitmap = Bitmap.createBitmap(mat.width(), mat.height(), Bitmap.Config.ARGB_8888); Utils.matToBitmap(mat, bitmap); mIvSrc.setImageBitmap(bitmap); mat.release(); } "Android OpenCv4如何实现边缘检测及轮廓绘制出图像最大边缘"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
轮廓
边缘
图像
检测
参数
最大
梯度
阈值
出图
像素
内容
情况
更多
知识
矩形
算法
类型
线条
负数
过程
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全应急指挥中心
安卓本地服务器管理
金税盘数据库索引审查失败
郑州众易软件开发
河南鲲鹏服务器如何挑选
光合网络技术服务
服务器上文件怎么删除
3d手机游戏是什么软件开发的
数据库有哪些集成技术
数据库创建表学生约束条件
服务器同步数据库
数据共享和数据库
网络安全事件举报中心
网络安全风险排查及防控措施
立体版网络安全手抄报
辽宁语音网络技术服务
小软件开发测试
南通应用软件开发
融媒体中心网络安全工作
wow转服去哪个服务器好
小火箭服务器节点创建
诚毅科技软件开发限公司
软件开发工作室赚钱思路
服务器安全狗配置开放端口
济南ntp网络时间服务器
成都c语言软件开发个人
数据库 数据格式
宜宾app软件开发
合肥上海亨嘉网络技术公司
网络安全需要的设备有哪些