C++和OpenCV實現圖像字符化效果
作者:翟天保Steven
版權聲明:著作權歸作者所有,商業轉載請聯系作者獲得授權,非商業轉載請註明出處
實現原理
圖像字符化的意思是將圖像以字符形式呈現,具有一定的娛樂價值。許多開發人員通過python實現該功能,C++實現的代碼較少,因此本文通過C++和OpenCV實現,給予C++開發人員一些可供借鑒的思路。
圖像字符化的實現流程如下:
1.將圖像縮小,如縮小為原尺寸的二十分之一。
2.創建一個同原圖尺寸一致的白色畫佈。
3.遍歷縮小圖像的灰度值,根據灰度值數值的不同,選擇不同的字符。
4.將字符以20*20的尺寸繪制在畫佈的對應像素位置。註意因為縮小圖像的尺寸為原尺寸二十分之一,所以字符尺寸才是20*20。通俗的講,原尺寸1000*1000,縮小圖像為50*50,那總共就有2500個字符,每個字符的尺寸為20*20,畫滿畫佈剛好是1000*1000。
功能函數代碼
// 圖像字符化 cv::Mat Characterize(cv::Mat src) { // 初始化 cv::Mat re; cv::resize(src, re, cv::Size(0, 0), 0.05, 0.05); cv::Mat result = cv::Mat(src.size(), CV_8UC1, 255); if (src.channels() > 1) { cout << "The number of image channels is greator than 1. " << endl; return result; } // 字符繪制 string str = ""; int row = re.rows; int col = re.cols; for (int i = 0; i < row; ++i) { uchar *t = re.ptr<uchar>(i); for (int j = 0; j < col; ++j) { string temp; char c = Getchar(int(t[j])); temp.push_back(c); // 繪制字符 putText(result, temp, cv::Point(j * 20, (i + 1) * 20), cv::FONT_HERSHEY_TRIPLEX, 0.6, cv::Scalar(0), 1, 16); str += c; } str += "\r\n"; } // 輸出txt OutToFile(txt, str); return result; }
C++測試代碼
#include <iostream> #include <opencv.hpp> #include <string> #include <sstream> #include <Windows.h> #include <fstream> using namespace std; const string ascii_char = "$@B%8&WM#*oahkbdpqwmZO0QLCJUYXzcvunxrjft/\|()1{}[]?-_+~<>i!lI;:,\"^`'. "; const char *txt = "test.txt"; // 獲取字符 char Getchar(int n) { int size = ascii_char.size(); int t = n * size / 256 ; char c = ascii_char[t]; return c; } //將字符串寫入文件 void OutToFile(const char *fileName, string str) { ofstream outStream; outStream.open(fileName); outStream << str << endl; outStream.close(); } // 圖像字符化 cv::Mat Characterize(cv::Mat src) { // 初始化 cv::Mat re; cv::resize(src, re, cv::Size(0, 0), 0.05, 0.05); cv::Mat result = cv::Mat(src.size(), CV_8UC1, 255); if (src.channels() > 1) { cout << "The number of image channels is greator than 1. " << endl; return result; } // 字符繪制 string str = ""; int row = re.rows; int col = re.cols; for (int i = 0; i < row; ++i) { uchar *t = re.ptr<uchar>(i); for (int j = 0; j < col; ++j) { string temp; char c = Getchar(int(t[j])); temp.push_back(c); // 繪制字符 putText(result, temp, cv::Point(j * 20, (i + 1) * 20), cv::FONT_HERSHEY_TRIPLEX, 0.6, cv::Scalar(0), 1, 16); str += c; } str += "\r\n"; } // 輸出txt OutToFile(txt, str); return result; } int main() { // 加載灰度圖 cv::Mat src = cv::imread("6.jpg", 0); // 圖像字符化 cv::Mat result = Characterize(src); // 顯示 cv::imshow("src", src); cv::imshow("result", result); cv::waitKey(0); system("pause"); return 0; }
測試效果
圖1灰度圖
圖2圖像字符化
圖3txt字符圖
OpenCV中putText函數可以將字符繪制在圖像中,但是這種方式並不是最優的解決方案,采用其他專用的圖形繪制庫,繪制的效率可能會更高,感興趣的可以自行測試。
如果函數有什麼可以改進完善的地方,非常歡迎大傢指出,一同進步何樂而不為呢~
到此這篇關於OpenCV-圖像字符化的文章就介紹到這瞭,更多相關OpenCV圖像字符化內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- OpenCV實現更改圖片顏色功能
- 基於OpenCV自定義色條實現灰度圖上色功能代碼
- C++基於灰度圖上色GrayToColorFromOther的實現
- C++ Opencv自寫函數實現膨脹腐蝕處理技巧
- OpenCV去除綠幕摳圖源碼