#include<opencv2/core.hpp>
#include<opencv2/highgui.hpp>
#include<opencv2/imgproc.hpp>
#include<iostream>
using namespace std;
using namespace cv;
void getBlueMask(IplImage*src, IplImage*dst);
int main(){
//读入原始图像
IplImage*src_image=cvLoadImage("C:\\Users\\aoe\\Desktop\\chepai-matlab\\chepai3.jpg");
//生成原始图像的一个副本,方便处理
IplImage *Psrc_image = cvCreateImage(cvGetSize(src_image), src_image->depth, src_image->nChannels);
Psrc_image = cvCloneImage(src_image);
//将RGB模型转换成HSV模型
IplImage *hsv = cvCreateImage(cvGetSize(Psrc_image), IPL_DEPTH_8U, 3);
cvCvtColor(Psrc_image, hsv, CV_BGR2HSV);
//将彩色图像转换成灰度图像
IplImage*blue = cvCreateImage(cvGetSize(Psrc_image), IPL_DEPTH_8U, 1);
cvCvtColor(Psrc_image, blue, CV_BGR2GRAY);
//利用车牌蓝底白字对车牌区域进行检索,车色车牌区域保留,非车牌区域置0
getBlueMask(hsv, blue);
cvNamedWindow("blue");
cvShowImage("blue", blue);
//二值化,将车牌区域置为白色
IplImage*bin = cvCreateImage(cvGetSize(Psrc_image), IPL_DEPTH_8U, 1);
cvThreshold(blue, bin, 0, 255, CV_THRESH_BINARY);
cvNamedWindow("bin");
cvShowImage("bin", bin);
//保留一个副本
IplImage*image = cvCreateImage(cvGetSize(Psrc_image), IPL_DEPTH_8U, 1);
cvCopy(bin, image);
cvNamedWindow("image");
cvShowImage("image", image);
//水平投影
<
车牌区域定位——opencv
最新推荐文章于 2024-05-02 14:24:14 发布
本文介绍如何利用OpenCV库进行车牌区域的精准定位,包括图像预处理、特征检测和轮廓识别等步骤,适用于智能交通系统和车辆识别技术。
摘要由CSDN通过智能技术生成