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++实现啦~~~~

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • win10JDK环境变量的配置

    win10JDK环境变量的配置在win10系统下进行jdk环境变量与win7的一些区别,作者踩过一些坑,最后通过网上查找资料才将问题解决,但是网上的资料比较零碎,作者整理一下亲自操作过程并且将步骤详细的写了下来,希望能够帮助需要的人。一、下载安装完成jdk之后,桌面右键此电脑选择属性,进入以下界面,然后选择高级系统设置,进入系统配置二、进入系统配置之后点击环境变量,进入环境变量配置窗口三、此时我们可以看到有用户变量…

  • 创建索引sql 语句「建议收藏」

    创建索引sql 语句「建议收藏」1、创建表的同时指定createtablet1( idintnotnull, namechar(30)notnull, uniqueindexUniqIdx(id))2、在已经存在的表创建索引使用ALTERTABLE语句创建索引1.执行语句altertablebookaddindexBkName(bookname(30))2…

  • jdbc 事务

    jdbc 事务

  • C语言入门项目篇:贪吃蛇(完整代码+详细注释)「建议收藏」

    C语言入门项目篇:贪吃蛇可直接运行。#include<stdio.h>#include<stdlib.h>#include<windows.h>#include<time.h>#include<conio.h>/*大一上的时候C语言入门学的一个小游戏。还是挺有意思的,有兴趣的同学可以继续优化下:比如蛇头碰到蛇身就判定为输/给蛇身加点颜色等。*///1.2食物结构体#defineMAPHEIGHT25#defi

  • 卡盟网站程序源码,支持无限分站,货源共享「建议收藏」

    卡盟网站程序源码,支持无限分站,货源共享「建议收藏」服务器系统:cenos7.x64位(购买vps都知道ba?安装7.x以上系统)宝塔安装命令:bt.cn(自行获取)(baota我已经安装好了,接下来给大家演示如何操作搭建卡信乐)ssh输入宝塔命令会自动安装好自己查看一下登陆地址和账号密码就可以登陆面板后安装apache2.4+mysql5.5+php5.6phpadmin4.7(应该都会安装把!)登陆宝塔,打开网站的根目录的home文件夹,上传源码然后解压上传好后解压文件修改vhost文件里的域名创建一个数据库yunos数据库

  • initramfs学习「建议收藏」

    initramfs学习「建议收藏」(一)helloworld一、initramfs是什么在2.6版本的linux内核中,都包含一个压缩过的cpio格式的打包文件。当内核启动时,会从这个打包文件中导出文件到内核的rootfs文件系统,然后内核检查rootfs中是否包含有init文件,如果有则执行它,作为PID为1的第一个进程。这个init进程负责启动系统后续的工作,包括定位、挂载“真正的”根文件系统设备(如果有的话)。

发表回复

您的电子邮箱地址不会被公开。

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