2014 4.20

近期想做一个关于图像处理的软件玩玩,可惜也没有什么特别的想法,就当玩玩好了,准备用Opencv开源库实现下简单的功能吧。

Opencv是一个专业的图像处理库,里面有非常多基础函数能够实现非常多非常多功能,明天開始动工吧,真是兴致来了挡也档不住,思考一晚上!

2014 4.21

本来想用Vs2010做下,发现配置有点麻烦,还是选择Vc6干吧,选用的库为 Opencv1.0.

配置Visual C++ 6.0

全局设置

菜单Tools->Options->Directories:先设置lib路径,选择Library files,在下方填入路径:

E:\OpenCV\lib

然后选择include files,在下方填入路径:

E:\OpenCV\cxcore\include

E:\OpenCV\cv\include

E:\OpenCV\cvaux\include

E:\ml\include

E:\OpenCV\otherlibs\highgui

E:\otherlibs\cvcam\include

然后选择source files,在下方填入路径:

E:\OpenCV\cv\src

E:\OpenCV\cxcore\src

E:\OpenCV\cvaux\src

E:\OpenCV\otherlibs\highgui

E:\OpenCV\otherlibs\cvcam\src\windows

还有就是配置系统环境变量 E:\OpenCV\bin

然后选择右边的link标签,在Object/library modules附加上

cxcore.lib cv.lib ml.lib cvaux.lib highgui.lib cvcam.lib

关于配置的基本就到这里了,该用的基本都用上了。

以下就開始做小demo測试了。

2014 4.28

近期事情有点多,偷懒不想写,还是坚持下吧。

以下做一个人脸检測的demo,基于Win32 application,功能大致实现了,代码网上也有非常多,我来分析下代码吧。

#include "cv.h"    //核心头文件

#include "highgui.h"//图像处理头文件

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

#include <assert.h>

#include <math.h>

#include <float.h>

#include <limits.h>

#include <time.h>

#include <ctype.h>

#ifdef _EiC

#define WIN32

#endif

static CvMemStorage* storage = 0;

static CvHaarClassifierCascade* cascade = 0;

void detect_and_draw( IplImage* image );

const char* cascade_name =

"D:\\OpenCV 1.0\\data\\haarcascades\\haarcascade_frontalface_alt.xml";//人脸检測库文件

/*    "haarcascade_profileface.xml";*/

int main( int argc, char** argv )

{

    //cascade_name = "haarcascade_frontalface_alt.xml";

    cascade = (CvHaarClassifierCascade*)cvLoad( cascade_name, 0, 0, 0 );

 

    if( !cascade )

    {

        fprintf( stderr, "ERROR: Could not load classifier cascade\n" );

        return -1;

    }

    storage = cvCreateMemStorage(0);

    cvNamedWindow( "result", 1 ); //创建一个窗体 名称为result

    

    const char* filename = "D:\\lena.jpg"; //目标图片

    IplImage* image = cvLoadImage( filename, 1 );

if( image )

    {

        detect_and_draw( image );

        cvWaitKey(0);

        cvReleaseImage( &image );  

    }

cvDestroyWindow("result");

 

    return 0;

}

void detect_and_draw(IplImage* img ) //把脸部范围圈出来

{

    double scale=1.2;

    static CvScalar colors[] = {

        {{0,0,255}},{{0,128,255}},{{0,255,255}},{{0,255,0}},

        {{255,128,0}},{{255,255,0}},{{255,0,0}},{{255,0,255}}

    };//Just some pretty colors to draw with

//Image Preparation

    //

    IplImage* gray = cvCreateImage(cvSize(img->width,img->height),8,1);

    IplImage* small_img=cvCreateImage(cvSize(cvRound(img->width/scale),cvRound(img->height/scale)),8,1);


    cvCvtColor(img,gray, CV_BGR2GRAY);

    cvResize(gray, small_img, CV_INTER_LINEAR);

cvEqualizeHist(small_img,small_img); //直方图均衡

//Detect objects if any

    //

    cvClearMemStorage(storage);

    double t = (double)cvGetTickCount();

    CvSeq* objects = cvHaarDetectObjects(small_img,

                                                                        cascade,

                                                                        storage,

                                                                        1.1,

                                                                        2,

                                                                        0/*CV_HAAR_DO_CANNY_PRUNING*/,


                                                                        cvSize(30,30));

t = (double)cvGetTickCount() - t;

    printf( "detection time = %gms\n", t/((double)cvGetTickFrequency()*1000.) );

//Loop through found objects and draw boxes around them

   

 for(int i=0;i<(objects? objects->total:0);++i)

    {

        CvRect* r=(CvRect*)cvGetSeqElem(objects,i);

        cvRectangle(img, cvPoint(r->x*scale,r->y*scale), cvPoint((r->x+r->width)*scale,(r->y+r->height)*scale), colors[i%8]);


    }

   

 /*for( int j= 0; j < (objects? objects->total : 0); j++ )

    {

        CvRect* r = (CvRect*)cvGetSeqElem( objects, j );

        CvPoint center;

        int radius;

        center.x = cvRound((r->x + r->width*0.5)*scale);

        center.y = cvRound((r->y + r->height*0.5)*scale);

        radius = cvRound((r->width + r->height)*0.25*scale);

        cvCircle( img, center, radius, colors[j%8], 3, 8, 0 );

    }*/

cvShowImage( "result", img );

    cvReleaseImage(&gray);

    cvReleaseImage(&small_img); //记得创建的指针得释放

}

效果大致是这种,把脸部圈出来了。

基于Opencv图像处理的时时头像採集试验的更多相关文章

  1. 基于matlab的音频波形实时採集显示 v0.1

    robj = audiorecorder(44100,16,1); %设置採样频率.採样位数.通道数 recordblocking(robj,1); %採集初步数据(1s长度) rdata = get ...

  2. 基于opencv在摄像头ubuntu根据视频获取

     基于opencv在摄像头ubuntu根据视频获取 1  工具 原料 平台 :UBUNTU12.04 安装库  Opencv-2.3 2  安装编译执行步骤 安装编译opencv-2.3  參考h ...

  3. STM32F103频率和AD採集项目总结

    刚刚做了我的第一个嵌入式项目----基于STM32F103的频率和AD採集系统. 是一个大系统的一个部分.没用操作系统,使用库函数编写,尽管东西非常easy.可是对于我这个还没入门的菜鸟来说还是有点难 ...

  4. 基于Opencv和Mfc的图像处理增强库GOCVHelper(索引)

    GOCVHelper(GreenOpen Computer Version Helper )是我在这几年编写图像处理程序的过程中积累下来的函数库.主要是对Opencv的适当扩展和在实现Mfc程序时候的 ...

  5. 【源代码】基于Android和蓝牙的单片机温度採集系统

    如需转载请标明出处:http://blog.csdn.net/itas109 QQ技术交流群:129518033 STC89C52单片机通过HC-06蓝牙模块与Android手机通信实例- 基于And ...

  6. 【MFC两种视频图像採集方法】DirectShow与Opencv

    效果图: DirectShow採集核心代码: 创建线程调用该函数,採集图像通过x264解码封装rtmp协议包.推送至FMSserver,可实现视频直播 UINT __stdcall StartVide ...

  7. 基于lucene的案例开发:纵横小说分布式採集

    转载请注明出处:http://blog.csdn.net/xiaojimanman/article/details/46812645 http://www.llwjy.com/blogdetail/9 ...

  8. 基于 opencv 的图像处理入门教程

    前言 虽然计算机视觉领域目前基本是以深度学习算法为主,但实际上很多时候对图片的很多处理方法,并不需要采用深度学习的网络模型,采用目前成熟的图像处理库即可实现,比如 OpenCV 和 PIL ,对图片进 ...

  9. Python图像处理丨基于OpenCV和像素处理的图像灰度化处理

    摘要:本篇文章讲解图像灰度化处理的知识,结合OpenCV调用cv2.cvtColor()函数实现图像灰度操作,使用像素处理方法对图像进行灰度化处理. 本文分享自华为云社区<[Python图像处理 ...

随机推荐

  1. 升级版:深入浅出Hadoop实战开发(云存储、MapReduce、HBase实战微博、Hive应用、Storm应用)

          Hadoop是一个分布式系统基础架构,由Apache基金会开发.用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力高速运算和存储.Hadoop实现了一个分布式文件系 ...

  2. ASP.NET - TreeView

    设置节点图片 : Windows资源管理器左侧的树型资源结构图中,各节点都有图片连接,例如磁盘的图片.光盘的图片和文件夹的图片等,使资源的表现更加形象.IEWebControls的TreeView控件 ...

  3. HTTPClient和URLConnection核心区别分析

    首先:在 JDK 的 java.net 包中已经提供了访问 HTTP 协议的基本功能:HttpURLConnection.但是对于大部分应用程序来说,JDK 库本身提供的功能还不够丰富和灵活. 在An ...

  4. 谈谈Ext JS的组件——布局的用法续二

    绝对布局(Ext.layout.container.Absolute) 绝对布局让我回忆到了使用Foxpro开发的时候,哪时候的界面布局就是这样.通过设置控件的左上角坐标(x.y)和宽度来进行的,由于 ...

  5. 怎样配置PHP环境和安装Zendstdio编辑器

    想学习PHP好久了.苦于环境配置不好,一直感觉无从下手. 在网上找了个视频: 李炎恢PHP教程 第一章前3节给出了具体的配置的方法,即安装Apache和Zendstudio 10.5仅仅须要照着视频做 ...

  6. Could not find or load main class

    Then add '.' to your $CLASSPATH with CLASSPATH=.:$CLASSPATH or as a paramater with java -classpath . ...

  7. cct信息安全

    基本信息 全国计算机等级考试三级教程——信息安全技术(2016年版) 作    者:教育部考试中心 编 出 版 社:高等教育出版社 出版时间:2015-12-1 ISBN:9787040443035 ...

  8. 条款38 通过复合塑膜出has-a或&quot;依据某物实现&quot;

    结论: 复合的意义和public继承全然不同. (public继承參考:条款32 确定你的public继承塑模出is-a关系) 在应用域,复合意味着has-a(有一个).在实现域,复合意味着is-im ...

  9. python web

    [root@xen202 wbk]# python -m SimpleHTTPServerServing HTTP on 0.0.0.0 port 8000 ...

  10. 使用gulp创建ajax模拟请求

    概述 之前一直使用gulp构建前端项目,这个基于node流并崇尚“编程而非配置”的工具让我深深的爱上了他.强大的gulp能做到的不仅仅是压缩和合并js.css,它能做到的还有更多.今天我给大家带来使用 ...