cv图像识别

安卓opencv全分辨率找图


contourArea 取轮廓面积

<p>[TOC]</p> <h5>简要描述</h5> <ul> <li>获取轮廓面积。用于过滤某些不符合面积大小要求的轮廓。</li> </ul> <h5>参数</h5> <table> <thead> <tr> <th style="text-align: left;">参数名</th> <th style="text-align: left;">必选</th> <th style="text-align: left;">类型</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td style="text-align: left;">Points</td> <td style="text-align: left;">是</td> <td style="text-align: left;">Point[]</td> <td>轮廓坐标数据集中的一个Points组。 findContours的返回值Arrlist其中的元素为 Point[]</td> </tr> <tr> <td style="text-align: left;">oriented</td> <td style="text-align: left;">(可选)</td> <td style="text-align: left;">boolean</td> <td>轮廓的方向。如果为true返回有符号值(正负值),否则返回绝对值。通常为false。</td> </tr> </tbody> </table> <h5>返回参数说明</h5> <p>double</p> <h5>示例</h5> <pre><code class="language-java"> //载入图像(载入灰度) var mat=cvImg.loadFromFile("/sdcard/Pictures/tem.jpg",0); //高斯平滑 var mat_blur=cvImg.blurGaussian(mat); cvImg.toFile(mat_blur,"/sdcard/Pictures/tem3.jpg"); //边缘检测 var mat_canny=cvImg.canny(mat_blur,50,150,3,true); cvImg.toFile(mat_canny,"/sdcard/Pictures/tem4.jpg"); //闭操作,小的,不连续的线条,使之连接起来 var mat_result=cvImg.morphologyEx (mat_canny,3,3,3,-1,-1,2); cvImg.toFile(mat_result,"/sdcard/Pictures/tem5.jpg"); //提取轮廓 var pointList=cvImg.findContours(mat_result,0,1,0,0); //绘制轮廓最小边界矩形 var mat_mask=cvImg.zeros(mat.cols(),mat.rows(),16);//创建大小与原图一样的模板图。 for(var i=0;i&lt;pointList.size();i++){ var color=[ random(100,255), random(100,255), random(100,255), 0 ]; //过滤仅仅绘制面积小于100的轮廓。 if(cvImg.contourArea(pointList.get(i))&lt;100){ //绘制轮廓 cvImg.drawContours(mat_mask,pointList,i,color,1); //计算最小边界矩形(4个顶点坐标) var points=cvImg.minAreaRect_vertex(pointList.get(i)); //画最小边界矩形(注意,最小边界矩形可能是旋转一定角度的矩形,所以需使用画直线方式。) cvImg.line(mat_mask,points[0].x,points[0].y,points[1].x,points[1].y,color,2); cvImg.line(mat_mask,points[1].x,points[1].y,points[2].x,points[2].y,color,2); cvImg.line(mat_mask,points[2].x,points[2].y,points[3].x,points[3].y,color,2); cvImg.line(mat_mask,points[0].x,points[0].y,points[3].x,points[3].y,color,2); } } cvImg.toFile(mat_mask,"/sdcard/Pictures/tem6.jpg"); cvImg.release(mat);//释放 cvImg.release(mat_blur);//释放 cvImg.release(mat_canny);//释放 cvImg.release(mat_mask);//释放</code></pre> <p>原图 <img src="https://www.showdoc.com.cn/server/api/attachment/visitFile?sign=3d8a63ddd957da1963596beb18f12997" alt="" /> 边缘检测后 <img src="https://www.showdoc.com.cn/server/api/attachment/visitFile?sign=bcacd77abe866357489d3d80a045cf32" alt="" /> 闭操作后 <img src="https://www.showdoc.com.cn/server/api/attachment/visitFile?sign=9645e145b92c4e6d63b90e4acfdf105b" alt="" /> 绘制并填充轮廓。 <img src="https://www.showdoc.com.cn/server/api/attachment/visitFile?sign=5feeefc8a76894453deed25ebf2a16d6" alt="" /> 过滤轮廓面积并绘制 <img src="https://www.showdoc.com.cn/server/api/attachment/visitFile?sign=18d84ac135e415f5b669a27386e235b6" alt="" /></p> <p>**</p>

页面列表

ITEM_HTML