车牌区域定位——opencv

本文介绍如何利用OpenCV库进行车牌区域的精准定位,包括图像预处理、特征检测和轮廓识别等步骤,适用于智能交通系统和车辆识别技术。
摘要由CSDN通过智能技术生成
#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);
//水平投影
<
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值