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图像字符化内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++ OpenCV实战之图像全景拼接

    目录 前言 一.OpenCV Stitcher 1.功能源码 2.效果 二.图像全景拼接 1.特征检测 2.计算单应性矩阵 3.透视变换 4.图像拼接 5.功能源码 6.效果 三.源码 总结 前言 本文将使用OpenCV C++ 进行图像全景拼接.目前使用OpenCV对两幅图像进行拼接大致可以分为两类. 一.使用OpenCV内置API Stitcher 进行拼接. 二.使用特征检测算法匹配两幅图中相似的点.计算变换矩阵.最后对其进行透视变换就可以了. 一.OpenCV Stitcher imag

  • 使用c++实现OpenCV图像横向&纵向拼接

    功能函数 // 图像拼接 cv::Mat ImageSplicing(vector<cv::Mat> images,int type) { if (type != 0 && type != 1) type = 0; int num = images.size(); int newrow = 0; int newcol = 0; cv::Mat result; // 横向拼接 if (type == 0) { int minrow = 10000; for (int i = 0;

  • C++ OpenCV实战之图像透视矫正

    目录 前言 一.图像预处理 二.轮廓提取 1.提取最外轮廓 2.提取矩形四个角点 3.将矩形角点排序 三.透视矫正 四.源码 前言 本文将使用OpenCV C++ 进行图像透视矫正. 一.图像预处理 原图如图所示.首先进行图像预处理.将图像进行灰度.滤波.二值化.形态学等操作,目的是为了下面的轮廓提取.在这里我还使用了形态学开.闭操作,目的是使整个二值图像连在一起.大家在做图像预处理时,可以根据图像特征自行处理. Mat gray; cvtColor(src, gray, COLOR_BGR2G

  • C++ OpenCV中几种基本的图像处理方式

    目录 一.图像显示 1.OpenCV的命名空间 2.Mat类简析 3.图像的载入:imread()函数 4.imshow()函数 二.图像腐蚀和膨胀 三.图像模糊 四.canny边缘检测 虽然单单要做车牌号识别的话不需要特别多种类的图像处理,但是我们不能只是为了这么一个目标去学习,所以这次就讲一些OpenCV里基本的图像处理,大家以后可以根据需求使用不同的图像处理. 一.图像显示 [打开Visual Studio]→[新建项目]→[Win32控制台应用项目(修改名称后点确定)]→[下一步]→[空

  • C++使用opencv读取图片的操作代码(图像处理)

    目录 代码理解 全部代码 读取结果 参考 代码理解 using namespace cv; 解释:加入此代码,后面就不需要在函数前加入cv:: 如从cv::imread(),可以直接写成imread() int main(int argc, char** argv) { return 0: } 解释: // argc是命令行,总的参数个数; argv[]是argc个参数,其中第0个参数是程序的全名,以后的参数命令行后面跟的用户输入的参数 // char *argv[] 用来取得你所输入的参数 /

  • OpenCV和C++实现图像的翻转(镜像)、平移、旋转、仿射与透视变换

    目录 一.翻转(镜像) 二.仿射扭曲 获取变换矩阵 仿射扭曲函数 warpAffine 旋转 平移 三.仿射变换 四.透视变换 综合示例 总结 官网教程 一.翻转(镜像) 头文件 quick_opencv.h:声明类与公共函数 #pragma once #include <opencv2\opencv.hpp> using namespace cv; class QuickDemo { public: ... void flip_Demo(Mat& image); void rotat

  • C++ OpenCV实现图像修复功能

    目录 前言 一.OpenCV inpaint 二.源码 三.效果显示 前言 本文将使用OpenCV C++ 对有瑕疵的图像进行修复.OpenCV 提供了inpaint API可进行图像修复. 一.OpenCV inpaint 原图如图所示.本案例的需求是希望能够将图像上的红线给消除.OpenCV 提供的inpaint API能够实现这个效果. void inpaint( InputArray src, 原图 InputArray inpaintMask, 二进制掩模,指示要修复的像素 Outpu

  • C++和OpenCV实现图像字符化效果

    目录 实现原理 功能函数代码 作者:翟天保Steven版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处 实现原理 图像字符化的意思是将图像以字符形式呈现,具有一定的娱乐价值.许多开发人员通过python实现该功能,C++实现的代码较少,因此本文通过C++和OpenCV实现,给予C++开发人员一些可供借鉴的思路. 图像字符化的实现流程如下: 1.将图像缩小,如缩小为原尺寸的二十分之一. 2.创建一个同原图尺寸一致的白色画布. 3.遍历缩小图像的灰度值,根据灰度值数值的不

  • Java OpenCV实现图像镜像翻转效果

    本文实例为大家分享了Java OpenCV实现图像镜像翻转效果的具体代码,供大家参考,具体内容如下 主要使用OpenCV的flip()方法,可以实现图像的垂直.水平以及同时垂直镜像翻转. flip是Core的静态方法,用法为: public static void flip(Mat src, Mat dst, int flipCode) 参数说明: src:输入图像: dst:输出图像: flipCode: = 0 图像向下翻转 > 0 图像向右翻转 < 0 图像同时向下向右翻转 代码如下:

  • 基于Qt OpenCV的图像灰度化像素操作详解

    效果图 实现代码 #ifndef WIDGET_H #define WIDGET_H #include <QWidget> #include<opencv2/opencv.hpp> using namespace cv; QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACE class Widget : public QWidget { Q_OBJECT public: Widget(QWidget *

  • OpenCV实现图像转换为漫画效果

    本文实例为大家分享了OpenCV实现图像转换为漫画的具体代码,供大家参考,具体内容如下 From <OpenCV By Example> 1.先canny提取图像的边缘并强化,翻转边缘为黑色,将像素值转换为0-1的值 2.将图像进行双边滤波处理,然后将像素值缩短为每10个灰度级为一个值 3.将前两步得到的结果相乘,显示结果 #include <iostream> using namespace std; #include "opencv2/core.hpp" #

  • Python+OpenCV图像处理——图像二值化的实现

    简介:图像二值化就是将图像上的像素点的灰度值设置为0或255,也就是将整个图像呈现出明显的黑白效果的过程. 普通图像二值化 代码如下: import cv2 as cv import numpy as np #全局阈值 def threshold_demo(image): gray = cv.cvtColor(image, cv.COLOR_RGB2GRAY) #把输入图像灰度化 #直接阈值化是对输入的单通道矩阵逐像素进行阈值分割. ret, binary = cv.threshold(gray

  • Python OpenCV实现人物动漫化效果

    目录 前言 效果展示 代码展示 前言 前几天玩抖音,发现一个人像动漫化的操作,觉得很好玩儿.我心想:python既然这么强大,是不是也可以使用python程序来实现这样一个操作呢? 哈哈!我自己当然是没有这个本事编写这样一个牛逼的程序出来,但是百度可以呀,并且还很好用.百度AI开放平台给我们提供了完整的接口,甚至贴心的将代码都给我们写好了.这些接口还支持很多主流语言都呢,像Java.Python.PHP.C#等,我们做的就是直接调用它即可. 效果怎么样呢?我们先来看看下方的对比图吧. 效果展示

  • 详解Python+OpenCV实现图像二值化

    目录 一.图像二值化 1.效果 2.源码 二.图像二值化(调节阈值) 1.源码一 2.源码二 一.图像二值化 1.效果 2.源码 import cv2 import numpy as np import matplotlib.pyplot as plt # img = cv2.imread('test.jpg') #这几行是对图像进行降噪处理,但事还存在一些问题. # dst = cv2.fastNlMeansDenoisingColored(img,None,10,10,7,21) # plt

  • opencv实现图像缩放效果

    本文实例为大家分享了opencv实现图像缩放效果的具体代码,供大家参考,具体内容如下 图像缩放: 图像缩放即对图像的大小进行调整,即放大或者缩小 cv2.resize(src,dsize,fx=0,fy=0,interpolation=cv2.INTER_LINEAR) 参数: 实现代码: import cv2 as cv import matplotlib.pyplot as plt # 中文显示配置 plt.rcParams['font.sans-serif']=['SimHei'] # 用

  • opencv实现图像平移效果

    本文实例为大家分享了opencv实现图像平移效果的具体代码,供大家参考,具体内容如下 图像平移: 按照指定方向和距离,移动到相应位置 格式:cv.warpAffine(img,M,dsize) 参数: 实现代码: import numpy as np import cv2 as cv import matplotlib.pyplot as plt # 中文显示配置 plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签 plt.rcPara

  • 20行Python代码实现视频字符化功能

    我们经常在B站上看到一些字符鬼畜视频,主要就是将一个视频转换成字符的样子展现出来.看起来是非常高端,但是实际实现起来确是非常简单,我们只需要接触opencv模块,就能很快的实现视频字符化.但是在此之前,我们先看看我们实现的效果是怎样的: 上面就是截取的一部分效果图,下面开始进入我们的主题. 一.OpenCV的安装及图片读取 在Python中我们只需要用pip安装即可,我们在控制台执行下列语句: pip install opencv-python 安装完成就可以开始使用.我们先读取一个图片: im

随机推荐