拟采用的技术路线
本次设计计划以最快的速度实现一个清晰车牌的识别,后续再增加识别精确度,故采取以下技术路线本篇文章主要讲述图像二值化的实现。
打开图像->二值化->边沿检测->包络检测->提取轮廓->车牌识别
车牌图片打开
第一步就是将车牌图片打开,车牌图片打开使用QT中的标准化窗口QFileDialog::getOpenFileName()
打开文件之后,使用QPixmap类进行图片的接收,QPixmap类能够很方便的进行图片的缩放,但是不利于进行单个像素的操作,故在打开过程中,还添加了Qimage私有变量存储像素信息。
void MainWindow::slot_open()
{
qDebug()<<"slot_openFile";
QString filename=QFileDialog::getOpenFileName(this, QString("选择图片文件"), "", QString("图片文件格式(*.jpg *.png *.jpeg *. bmp)"));
qDebug()<<"filename == "<<filename;
QPixmap pixmap(filename);
//QPixmap fitpixmap = pixmap.scaled(IMGW, IMGH, Qt::IgnoreAspectRatio, Qt::SmoothTransformation); // 饱满填充
QPixmap fitpixmap = pixmap.scaled(IMGW,IMGH, Qt::KeepAspectRatio); // 按比例缩放
m_qimg=fitpixmap.toImage();
img_lable->setPixmap(fitpixmap);
}
图片二值化
车牌的图片二值化是进行图片识别必须的过程,通过对图像的二值化,能够减少多余的信息,只保留黑白两种颜色,方便进行对图像的遍历等算法取出车牌信息。
void MainWindow::slot_black_whtite()
{
QColor pix;
int red_value;
qDebug()<<m_qimg.width()<<m_qimg.height();
for (int x=0;x<m_qimg.width();x++) {//遍历像素,进行二值化
for(int y=0;y<m_qimg.height();y++){
pix=QColor::fromRgb(m_qimg.pixel(x,y));
red_value=pix.red();
if(red_value>100){//以红色100为界,进行二值化
red_value=0;
}
else{
red_value=255;
}
pix.setRed(red_value);
pix.setBlue(red_value);
pix.setGreen(red_value);
m_qimg.setPixelColor(x,y,pix);
}
}
QPixmap fitpixmap=QPixmap::fromImage(m_qimg);
img_lable->setPixmap(fitpixmap);
}
窗口UI实现
窗口UI实现不建议使用QT的UI设计方式实现,当软件非常庞大的时候,UI设计的方式将会非常难维护,使用代码直接进行UI实现的方式一开始会不习惯,但熟练之后会非常方便。
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
{
// QTextLine * get_num=new QLineEdit;
widget=new QWidget(this);
vLayout=new QVBoxLayout;
btn1=new QPushButton(this);
btn2=new QPushButton(this);
img_lable=new QLabel(this);
img_lable->setFixedSize(IMGW,IMGH);
vLayout->addWidget(img_lable);
btn1->setText("打开图片");
vLayout->addWidget(btn1);
btn2->setText("二值化处理");
vLayout->addWidget(btn2);
widget->setLayout(vLayout);
this->setCentralWidget(widget);
connect(btn1,SIGNAL(clicked()),this,SLOT(slot_open()));
connect(btn2,SIGNAL(clicked()),this,SLOT(slot_black_whtite()));
}