24真彩圖轉4位位元影像

來源:互聯網
上載者:User

 

一定要注意資料對齊%%%%%%%%%%%%%

BOOL CPhotoDlg::Convert24To4(LPCTSTR lpszSrcFile, LPCTSTR lpszDestFile)
{
 FILE*fp;
 fp = fopen("aa.txt", "wr");
 BITMAPFILEHEADER bmHdr;
 BITMAPINFOHEADER bmInfo;
 HANDLE hFile, hNewFile;
 DWORD dwByteWritten = 0;

 //開啟源檔案控制代碼
 hFile = CreateFile(lpszSrcFile,
  GENERIC_READ,
  FILE_SHARE_READ,
  NULL,
  OPEN_EXISTING,
  FILE_ATTRIBUTE_NORMAL,
  NULL);

 if(hFile == INVALID_HANDLE_VALUE)
  return FALSE;
 hNewFile = CreateFile(lpszDestFile,
  GENERIC_READ|GENERIC_WRITE,
  FILE_SHARE_READ|FILE_SHARE_WRITE,
  NULL,
  CREATE_ALWAYS,
  FILE_ATTRIBUTE_NORMAL,
  NULL);
 if(hNewFile == INVALID_HANDLE_VALUE)
 {
  CloseHandle(hFile);
  return false;
 }
 //讀取原檔案bmp頭和檔案雪梨市
 ReadFile(hFile, &bmHdr, sizeof(bmHdr), &dwByteWritten, NULL);
 ReadFile(hFile, &bmInfo, sizeof(bmInfo), &dwByteWritten, NULL);
 //只處理24位為壓縮映像
 if(bmInfo.biBitCount != 24 || bmInfo.biCompression != 0)
 {
  CloseHandle(hNewFile);
  CloseHandle(hFile);
  DeleteFile(lpszDestFile);
  return false;
 }
 //計算映像資料大小
 DWORD dwOldSize = bmInfo.biSizeImage;
 if(dwOldSize == 0)
 {
  dwOldSize = bmHdr.bfSize - sizeof(bmHdr) - sizeof(bmInfo);
 }
 /*
 long wid = bmInfo.biWidth % 4;
 if(wid > 0)
 {
  wid = 4 - wid;
 }
 wid += bmInfo.biWidth;
 */
 long wid = bmInfo.biWidth;
 long lOldWidth = (bmInfo.biWidth * 3 +3)/4*4;
 long lNewWidth = ((bmInfo.biWidth+1)/2 +3)/4*4;
 DWORD dwNewSize;
 dwNewSize = lNewWidth *bmInfo.biHeight; // 轉換後圖片的大小
 //讀取未經處理資料
 unsigned char *pBuffer = NULL;
 pBuffer = new unsigned char[dwOldSize];
 if(pBuffer == NULL)
 {
  CloseHandle(hNewFile);
  CloseHandle(hFile);
  DeleteFile(lpszDestFile);
  return false;
 }
 ReadFile(hFile, pBuffer, dwOldSize, &dwByteWritten, NULL);
 fwrite(pBuffer, dwOldSize, 1, fp);
 //fclose(fp);
 unsigned char *pNew = new unsigned char [dwNewSize];
 unsigned char color = 0;
 DWORD dwIndex = 0, dwOldIndex = 0;
 int i, j, k;
 long pos = 0;

 unsigned char R, G, B;
 //
 for(j = 0; j < bmInfo.biHeight; j++)
 {
  pos = lOldWidth * j;
  for(i = 0; i< lOldWidth; i = i+6)
  {
   B = pBuffer[pos+i];
   G = pBuffer[pos+i+1];
   R = pBuffer[pos+i+2];
   unsigned char maxcolor = 0.299*R+0.587*G+0.114*B;
   maxcolor /= 17;
   B = pBuffer[pos+i+3];
   G = pBuffer[pos+i+4];
   R = pBuffer[pos+i+5];
   unsigned char maxcolor2 = 0.299*R+0.587*G+0.114*B;
   maxcolor2 /= 17;
   pNew[j*lNewWidth + i/6] = (maxcolor<<4)|maxcolor2;
  }
 }
 fwrite("------------------", sizeof("------------------"), 1, fp);
 fwrite(pNew, dwNewSize, 1, fp);
 fclose(fp);
 /////////////////////////////////
 //把結果儲存到新檔案
 //修改屬性
 bmHdr.bfSize = sizeof(bmHdr)+sizeof(bmInfo)+sizeof(RGBQUAD)*16 + dwNewSize;
 bmHdr.bfOffBits = bmHdr.bfSize - dwNewSize;
 bmInfo.biBitCount = 4;
 bmInfo.biSizeImage = dwNewSize;

 //建立調色盤
 RGBQUAD pa[16];
 unsigned char c;
 for(i = 0; i < 16; i++)
 {
  c = i * 17;
  pa[i].rgbBlue =c;
  pa[i].rgbGreen = c;
  pa[i].rgbRed= c;
  pa[i].rgbReserved = 0;
 }
 //BMP頭
 WriteFile(hNewFile, &bmHdr, sizeof(bmHdr), &dwByteWritten, NULL);
 WriteFile(hNewFile, &bmInfo, sizeof(bmInfo), &dwByteWritten, NULL);
 WriteFile(hNewFile, pa, sizeof(RGBQUAD)*16, &dwByteWritten, NULL);
 WriteFile(hNewFile, pNew, dwNewSize, &dwByteWritten, NULL);
 delete []pBuffer;
 delete []pNew;
 CloseHandle(hNewFile);
 CloseHandle(hFile);
 return true;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.