opencv边界填充_opencv边缘提取

opencv边界填充_opencv边缘提取目标:将区域内的小洞填充因为c++算法还不会,决定先用matlab试试,找到一个imfill可以实现区域的填充Matlab里的实现clearall;clc;I=im2bw(imread(‘E:\免疫组化\pic\tt.bmp’));figure,imshow(I);I1=imfill(I,’holes’);figure,imshow(I1);效果图但是二值免疫图的效果就不太理想原因也不是很清楚?…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

目标:将区域内的小洞填充

因为c++算法还不会,决定先用matlab试试,找到一个imfill可以实现区域的填充

Matlab里的实现

clear all;clc;

I=im2bw(imread(‘E:\免疫组化\pic\tt.bmp’));

figure,imshow(I);

I1=imfill(I,’holes’);

figure,imshow(I1);

效果图

opencv边界填充_opencv边缘提取

opencv边界填充_opencv边缘提取

但是二值免疫图的效果就不太理想

原因也不是很清楚?是不是因为图像太大的缘故呢?

再来看在c++中,利用opencv实现

首先要倒入opencv路径神马的,这一步骤大神已经帮我弄好了,具体参见:http://www.cnblogs.com/freedomshe/archive/2012/04/25/2470540.html

然后要在头文件中加入:

#include

using namespace cv;

新建了一个函数testcv(LPALGINFO lpSrc, LPALGINFO

lpDst)传入原图,传出目标图像

第一部分,将lpSrc里的图像数据存到lpt指针数组中,再将BYTE*类型转为opencv里的IplImage*类型。

for(

i=0;i

{

lpt[i]=lpSrc->bpValue[i*3];

}

IplImage*

img=cvCreateImage(cvSize(nW,nH),IPL_DEPTH_8U,1);

cvSetData(img,lpt,nW);//

第二部分,找轮廓并填充轮廓

这一部分利用的是opencv里现成的函数,其实想自己写算法实现的。要注意的一点是,这两个函数都是对单通道的二值图像进行的操作。所以在第一部分的传入图像数据和第三部分的传出图像数据时要注意单通道。

Mat

src(img);//这里将IplImage*类型转为Mat类型

vector >

contours;

vector

hierarchy;

//寻找轮廓函数

findContours(src, contours, hierarchy, CV_RETR_EXTERNAL,

CV_CHAIN_APPROX_NONE);

if(

!contours.empty() && !hierarchy.empty() )

{

for (int idx=0;idx < contours.size();idx++)

{

填充轮廓函数

drawContours(src,contours,idx,Scalar::all(255),CV_FILLED,8);

}

}

img=&IplImage(src) //这里将Mat类型转为IplImage*类型

第三部分,将图像数据传到目标图像中

for(int

j=0;j

{

for(i=0;i

{

lpDst->bpValue[j*nW*3+i*3]=(img->imageData)[j*nW+i];

lpDst->bpValue[j*nW*3+i*3+1]=(img->imageData)[j*nW+i];

lpDst->bpValue[j*nW*3+i*3+2]=(img->imageData)[j*nW+i];

}

}

效果图:

opencv边界填充_opencv边缘提取

opencv边界填充_opencv边缘提取

第一个测试有边缘噪声,第二个又有条对角线,很奇怪在形态学算法中就出现了,真是阴魂不散。。。

下一步就是自己用c++实现啦~~~~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197484.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python开发环境搭建,pycharm安装运行[通俗易懂]

    python开发环境搭建,pycharm安装运行[通俗易懂]一、python安装指南首先我们安装python1、进入官方网站(网址:https://www.python.org/downloads),根据自己的需求选择python的版本,这里我是选择的Python3.7.3,点击DownloadPython3.7.3按钮2、下载完成后点击安装文件包3、双击EXE文件进行安装,如下…

    2022年8月28日
    4
  • spss数据分析聚类分析_SPSS聚类分析

    spss数据分析聚类分析_SPSS聚类分析SPSS之聚类分析(图文+数据集)聚类分析简介按照个体(记录)的特征将它们分类,使同一类别内的个体具有尽可能高的同质性,而类别之间则具有尽可能高的异质性。为了得到比较合理的分类,首先要采用适当的指标来定量地描述研究对象之间的联系的紧密程度。假定研究对象均用所谓的“点”来表示。在聚类分析中,一般的规则是将“距离”较小的点归为同一类,将“距离”较大的点归为不…

    2022年10月17日
    2
  • 架构设计——ID生成器「建议收藏」

    架构设计——ID生成器「建议收藏」一、分布式ID发号器要求很明确:不同机器同一时间生成不同ip;同一机器不同时间生成不同IP;所以根据需求,可选变量有:机器(网卡、IP)+时间,随机数二、WhynotUUID?UUID的实现:算法的核心思想是结合机器的网卡、当地时间、一个随机数来生成UUID。优势:保证唯一性;本地调用,不需要rpcUUID的缺陷:1.UUID较长,占用内存空间;往往用字符串表示…

    2022年6月15日
    43
  • 网页背景音乐设置_网页制作怎么插背景音乐

    网页背景音乐设置_网页制作怎么插背景音乐一、添加背景音乐时,一般会用到两种标签:1、<bgsound>2、<embed>二、一般用法:<bgsoundsrc=”音频源”autostart=”true”loop=”false”/><embedsrc=”音频源”autostart=”true”loop=”false”…

    2022年9月24日
    3
  • 通过PropertyDescriptor反映射调用set和get方法

    通过PropertyDescriptor反映射调用set和get方法1packagecom.zhoushun;importjava.lang.reflect.Method;importjava.lang.reflect.Field;importjava.beans.PropertyDescriptor;publicclassPropertyUtil{ @SuppressWarnings(“unchecked”) publicsta

    2022年10月1日
    4
  • 【实战】javaweb学生信息管理系统[通俗易懂]

    javaweb学生信息管理系统总的来说整个项目通过Maven来管理jar包,实现了学生信息管理系统的登录,增删改查等基本操作,然后不喜写css样式,页面有点丑,但是代码中的逻辑基本正确。项目下载链接csdn下载链接github地址一、项目架构二、数据库的设计操作1.user表2.student表三、登录界面(动态生成验证码、提示账号or密码or验证码输入有误)四、登录的主界面五…

    2022年4月15日
    91

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号