OpenCV官網(wǎng)首頁:https://opencv.org/
OpenCV GitHub: https://github.com/opencv
OpenCV 下載: https://opencv.org/releases/
mac 安裝opencv
brew install opencv
可能對于新手有個種問題入撒,解決不難
OpenCV 及切換版本
- 如果要安裝其它版本,如 OpenCV3、OpenCV2肤寝,則 使用如下命令
brew install opencv@3
brew install opencv@2
安裝后的位置:
本體:/usr/local/Cellar
以下均以鏈接形式存在:頭文件:/usr/local/include
庫文件:/usr/local/lib
cmake module:/usr/local/share
二進(jìn)制文件:/usr/local/bin寂玲,只是自帶的幾個Demo
符號鏈接: /usr/local/opt壹无,不知道干啥用的
通過 opencv_version 命令可以查看當(dāng)前 opencv 版本拍埠,首位數(shù)就是大版本號。
目前 OpenCV 有 3 個大版本分別是 2速和、3、4耸别,可以通過 brew 同時安裝這幾個版本健芭,然后通過命令切換大版本。
比如從 版本4 切換到 版本3:
- 首先 unlink 當(dāng)前版本秀姐。
brew unlink opencv@4
- 然后 link 想要的版本慈迈。
需要加 --force 選項
brew link opencv@3 --force
- 完成切換
此時相關(guān)的頭文件、庫文件的鏈接就都轉(zhuǎn)到 /usr/local/Cellar/opencv@3 上了省有。
可通過 opencv_version 命令看看當(dāng)前的 opencv 版本痒留。
用Clion環(huán)境
可以減少配置量,專業(yè)c環(huán)境
圖片處理識別文字思路
第一步: 圖片灰度化(提升效率蠢沿,只考慮灰度值就好了)
第二步:二值化
比如伸头,灰度0~255 ,去掉0到100舷蟀,保留101到255
第三步:輪廓檢測
多有連續(xù)的閉包用矩形框起來
第四步:腐蝕膨脹恤磷,erode(矩形連貫起來)
opencv 測試環(huán)境面哼,打開圖片,圖片去顏色
#include <iostream>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int main1() {
Mat srcImage = imread("/Users/zcw/Downloads/WechatIMG12683.jpeg");
if (!srcImage.data) {
std::cout << "Image not loaded";
return -1;
}
imshow("[img]", srcImage);
waitKey(0);
return 0;
}
int main2() {
Mat src = imread("/Users/zcw/Downloads/download_temp/id_card.jpg");
if (!src.data) {
std::cout << "Image not loaded";
return -1;
}
Mat gray, color_boost;
decolor(src, gray, color_boost);
imshow("Source Image", src);
imshow("grayscale", gray);
imshow("color_boost", color_boost);
waitKey(0);
return 0;
}
完整識別身份證號碼等demo
-> 目的是可以將代碼移植到 Android修改扫步,唯一要修改的是Mat和Bitmap的轉(zhuǎn)換用來展示用魔策,這里用pc做測試
#include <iostream>
#include <opencv2/opencv.hpp>
#include <opencv2/photo.hpp>
#include <opencv2/imgproc.hpp>
#include <opencv2/highgui.hpp>
#include <opencv2/core.hpp>
using namespace std;
using namespace cv;
#define DEFAULT_CARD_WIDTH 640
#define DEFAULT_CARD_HEIGHT 400
#define FIX_IDCARD_SIZE Size(DEFAULT_CARD_WIDTH,DEFAULT_CARD_HEIGHT)
#define FIX_TEMPLATE_SIZE Size(153, 28)
int main() {
Mat src_img = imread("/Users/zcw/Downloads/download_temp/id_card.jpg");
imshow("src_", src_img);
Mat dst_img;
Mat dst;
//無損壓縮//640*400
resize(src_img, src_img, FIX_IDCARD_SIZE);
imshow("dst", src_img);
//灰度化
cvtColor(src_img, dst, COLOR_BGR2GRAY);
imshow("gray", dst);
//二值化
threshold(dst, dst, 100, 255, THRESH_BINARY);
imshow("threshold", dst);
//加水膨脹,發(fā)酵
Mat erodeElement = getStructuringElement(MORPH_RECT, Size(20, 10));
erode(dst, dst, erodeElement);
imshow("erode", dst);
//輪廓檢測 // arraylist
vector< vector<Point> > contours;
vector<Rect> rects;
findContours(dst, contours, RETR_TREE, CHAIN_APPROX_SIMPLE, Point(0, 0));
for (int i = 0; i < contours.size(); i++)
{
Rect rect = boundingRect(contours.at(i));
//rectangle(dst, rect, Scalar(0, 0, 255)); // 在dst 圖片上顯示 rect 矩形
if (rect.width > rect.height * 9) {
rects.push_back(rect);
rectangle(dst, rect, Scalar(0,255,255));
dst_img = src_img(rect);
}
}
// imshow("輪廓檢測", dst);
imshow("lkjc", dst);
if (rects.size() == 1) {
Rect rect = rects.at(0);
dst_img = src_img(rect);
}
else {
int lowPoint = 0;
Rect finalRect;
for (int i = 0; i < rects.size(); i++)
{
Rect rect = rects.at(i);
Point p = rect.tl();
if (rect.tl().y > lowPoint) {
lowPoint = rect.tl().y;
finalRect = rect;
}
}
rectangle(dst, finalRect, Scalar(255, 255, 0));
imshow("contours", dst);
dst_img = src_img(finalRect);
}
if (!dst_img.empty()) {
imshow("target", dst_img);
}
src_img.release();
dst_img.release();
dst.release();
waitKey(0);
return 0;
}