BMP图像转txt C++代码

BMP图像转txt C++代码

理论上适用所有格式的图片。使用opencv编写,编译需要依赖opencv,工程代码中有编译好的不需要opencv环境。直接可运行的linux程序,需要请下载

#include "main.h"
#include "ImageEvaluation.h"
int main(int argc, char* argv[]) {
	 FILE * fp;
	 
	if(argc<3)
	{		
		cout << "Input param error ,please input : "<< argv[0] <<" srcxx.jpg dstxx.dat" << endl;	
		return 0;
	}
	string file_src1 = argv[1];	// 输入 
	Image_src1 = imread(file_src1, 1);	// 	
	//string file_dst1 = argv[2];	// 输入 
	//Image_dst1 = fopen(file_dst1, 1);	// 
	
	fp = fopen (argv[2], "w+");	
	/* 图像输入 */
	//Input_Image();
	clock_t start, end;	// 
	start = clock();
	//--- 图像处理 -------------------------------------------------------------------------------
	//GaussianBlur(Image_src, Image_dst, Size(5, 5), 0);	// 高斯滤波
	checkMat(Image_src1);					// 检查Mat函数的大小和类型
	//--------------------------------------------------------------------------------------------
	
	
	for (int i = 0; i < Image_src1.rows; ++i)
	{
		for (int j = 0; j < Image_src1.cols; ++j)
		{
			fprintf(fp, "00%02X%02X%02X\r\n", Image_src1.at<Vec3b>(i, j)[0], Image_src1.at<Vec3b>(i, j)[1], Image_src1.at<Vec3b>(i, j)[2]);	
		}	
		
	}

	fclose(fp);
	//Evaluation_MSE_PSNR_SSIM(Image_src1, Image_dst1);
	end = clock();
	double time_difference = (double)end - (double)start;
	const double time = time_difference / CLOCKS_PER_SEC * 1000.0;
	cout << "time : " << time << " [ms]" << endl;
	/*输出 */
	return 0;
}



原图:
在这里插入图片描述

转换结果

在这里插入图片描述

工程下载链接: link

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值