zoukankan      html  css  js  c++  java
  • BMP图像差分/比较

      1 #include <stdio.h>
      2 #include <stdlib.h>
      3 #include <string.h>
      4 
      5 int main(int argc, char *argv[])
      6 {
      7     int row, col;
      8     int width, height, widthbyte, bitcount, imagesize, bytecount;
      9     const char *magenta = NULL;
     10     const char *magendiff = NULL;
     11     unsigned char header[] =
     12     {
     13         0x42, 0x4D, 0xAA, 0xAA, 0xAA, 0xAA, 0x00, 0x00, //  2 AA->FileSize
     14         0x00, 0x00, 0xBB, 0xBB, 0xBB, 0xBB, 0x28, 0x00, // 10 BB->OffBits
     15         0x00, 0x00, 0xCC, 0xCC, 0xCC, 0xCC, 0xDD, 0xDD, // 18 CC->Width
     16         0xDD, 0xDD, 0x01, 0x00, 0xEE, 0xEE, 0x00, 0x00, // 22 DD->Height
     17         0x00, 0x00, 0xFF, 0xFF, 0xFF, 0xFF, 0x00, 0x00, // 28 EE->BitCount
     18         0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // 34 FF->ImageSize
     19         0x00, 0x00, 0x00, 0x00, 0x00, 0x00
     20     };
     21     
     22     FILE *fpA = NULL;
     23     FILE *fpB = NULL;
     24     FILE *fpC = NULL;
     25     const char *filenameA = "A.bmp";
     26     const char *filenameB = "B.bmp";
     27     const char *filenameC = "C.bmp";
     28     unsigned char *rowbufA = NULL;
     29     unsigned char *rowbufB = NULL;
     30     
     31     const char * errmsg = NULL;
     32 
     33     switch(argc)
     34     {
     35     case 1:
     36         break;
     37     case 2:
     38         break;
     39     case 3:
     40         filenameA = argv[1];
     41         filenameB = argv[2];
     42         break;
     43     case 4:
     44         filenameA = argv[1];
     45         filenameB = argv[2];
     46         filenameC = argv[3];
     47         break;
     48     }
     49     
     50     do
     51     {
     52         fpA = fopen(filenameA, "rb");
     53         if(fpA == NULL) { errmsg = "A.bmp open failed"; break; };
     54         
     55         fpB = fopen(filenameB, "rb");
     56         if(fpB == NULL) { errmsg = "B.bmp open failed"; break; };
     57     
     58         // read file A.bmp
     59         fread(header, sizeof(header), 1L, fpA);
     60         width = *((int *)(header + 18));
     61         height = *((int *)(header + 22));
     62         bitcount = *((short *)(header + 28));
     63         imagesize = *((int *)(header + 34));
     64         widthbyte = (width * bitcount + 31) / 32 * 4;
     65         bytecount = bitcount / 8;
     66         switch(bitcount)
     67         {
     68         case 16:
     69             magenta = "x1Fx7C";
     70             magendiff = "x1Fx7C"; 
     71             break;
     72         case 24:
     73         case 32:
     74             magenta = "x00x00x00x00";
     75             magendiff = "x00x00xFFxFF";
     76             break;
     77         default:
     78             errmsg = "A.bitcount != 16 or 24 or 32";
     79             break;
     80         }
     81         if(errmsg) break;
     82         
     83         // check file B.bmp
     84         fread(header, sizeof(header), 1L, fpB);
     85         if(width != *((int *)(header + 18))) { errmsg = "A.width != B.width"; break; }
     86         if(height != *((int *)(header + 22))) { errmsg = "A.height != B.height"; break; }
     87         if(bitcount != *((short *)(header + 28))) { errmsg = "A.bitcount != B.bitcount"; break; }
     88         if(imagesize != *((int *)(header + 34))) { errmsg = "A.imagesize != B.imagesize"; break; }
     89         
     90         rowbufA = (unsigned char *)malloc(widthbyte);
     91         if(rowbufA == NULL) { errmsg = "rowbufA malloc failed"; break; }
     92         
     93         rowbufB = (unsigned char *)malloc(widthbyte);
     94         if(rowbufB == NULL) { errmsg = "rowbufB malloc failed"; break; }
     95                         
     96         fpC = fopen(filenameC, "wb");
     97         if(fpC == NULL) { errmsg = "C.bmp open failed"; break; };
     98 
     99         // wirte file C.bmp
    100         fwrite(header, sizeof(header), 1L, fpC);
    101         for(row = 0; row < height; row++)
    102         {
    103             fread(rowbufA, widthbyte, 1, fpA);
    104             fread(rowbufB, widthbyte, 1, fpB);
    105     
    106             for(col = 0; col < width; col++)
    107             {
    108                 if(memcmp(rowbufA + bytecount * col, rowbufB + bytecount * col, bytecount) == 0)
    109                 {
    110                     memcpy(rowbufB + bytecount * col, magenta, bytecount);
    111                 }
    112                 else
    113                 {
    114                     memcpy(rowbufB + bytecount * col, magendiff, bytecount);
    115                 } 
    116             }
    117     
    118             fwrite(rowbufB, widthbyte, 1, fpC);
    119         }
    120         
    121     } while(0);
    122 
    123     if(fpA) fclose(fpA);
    124     if(fpB) fclose(fpB);
    125     if(fpC) fclose(fpC);
    126     if(rowbufA) free(rowbufA);
    127     if(rowbufB) free(rowbufB);
    128 
    129     if(errmsg)
    130     {
    131         printf("%s
    ", errmsg);
    132         system("PAUSE");
    133     }
    134 
    135     return 0;
    136 }
    View Code
  • 相关阅读:
    细说MS事务管理
    大话设计模式(含源码)下载
    CSS基础到提高(PPT、视频、源代码),网页布局不用愁
    Android开发中Layout中明明改了id,但是还出现"cannot be resolved or is not a field"的原因
    读《OO真经》有感,以及我自己的关于哲学的体会
    Web服务小试牛刀
    在Android的RaletiveLayout中,如果空间的相对位置矛盾将不显示此控件
    .net 面试题2
    敏捷软件转
    中英文标点
  • 原文地址:https://www.cnblogs.com/ply616/p/6180598.html
Copyright © 2011-2022 走看看