OpenCV由汉字生成图片(透明)----可以对抗论文查重!!!

今天听说很多同志们写毕业论文重复率过高的问题,大牛说用图片代替字就行了,我就想用OpenCV实现一下看看能不能搞,果不其然还是可以的!!!主要的难点在于普通格式的图片背景不透明,需要使用背景透明的png格式图片就行。

主要思想和步骤:

1.首先配置好FreeType与OpenCV,添加编译好的lib,与include目录和CvxText.h和CvxText.cpp就行了,参考[1]

2.说一下思路,主要就是OpenCV版本的问题造成有的函数用的IplImage,而函数

//设置原图像文字

text.putText(ImageSrc, msg, cvPoint(1, size_zi), color);

只能接受IplImage格式的参数,所以保存成png,就比较麻烦了。

png是4个通道,安装BGRA来放置。我们的思路就是按照原来直接给图片上叠加文字的办法,新建与文字大小相同的图片,然后二值化,按照二值模版生成新的png文字图片。

当然二值化算法网上搜了一个自适应阀值的算法效果非常好:参考[3]

3.生成了透明的文字图片,粘贴到论文里面,估计查询重复的系统再牛逼也是无能为力了。后序有空做一些程序界面跟字符分割的东西,可以直接卖钱了。

当然,字体跟大小,上下边距都是可以设置的,后序再往程序里面写。

实现效果:

主要代码:

// AddChinese.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include "CvxText.h"

#pragma comment(lib,"freetype255d.lib")
#pragma comment(lib,"opencv_core2410d.lib")
#pragma comment(lib,"opencv_highgui2410d.lib")
#pragma comment(lib,"opencv_imgproc2410d.lib")   

using namespace std;
using namespace cv;

#define ROW_BLOCK 2
#define COLUMN_Block 2

// writePng.cpp : 定义控制台应用程序的入口点。
//

int run_test_png(Mat &mat,string image_name)
{

	/*采用自己设置的参数来保存图片*/
	//Mat mat(480, 640, CV_8UC4);
	//createAlphaMat(mat);
	vector<int> compression_params;
	compression_params.push_back(CV_IMWRITE_PNG_COMPRESSION);
	compression_params.push_back(9);    //png格式下,默认的参数为3.
	try
	{
		imwrite(image_name, mat, compression_params);
	}
	catch (runtime_error& ex)
	{
		fprintf(stderr, "Exception converting image to PNG format: %s\n", ex.what());
		return 1;
	}
	fprintf(stdout, "Saved PNG file with alpha data.\n");

	waitKey(0);
	return 0;
}

int coloured(Mat &template_src, Mat &mat_png, CvScalar color)
{

	for (int i = 0; i < template_src.rows; ++i)
	{
		for (int j = 0; j < template_src.cols; ++j)
		{
			Vec4b& bgra = mat_png.at<Vec4b>(i, j);
			//int temp = template_src.at<uchar>(i,j);
			if (template_src.at<uchar>(i,j)== 0)
			{
				bgra[0] = color.val[0];    //b通道
				bgra[1] = color.val[1];		//g通道
				bgra[2] = color.val[2];		//r通道
				bgra[3] = 255;//alpha通道全部设置为透明完全透明为0,否则为255
			}
			else
			{
				bgra[3] = 0;//alpha通道全部设置为透明完全透明为0,否则为255
			}

		}
	}

	return 0;
}

void ImageBinarization(IplImage *src)
{	/*对灰度图像二值化,自适应门限threshold*/
	int i,j,width,height,step,chanel,threshold;
	/*size是图像尺寸,svg是灰度直方图均值,va是方差*/
	float size,avg,va,maxVa,p,a,s;
	unsigned char *dataSrc;
	float histogram[256];

	width = src->width;
	height = src->height;
	dataSrc = (unsigned char *)src->imageData;
	step = src->widthStep/sizeof(char);
	chanel = src->nChannels;
	/*计算直方图并归一化histogram*/
	for(i=0; i<256; i++)
		histogram[i] = 0;
	for(i=0; i<height; i++)
		for(j=0; j<width*chanel; j++)
		{
			histogram[dataSrc[i*step+j]-'0'+48]++;
		}
		size = width * height;
		for(i=0; i<256; i++)
			histogram[i] /=size;
		/*计算灰度直方图中值和方差*/
		avg = 0;
		for(i=0; i<256; i++)
			avg += i*histogram[i];
		va = 0;
		for(i=0; i<256; i++)
			va += fabs(i*i*histogram[i]-avg*avg);
		/*利用加权最大方差求门限*/
		threshold = 20;
		maxVa = 0;
		p = a = s = 0;
		for(i=0; i<256; i++)
		{
			p += histogram[i];
			a += i*histogram[i];
			s = (avg*p-a)*(avg*p-a)/p/(1-p);
			if(s > maxVa)
			{
				threshold = i;
				maxVa = s;
			}
		}
		/*二值化*/
		for(i=0; i<height; i++)
			for(j=0; j<width*chanel; j++)
			{
				if(dataSrc[i*step+j] > threshold)
					dataSrc[i*step+j] = 255;
				else
					dataSrc[i*step+j] = 0;
			}
}

Mat binaryzation(Mat &src)
{
	Mat des_gray(src.size(),CV_8UC1);

	cvtColor(src,des_gray,CV_BGR2GRAY);

	//Mat bin_mat();
	IplImage temp(des_gray);
	ImageBinarization(&temp);

	//threshold(des_gray,des_gray,150,255,THRESH_BINARY);
	imshow("二值图像",des_gray);
	return des_gray;
}

int generate_chinese(const int size_zi, const char *msg ,int number,CvScalar color)
{
	//int size_zi = 50;//字体大小
	CvSize czSize;  //目标图像尺寸
	float p = 0.5;
	CvScalar fsize;

	//读取TTF字体文件
	CvxText text("simhei.ttf");     

	//设置字体属性 字体大小/空白比例/间隔比例/旋转角度
	fsize = cvScalar(size_zi, 1, 0.1, 0);
	text.setFont(NULL, &fsize, NULL, &p);      

	czSize.width = size_zi*number;
	czSize.height = size_zi;
	//加载原图像
	IplImage* ImageSrc = cvCreateImage(czSize,IPL_DEPTH_8U,3);//cvLoadImage(Imagename, CV_LOAD_IMAGE_UNCHANGED);
	//Mat image(ImageSrc);
	//createAlphaMat(image);
	//ImageSrc = ?

	//IplImage temp(image);
	//ImageSrc = &temp;

	//设置原图像文字
	text.putText(ImageSrc, msg, cvPoint(1, size_zi), color); 

	//显示原图像
	cvShowImage("原图", ImageSrc);

	string hanzi = msg;
	hanzi = hanzi + ".png";

	Mat chinese(ImageSrc,true);
	Mat gray = binaryzation(chinese);

	imwrite("chinese_gray.jpg",gray);

	Mat mat_png(chinese.size(),CV_8UC4);
	coloured(gray,mat_png,color);
	run_test_png(mat_png,hanzi);
	//
	////cvSaveImage("hanzi.jpg",reDstImage);
	//run_test_png(chinese,hanzi);
	//等待按键事件
	cvWaitKey();
	return 0;
}

int main()
{
	CvScalar color = CV_RGB(0,0,0);
	int size = 200;
	const char* msg = "你好a";//暂时一行字不要太长

	int number = 3;//字符个数

	generate_chinese(size,msg,number,color);

	return 0;
}

完整工程下载:

http://download.csdn.net/detail/wangyaninglm/8486521

参考文献:

http://blog.csdn.net/fengbingchun/article/details/8029337

http://www.oschina.net/code/snippet_1447359_36028

http://blog.csdn.net/hustspy1990/article/details/6301592

时间: 2024-12-22 08:13:07

OpenCV由汉字生成图片(透明)----可以对抗论文查重!!!的相关文章

怎样免费进行论文查重

假设是初次进行论文查重能够在paperpass上进行申请.每一个ID仅能够申请一次,每次能够进行3000字的免费查重,假设不过想改动一下摘要.或者部分自己写的章节能够充分利用这3000字的免费查询,会对我们的论文改动有非常大的帮助,免费查重的网址例如以下.http://www.paperpass.com

免费的论文查重软件

主题:免费的论文查重网站正文:推荐一个免费的论文查重网站PaperFree:http://www.paperfree.cn

免费的论文查重网站

推荐一个免费的论文查重网站PaperFree:http://www.paperfree.cn 活动内容:把上述的主题和正文发布到高校bbs或者科研论坛,然后提交链接,待系统确认后,即可获得5000字检测权.

如何免费进行论文查重

如果是初次进行论文查重可以在paperpass上进行申请,每个ID仅能够申请一次,每次可以进行3000字的免费查重,如果仅仅是想修改一下摘要,或者部分自己写的章节可以充分利用这3000字的免费查询,会对我们的论文修改有很大的帮助,免费查重的网址如下,http://www.paperpass.com

paperDF 瑞克论文查重软件 使用说明

paperDF 瑞克论文查重软件 使用说明 软件下载地址:https://pan.baidu.com/s/1b60LEu 一.软件截图 (软件启动界面) (单文件查重 软件运行界面) 目录文件介绍 二.使用说明 1.本软件是基于JAVA开发,运行本软件需安装JRE1.7或以上版本JAVA运行环境. 2.本软件需作者授权后才能使用.获取授权方法: 1.运行本软件,软件将提示获取授权.请复制授权文本框中的字符串发到作者邮箱获取授权文件. 2.将获取到的授权文件替换软件目录中的mylicense.li

论文查重检测---PaperPass

方法1:PaperPass网站查重 网站登录注册我就不说了:http://www.paperpass.com/login.aspx 检测自己的论文的查重率: 1.可申请免费使用 图1:可以试着先申请免费使用,但只能检测3K字 2.付费查询检测.1K字1元,需要充值. 图2:付费检测 3.检测报告.通过下载检测报告可以看到自己的论文到底哪里和其他人的论文重复了,并且PaperPass给出了详细的报告和综合评估,以及自动修改,能够降低查重率,最后还给出了打印的pdf,给跪了. 图3:检测相似度 图4

如何在线进行学术论文查重

如何在线进行学术论文查重,大家都知道,在大学生毕业的时候会做毕业论文,科学家发明东西后会做研究论文,但写论文不可避免的去网上摘抄相关资料的文献,那如何避免相同文案过多的情况呢,小编这就来告诉你.一:在电脑上准备好,需要进行查重的论文电子文档,因为我们需要通过电脑来对论文重复率进行检测.二:论文在电脑上准备好后,还需要通过电脑浏览器搜索paperpaper论文查重,帮助我们对论文进行检测.三:通过搜索进入到论文查重页面后,在页面上方的功能选项中选择论文检测的选项.四:论文检测的选项进来后,我们需要

PDF阅读器如何实现免费论文查重

一年的紧张的毕业季又要来临.毕业论文写作的战鼓已然敲响.想要论文不二辩,重复就要早发现.为了对论文进行查重,很多同学搜遍了网上的论文查重网站和软件.但是许多论文查重网站对PDF文档的论文查重准确率都不高. 今天就给各位同学介绍如何在PDF阅读器实现免费论文查重. 首先需要一款福昕阅读器,然后鼠标右击论文图标,在打开方式中选择福昕阅读器打开: 打开之后,点击导航栏[特色功能],然后点击[免费查重]: 点击[免费查重],会直接打开浏览器进入免费论文查重网站,点击“登录领取免费字数”来领取免费论文检测

手机论文查重软件哪个靠谱?

手机论文查重软件哪个靠谱?相信很多大学生都会问这个问题,因为马上就要毕业了,这个论文查重是很重要的,电脑上面的查重软件很多人都知道,手机的就不一定了,这里分享下. 1.首先要在手机的应用市场里面找到迅捷论文查重,点击安装. 2.熟悉下工具,然后就可以开始查询了. 3.填写一下信息,这里是上传的文档. 4.结果出来之后可以自己去看,也可以根据结果来修改论文. 手机论文查重软件哪个靠谱到这里就结束了,大家赶快去弄弄吧,毕竟顺利发表论文才是当务之急啊. 原文地址:https://blog.51cto.