《Mastering Opencv读书笔记》第一章 实现图像卡通效果

简介: 这本书和配套代码网上都有得下载。 要实现书中的效果,只要三步:1.使用拉普拉斯算子提取轮廓  2.使用双边滤波器对图像进行平滑 3.根据第一步得到的轮廓模版图,将第二步的结果拷贝过去【填充轮廓图中全白的部分】 由于我的笔记本摄像头坏了,故我的程序读取的是手机拍摄的视频。

这本书和配套代码网上都有得下载。

要实现书中的效果,只要三步:1.使用拉普拉斯算子提取轮廓  2.使用双边滤波器对图像进行平滑 3.根据第一步得到的轮廓模版图,将第二步的结果拷贝过去【填充轮廓图中全白的部分】

由于我的笔记本摄像头坏了,故我的程序读取的是手机拍摄的视频。

下面给出我整理的两段代码:

1.边缘提取:

// GetMySketch.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include<iostream>
#include <opencv2/core/core.hpp>  
#include <opencv2/highgui/highgui.hpp>  
#include <opencv2/imgproc/imgproc.hpp>  
using namespace std;
using namespace cv;

int _tmain(int argc, _TCHAR* argv[])
{
	VideoCapture m_caputre("test2.avi");
	Mat m_frame,gray,edges,masks;
	const int MEDIAN_BLUR_FILTER_SIZE = 7;
	const int LAPLACIAN_FILTER_SIZE = 5;
	const int EDGES_THRESHOLD = 80;

	while (true)
	{
		m_caputre>>m_frame;
		if (m_frame.empty()) {
			std::cerr << "ERROR: Couldn't grab a video frame." <<
				std::endl;
			exit(1);
		}

		cvtColor(m_frame,gray,CV_BGR2GRAY);

		medianBlur(gray,gray,MEDIAN_BLUR_FILTER_SIZE);
		
		Laplacian(gray, edges, CV_8U, LAPLACIAN_FILTER_SIZE);

		threshold(edges, masks, EDGES_THRESHOLD, 255, THRESH_BINARY_INV);

		// Display the processed image onto the screen.
		imshow("keep smile :)", masks);
		char keypress = cv::waitKey(20); // Need this to see anything!
		if (keypress==27)
		{
			break;
		}
	}
	return 0;
}
边缘检测结果:


2.最终卡通效果:

// ColorPainting_Cartoon.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include<iostream>
#include <opencv2/core/core.hpp>  
#include <opencv2/highgui/highgui.hpp>  
#include <opencv2/imgproc/imgproc.hpp>  
using namespace std;
using namespace cv;

int _tmain(int argc, _TCHAR* argv[])
{
	VideoCapture m_capture("test2.avi");
	Mat m_frame,smallImg,tmp,bigImg,gray,edges,masks,dst;
	int repetitions = 7; // Repetitions for strong cartoon effect.
	const int MEDIAN_BLUR_FILTER_SIZE = 7;
	const int LAPLACIAN_FILTER_SIZE = 5;
	const int EDGES_THRESHOLD = 80;

	m_capture>>m_frame;
	Size size = m_frame.size();
	Size smallSize;
	smallSize.width = size.width/2;
	smallSize.height = size.height/2;
	smallImg = Mat(smallSize, CV_8UC3);
	tmp = Mat(smallSize, CV_8UC3);
	dst= Mat(size,CV_8UC3);

	while (true)
	{
		m_capture>>m_frame;
		if (m_frame.empty()) {
			std::cerr << "ERROR: Couldn't grab a video frame." <<
				std::endl;
			exit(1);
		}

		cvtColor(m_frame,gray,CV_BGR2GRAY);

		medianBlur(gray,gray,MEDIAN_BLUR_FILTER_SIZE);

		Laplacian(gray, edges, CV_8U, LAPLACIAN_FILTER_SIZE);

		threshold(edges, masks, EDGES_THRESHOLD, 255, THRESH_BINARY_INV);

		resize(m_frame, smallImg, smallSize, 0,0, INTER_LINEAR);
		
		for (int i=0; i<repetitions; i++) {
			int ksize = 9; // Filter size. Has a large effect on speed.
			double sigmaColor = 9; // Filter color strength.
			double sigmaSpace = 7; // Spatial strength. Affects speed.
			bilateralFilter(smallImg, tmp, ksize, sigmaColor, sigmaSpace);
			bilateralFilter(tmp, smallImg, ksize, sigmaColor, sigmaSpace);
		}

		resize(smallImg, bigImg, size, 0,0, INTER_LINEAR);

		dst.setTo(0);

		//! copies those matrix elements to "m" that are marked with non-zero mask elements.
		bigImg.copyTo(dst,masks);

		// Display the processed image onto the screen.
		imshow("keep smile :)", dst);
		char keypress = cv::waitKey(20); // Need this to see anything!
		if (keypress==27)
		{
			break;
		}
	}
	return 0;
}
最终效果图:


第一章很简单,后面的肤色模型很水,就没去弄。下一篇,为实现如何将上述代码移植到android平台上。

目录
相关文章
|
3月前
|
计算机视觉
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
这篇文章详细介绍了OpenCV库中的图像二值化函数`cv2.threshold`,包括二值化的概念、常见的阈值类型、函数的参数说明以及通过代码实例展示了如何应用该函数进行图像二值化处理,并展示了运行结果。
791 0
Opencv学习笔记(三):图像二值化函数cv2.threshold函数详解
|
4月前
|
算法 计算机视觉
opencv图像形态学
图像形态学是一种基于数学形态学的图像处理技术,它主要用于分析和修改图像的形状和结构。
67 4
|
4月前
|
存储 计算机视觉
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
本文介绍了使用OpenCV进行图像读取、显示和存储的基本操作,以及如何绘制直线、圆形、矩形和文本等几何图形的方法。
Opencv的基本操作(一)图像的读取显示存储及几何图形的绘制
|
5月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
WK
|
5月前
|
编解码 计算机视觉 Python
如何在OpenCV中进行图像转换
在OpenCV中,图像转换涉及颜色空间变换、大小调整及类型转换等操作。常用函数如`cvtColor`可实现BGR到RGB、灰度图或HSV的转换;`resize`则用于调整图像分辨率。此外,通过`astype`或`convertScaleAbs`可改变图像数据类型。对于复杂的几何变换,如仿射或透视变换,则可利用`warpAffine`和`warpPerspective`函数实现。这些技术为图像处理提供了强大的工具。
WK
165 1
|
7月前
|
算法 计算机视觉
【Qt&OpenCV 图像的感兴趣区域ROI】
【Qt&OpenCV 图像的感兴趣区域ROI】
264 1
|
7月前
|
运维 算法 计算机视觉
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
【Qt&OpenCV 图像的模板匹配 matchTemplate/minMaxLoc】
101 1
|
7月前
|
存储 编解码 算法
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
【Qt&OpenCV 检测图像中的线/圆/轮廓 HoughLinesP/HoughCircles/findContours&drawContours】
129 0
|
6月前
|
机器学习/深度学习 XML 计算机视觉
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
OpenCV(Open Source Computer Vision Library)是一个开源的计算机视觉和机器学习库,它提供了大量的函数和工具,用于处理图像和视频数据。
|
7月前
|
算法 计算机视觉
【Qt&OpenCV 图像边缘检测 Sobel/Laplace/Canny】
【Qt&OpenCV 图像边缘检测 Sobel/Laplace/Canny】
95 0