上一篇,http://blog.csdn.net/jorney_dong/article/details/17411057 写了用来处理bmp数据的一个小算法,只是发现是不完善的。
这里再更新一下,之前的就保留在那吧。
那篇小文提到,做完前两个步骤以后,图片是颠倒的,先在windows上旋转以后再来处理。其实,windows旋转以后,左右又颠倒了。
说到底,还是bmp图片存储数据的方式的问题。我们把bmp图片存储的数据看成一个二维数组,第一行的数据对应的就是我们看到图片的最后一行,第二行,对应图片的倒数第二行,依次,最后一行,就对应看到图片的第一行。这里要注意的是,左右是不颠倒的。
所以我们在处理完上篇提到的前两步以后,只要再把各行换一下次序就可以了。
下面是完整的代码,用法和上一篇一样:
main.c
#include <stdio.h>
//TO_DO ++++++++
#include "test1.h"
//bmp width, height
int bytes_per_bpp = 3;
int bmp_width = 73;
int bmp_height = 73;
unsigned int file_len = 16114;
unsigned char *bmp_file_data = test1_bmp;
#define REVERT_BMP 1 //revert the bmp: 1, don't revert: 0
//TO_DO --------
/*bmp文件的前部是文件头信息,aboot中画图不需要这些
* 1 删除文件头信息,
*
* 以 24bit bmp: 134X290 为例
* 图片每一行134个像素,每个像素3个字节,所以每一行是134*3 == 402个字节,
* bmp会在每一行的最后添加两个字节对齐。
* aboot中要用这个图片的话,
* 2.要把每行最后的两个对齐字节删除
*
* 每行最后的两个字节删除以后
* 因为bmp本身的图片是倒的,
* 3.反转整张图,把最后一行,写到第一行,
* 第一行,写到最后一行,但是左右不要反。
*
*/
int main()
{
unsigned int i = 0;
unsigned int j = 0;
int off = 0;
unsigned int bmp_info_len = 0;
unsigned int temp = 0;
unsigned int actual_data_len = 0;
unsigned char result_arry[file_len];
unsigned char result_arry2[file_len];
unsigned char *result_arry3 = NULL;
unsigned int data_bytes_per_row = (bmp_width*bytes_per_bpp);
unsigned int total_bytes_per_row = 0;
unsigned int null_bytes_per_row = 0;
unsigned int array_len = 0;
if(data_bytes_per_row%4 != 0)
{
null_bytes_per_row = 4-data_bytes_per_row%4;
}
total_bytes_per_row = data_bytes_per_row + null_bytes_per_row;//total bytes per row
bmp_info_len = file_len - total_bytes_per_row*bmp_height;//bmp file info len,or len to delete
printf("file_len:---------------> %d \n",file_len);
printf("bmp_info_len:-----------> %d \nnull_bytes_per_row:-----> %d\n",bmp_info_len,null_bytes_per_row);
//1 删除文件头信息,
for(i=bmp_info_len,j=0;i<file_len;i++,j++)
{
result_arry2[j] = bmp_file_data[i];
}
array_len = j;
printf("step 1 over.\n");
printf("data total_bytes:-------> %d \n",file_len-bmp_info_len);
printf("total_bytes_per_row:----> %d \n",total_bytes_per_row);
//in data <-- bmp_file_data[..]
//2.删除每行最后的若干个字节,存于result_arry2
for(i=1,j=0;i<=array_len;i++)
{
//delete null data at the end of row
result_arry[j] = result_arry2[i-1];
j++;
if(i%total_bytes_per_row==0)
{
j -= null_bytes_per_row;
}
}// out data to -->result_arry[..]
printf("step 2 over.\n");
array_len = j;
printf("array_len: %d \n",array_len);
#if REVERT_BMP
//3.这里是反转整张图
for(i=array_len - data_bytes_per_row,j=0; i>=0; )
{
for( off = 0;off<data_bytes_per_row;off++,j++)
{
result_arry2[j] = result_arry[i+off];
}
if(i==0)
{
break;
}
i -= data_bytes_per_row;
}
result_arry3 = result_arry2;
printf("steps 3 over.\n");
#endif
printf("actual data array_len:---> %d \n",array_len);
FILE* fout = fopen("resutfile.h","w+");
if (fout == NULL) {
printf("Failed to open\n");
return;
}
for (i=0;i<array_len;)
{
fprintf(fout,"0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, 0x%x, \n",
result_arry3[i],result_arry3[i+1],result_arry3[i+2],result_arry3[i+3],
result_arry3[i+4],result_arry3[i+5],result_arry3[i+6],result_arry3[i+7],
result_arry3[i+8],result_arry3[i+9],result_arry3[i+10],result_arry3[i+11]);
i +=12;
}
if (fclose(fout) != 0) {
printf("Failed to close \n");
return;
}
}