欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言實(shí)現(xiàn)BMP圖像閉運(yùn)算處理

 更新時(shí)間:2021年10月25日 11:43:52   作者:傻不拉幾的程序員  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)BMP圖像閉運(yùn)算處理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

閉運(yùn)算可以把比結(jié)構(gòu)元素小的特定圖像細(xì)節(jié)出去,同時(shí)保證不產(chǎn)生全局的幾何失真。填充比結(jié)構(gòu)元素小的缺口或孔,搭接短的間斷而起到連接作用。

運(yùn)算:也就是先膨脹后腐蝕。

#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
 
int main(int* argc, char** argv)
{
 FILE* fp = fopen("./threshold.bmp", "rb");
 if (fp == 0)
  return 0;
 BITMAPFILEHEADER fileHead;
 fread(&fileHead, sizeof(BITMAPFILEHEADER), 1, fp);
 
 BITMAPINFOHEADER infoHead;
 fread(&infoHead, sizeof(BITMAPINFOHEADER), 1, fp);
 int width = infoHead.biWidth;
 int height = infoHead.biHeight;
 int biCount = infoHead.biBitCount;
 
 int lineByte = (biCount*width / 8 + 3) / 4 * 4;
 RGBQUAD* pColorTable;
 pColorTable = new RGBQUAD[256];
 fread(pColorTable, sizeof(RGBQUAD), 256, fp);
 
 unsigned char* pBmpBuf;
 pBmpBuf = new unsigned char[lineByte*height];
 fread(pBmpBuf, lineByte*height, 1, fp);
 fclose(fp);
 
 // 新圖
 FILE* fop = fopen("close.bmp", "wb");
 if (fop == 0)
  return 0;
 
 // 膨脹操作
 // 初始化
 int t = 0, d = 0, r = 0;
 unsigned char* pBmpBuf2;
 pBmpBuf2 = new unsigned char[lineByte*height];
 for (int i = 0; i < height; ++i){
  for (int j = 0; j < width; ++j){
   *(pBmpBuf2 + i*lineByte + j) = 255;
  }
 }
 
 for (int i = 1; i < height; ++i){
  for (int j = 0; j < width - 1; ++j){
   t = *(pBmpBuf + i*lineByte + j);       // 當(dāng)前點(diǎn)
   d = *(pBmpBuf + (i - 1)*lineByte + j); // 下面點(diǎn)
   r = *(pBmpBuf + i*lineByte + j + 1);   // 右邊點(diǎn)
   if (t == 0 && d == 0 && r == 0){
    *(pBmpBuf2 + i*lineByte + j) = 0;       // 當(dāng)前點(diǎn)
   }
  }
 }
 // 結(jié)構(gòu)元素向上反轉(zhuǎn)180度,對(duì)最下面一排處理
 for (int j = 0; j < width - 1; ++j){
  t = *(pBmpBuf + j);            // 當(dāng)前點(diǎn)
  d = *(pBmpBuf + lineByte + j); // 上面點(diǎn)
  r = *(pBmpBuf + j + 1);        // 右邊點(diǎn)
  if (t == 0 && d == 0 && r == 0){
   *(pBmpBuf2 + j) = 0;       // 當(dāng)前點(diǎn)
  }
 }
 // 結(jié)構(gòu)元素向右反轉(zhuǎn),對(duì)最右邊一列處理
 for (int i = 1; i < height; ++i){
  t = *(pBmpBuf + i*lineByte + width - 1);
  d = *(pBmpBuf + (i - 1)*lineByte + width - 1);
  r = *(pBmpBuf + i*lineByte + width - 2);
  if (t == 0 && d == 0 && r == 0){
   *(pBmpBuf2 + i*lineByte + width - 1) = 0;       // 當(dāng)前點(diǎn)
  }
 }
 
 // 腐蝕操作
 for (int i = 1; i < height; ++i){
  for (int j = 0; j < width - 1; ++j){
   t = *(pBmpBuf2 + i*lineByte + j);       // 當(dāng)前點(diǎn)
   d = *(pBmpBuf2 + (i - 1)*lineByte + j); // 下面點(diǎn)
   r = *(pBmpBuf2 + i*lineByte + j + 1);   // 右邊點(diǎn)
   if (t == 0 && d != 0){
    *(pBmpBuf2 + (i - 1)*lineByte + j) = 0;//下邊的置位1
   }
   if (t == 0 && r != 0){
    *(pBmpBuf2 + i*lineByte + j + 1) = 0;//右邊的置位1
    j = j + 1;
   }
  }
 }
 
 fwrite(&fileHead, sizeof(BITMAPFILEHEADER), 1, fop);
 fwrite(&infoHead, sizeof(BITMAPINFOHEADER), 1, fop);
 fwrite(pColorTable, sizeof(RGBQUAD), 255, fop);
 fwrite(pBmpBuf2, lineByte*height, 1, fop);
 fclose(fop);
 
 system("pause");
 return 0;
}

實(shí)驗(yàn)結(jié)果:

         

實(shí)驗(yàn)結(jié)果分析:原圖和效果圖略微由區(qū)別。但效果圖似乎和開運(yùn)算相反了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語(yǔ)言 淺談棧與隊(duì)列的定義與操作

    C語(yǔ)言 淺談棧與隊(duì)列的定義與操作

    棧和隊(duì)列,嚴(yán)格意義上來(lái)說(shuō),也屬于線性表,因?yàn)樗鼈円捕加糜诖鎯?chǔ)邏輯關(guān)系為 "一對(duì)一" 的數(shù)據(jù),但由于它們比較特殊,因此將其單獨(dú)作為一章,做重點(diǎn)講解
    2021-11-11
  • C++類的定義和對(duì)象的創(chuàng)建詳解

    C++類的定義和對(duì)象的創(chuàng)建詳解

    本篇文章重點(diǎn)講解了兩種創(chuàng)建對(duì)象的方式:一種是在棧上創(chuàng)建,形式和定義普通變量類似;另外一種是在堆上使用 new 關(guān)鍵字創(chuàng)建,必須要用一個(gè)指針指向它,下面和小編一起來(lái)學(xué)習(xí)下面為文章的內(nèi)容
    2021-09-09
  • C++?DLL注入工具(完整源碼)

    C++?DLL注入工具(完整源碼)

    這篇文章主要介紹了C++?DLL注入工具的相關(guān)資料,并向大家分享了完整的源碼,具有一定的參考價(jià)值,希望對(duì)正在工作或?qū)W習(xí)的你有所幫助
    2022-02-02
  • C++ 異常處理 catch(...)介紹

    C++ 異常處理 catch(...)介紹

    catch(…)能夠捕獲多種數(shù)據(jù)類型的異常對(duì)象,所以它提供給程序員一種對(duì)異常 對(duì)象更好的控制手段,使開發(fā)的軟件系統(tǒng)有很好的可靠性
    2013-09-09
  • C++將txt文件內(nèi)容保存到數(shù)組的方法

    C++將txt文件內(nèi)容保存到數(shù)組的方法

    今天小編就為大家分享一篇C++將txt文件內(nèi)容保存到數(shù)組的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-07-07
  • c語(yǔ)言獲取直播吧最近一周nba比賽信息

    c語(yǔ)言獲取直播吧最近一周nba比賽信息

    這篇文章主要介紹了使用c語(yǔ)言獲取直播吧最近一周nba比賽信息的方法,需要的朋友可以參考下
    2014-04-04
  • C++面向?qū)ο缶幊讨鰳?gòu)詳解

    C++面向?qū)ο缶幊讨鰳?gòu)詳解

    這篇文章主要為大家詳細(xì)介紹了C++面向?qū)ο缶幊讨鰳?gòu),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-03-03
  • C語(yǔ)言實(shí)現(xiàn)通訊錄系統(tǒng)課程設(shè)計(jì)

    C語(yǔ)言實(shí)現(xiàn)通訊錄系統(tǒng)課程設(shè)計(jì)

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)通訊錄系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • C++中的構(gòu)造函數(shù)詳解

    C++中的構(gòu)造函數(shù)詳解

    這篇文章主要介紹了C++ 中構(gòu)造函數(shù)的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • 關(guān)于函數(shù)傳參問題(指針傳參,值傳參,引用傳參)

    關(guān)于函數(shù)傳參問題(指針傳參,值傳參,引用傳參)

    這篇文章主要介紹了關(guān)于函數(shù)傳參問題(指針傳參,值傳參,引用傳參),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01

最新評(píng)論