国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
TIF圖像處理
 
源代碼下載地址:
 
 
 
1、圖像文件頭(Image File Header簡(jiǎn)稱(chēng)IFH):


圖一 IFH結(jié)構(gòu)描述

  IFH數(shù)據(jù)結(jié)構(gòu)包含3個(gè)成員共計(jì)8個(gè)字節(jié),Byte order成員可能是“MM”(0x4d4d)或“II”(0x4949),0x4d4d表示該TIFF圖是摩托羅拉整數(shù)格式 0x4949表示該圖是Intel整數(shù)格式;Version成員總是包含十進(jìn)制42(0x2a),它用于進(jìn)一步校驗(yàn)該文件是否為T(mén)IF格式,42這個(gè)數(shù)并不是一般人 想象中的那樣認(rèn)為是tif軟件的版本,實(shí)際上,42這個(gè)數(shù)大概永遠(yuǎn)不會(huì)變化;第三個(gè)成員是IFD(接下來(lái)要說(shuō)的第二個(gè)數(shù)據(jù)結(jié)構(gòu))相對(duì)文件開(kāi)始 處的偏移量。

2、圖像文件目錄(Image File Directory簡(jiǎn)稱(chēng)IFD):


圖二 IFD及DE結(jié)構(gòu)描述

  IFD是TIF圖中最重要的數(shù)據(jù)結(jié)構(gòu),它包含了一個(gè)TIF文件中最重要的信息,一個(gè)TIF圖可能有多個(gè)IFD,這說(shuō)明文件中有多個(gè)圖像,每個(gè)IFD標(biāo)識(shí)1個(gè)圖像的基本屬性。 IFD結(jié)構(gòu)中包含了三類(lèi)成員,Directory Entry Count指出該結(jié)構(gòu)里面有多少個(gè)目錄入口;接下來(lái)就是N個(gè)線性排列的DE序列,數(shù)量不定(這就是 為什么稱(chēng)TIF格式文件為可擴(kuò)充標(biāo)記的文件,甚至用戶(hù)可以添加自定義的標(biāo)記屬性),每個(gè)DE標(biāo)識(shí)了圖像的某一個(gè)屬性;最后就是一個(gè)偏移量, 標(biāo)識(shí)下一個(gè)文件目錄相對(duì)于文件開(kāi)始處的位置,當(dāng)然,如果該TIF文件只包含了一幅圖像,那么就只有一個(gè)IFD,顯然,這個(gè)偏移量就等于0;

3、目錄入口(Directory Entry簡(jiǎn)稱(chēng)DE):
  共12個(gè)字節(jié),見(jiàn)圖二。簡(jiǎn)單說(shuō),一個(gè)DE就是一幅圖像的某一個(gè)屬性。例如圖像的大小、分辨率、是否壓縮、像素的行列數(shù)、一個(gè)像素由幾位 表示(1位代表黑白兩色,8位代表256色等等)等。其中:tag成員是該屬性的編號(hào),在圖像文件目錄中,它是按照升序排列的。我們可以通過(guò)讀 這些編號(hào),然后到TIF格式官方白皮書(shū)中查找相應(yīng)的含義。屬性是用數(shù)據(jù)來(lái)表示的,那么type就是代表著該數(shù)據(jù)的類(lèi)型,TIF官方指定的有5種數(shù)據(jù)類(lèi)型。 type=1就是BYTE類(lèi)型(8位無(wú)標(biāo)記整數(shù))、type=2是ASCII類(lèi)型(7位ASCII碼加1位二進(jìn)制0)、type=3是SHORT類(lèi)型(16位無(wú)標(biāo)記整數(shù))、type=4是LONG 類(lèi)型(32位無(wú)標(biāo)記整數(shù))、type=5是RATIONAL類(lèi)型(2個(gè)LONG,第一個(gè)是分子,第二個(gè)是分母)。length成員是數(shù)據(jù)的數(shù)量而不是數(shù)據(jù)類(lèi)型的長(zhǎng)度。 第4個(gè)成員valueOffset很重要,它是tag標(biāo)識(shí)的屬性代表的變量值相對(duì)文件開(kāi)始處的偏移量。如果變量值占用的空間小于4個(gè)字節(jié),那么該值就存放在 valueOffset中即可,沒(méi)必要再另外指向一個(gè)地方了。

4、圖像數(shù)據(jù) 本例提供的圖像是基于256灰度級(jí)的,即一個(gè)字節(jié)代表一個(gè)像素點(diǎn),它是0x00~0xff區(qū)間中256個(gè)灰度級(jí)的任意一個(gè)整數(shù)。通過(guò)使用UltraEdit工具觀察, 我們發(fā)現(xiàn)該圖像文件的組織形式是:IFH--數(shù)據(jù)--IFD。以下的示例說(shuō)明遵循了這一觀察結(jié)果。

三、實(shí)戰(zhàn)

1、VC創(chuàng)建一個(gè)MFC AppWizard(exe)工程取名TiffTest,選擇單文檔程序。
2、添加TiffStruct.h文件,定義IFH和DE結(jié)構(gòu)(參考前面的結(jié)構(gòu)描述),用來(lái)接收讀TIF文件的信息。
#ifndef _TIFFSTRUCT_#define _TIFFSTRUCT_typedef struct tagIMAGEFILEHEADER{WORD byteOrder;WORD version;DWORD offsetToIFD;}IFH;typedef struct tagDIRECTORYENTRY{WORD tag;WORD type;DWORD length;DWORD valueOffset;}DE;#endif
3、在文檔類(lèi)中添加4個(gè)公有變量,并將其初始化為0。在TiffTestDoc.cpp中#include "TiffStruct.h"
DWORD m_dwBmSize; //圖象的數(shù)據(jù)部分的大小CPalette m_palDIB; //BMP圖象調(diào)色板HANDLE m_hDIB;  //BMP圖象內(nèi)存塊句柄CSize m_sizeDoc; //圖象的長(zhǎng)和寬
4、在文檔類(lèi)的OnOpenDocument函數(shù)中定義局部工具變量并讀文件
DWORD dwFileLength = 0;CString strTemp = _T("");WORD wDECount = 0;BYTE* pDIB = NULL;int i = 0;IFH ifh;ZeroMemory(&ifh, sizeof(IFH));CFile file;CFileException fe;if(0 == file.Open(lpszPathName, CFile::modeRead | CFile::shareDenyWrite, &fe)){AfxMessageBox("打開(kāi)文件失敗");return FALSE;}dwFileLength = file.GetLength();
讀IFH文件頭
if(sizeof(IFH) != file.Read(&ifh, sizeof(IFH))){AfxMessageBox("讀TIF文件頭失敗");return FALSE;}if(0x2a != ifh.version){AfxMessageBox("該文件不是TIF格式,讀文件失敗");return FALSE;}if(0x4949 != ifh.byteOrder){AfxMessageBox("該TIF文件不是IBMPC字節(jié)序,讀文件失敗");return FALSE;}file.Seek(ifh.offsetToIFD, CFile::begin);//將文件指針定位到IFD
讀文件有多少個(gè)目錄入口
if(2 != file.Read(&wDECount, 2)){AfxMessageBox("無(wú)法獲得TIF文件目錄入口數(shù)量");return FALSE;}strTemp.Format("該TIF文件有%d個(gè)目錄入口", wDECount);AfxMessageBox(strTemp);
創(chuàng)建DE數(shù)組,接收信息,數(shù)組中有wDECount個(gè)元素
DE* pde = new DE[wDECount];DE* pTemp = pde;memset(pde, 0, sizeof(DE)*wDECount);if(sizeof(DE)*wDECount != file.ReadHuge(pde, sizeof(DE)*wDECount)){AfxMessageBox("讀圖象文件目錄失敗");delete []pde;return FALSE;}
顯示圖像文件目錄信息
for(i=0; itag, i, pTemp->type, i, pTemp->length, i, pTemp->valueOffset);AfxMessageBox(strTemp);}
把圖像的大小和圖像數(shù)據(jù)的容量保存到成員變量中
for(i=0; i<wDECount; i++){pTemp = pde + i;if(256 == pTemp->tag) //tag為256的目錄入口中的變量標(biāo)識(shí)了圖象寬度{m_sizeDoc.cx = pTemp->valueOffset;}if(257 == pTemp->tag) //圖象高度{m_sizeDoc.cy = pTemp->valueOffset;}if(273 == pTemp->tag) //計(jì)算圖象數(shù)據(jù)占用字節(jié)數(shù){//m_dwBmSize = pTemp->valueOffset - sizeof(IFH);//或者把tag=256的valueOffset乘以tag=257的valueOffsetm_dwBmSize = m_sizeDoc.cx * m_sizeDoc.cy;}}
在文檔類(lèi)中創(chuàng)建一個(gè)成員工具函數(shù)CreateBmpBuffer,申請(qǐng)全局內(nèi)存塊以存放BMP文件結(jié)構(gòu)數(shù)據(jù)
BOOL CTiffTestDoc::CreateBmpBuffer(){//申請(qǐng)BMP內(nèi)存塊m_hDIB = GlobalAlloc(GMEM_MOVEABLE | GMEM_ZEROINIT,sizeof(BITMAPFILEHEADER) +sizeof(BITMAPINFOHEADER) +256*sizeof(RGBQUAD) +m_dwBmSize);if(NULL == m_hDIB){AfxMessageBox("申請(qǐng)BMP內(nèi)存塊失敗");return FALSE;}else{return TRUE;}}
回到OnOpenDocument成員函數(shù)中調(diào)用工具函數(shù)并獲得全局內(nèi)存塊指針
//構(gòu)造BMP圖象內(nèi)存塊if(!CreateBmpBuffer()){AfxMessageBox("構(gòu)造BMP圖象內(nèi)存塊失敗");delete []pde;return FALSE;}//獲得BMP內(nèi)存塊指針pDIB = (BYTE*)GlobalLock(m_hDIB);if(NULL == pDIB){AfxMessageBox("獲得BMP內(nèi)存塊指針失敗");GlobalUnlock(m_hDIB);delete []pde;return FALSE;}
  以下是將圖像信息填充到BMP內(nèi)存塊中,網(wǎng)上介紹BMP格式的文章很多,這里就不詳述了。因測(cè)試圖像數(shù)據(jù)表達(dá)的是0x00-0xff灰度,正好和BMP文件調(diào)色板索引值巧合。 故在代碼中直接把圖像數(shù)據(jù)信息當(dāng)成索引即可,減少了編碼復(fù)雜度。注:BMP文件中圖像數(shù)據(jù)的第一行代表的是最終顯示光柵的最后一行,所以在數(shù)據(jù)排列中要顛倒過(guò)來(lái)。
//構(gòu)造BITMAPFILEHEADER并復(fù)制到BMP內(nèi)存塊BITMAPFILEHEADER bmfHdr;memset(&bmfHdr, 0, sizeof(BITMAPFILEHEADER));bmfHdr.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER) +256*sizeof(RGBQUAD);bmfHdr.bfReserved1 = 0;bmfHdr.bfReserved2 = 0;bmfHdr.bfSize = bmfHdr.bfOffBits + m_dwBmSize;bmfHdr.bfType = 0x4d42;memmove(pDIB, &bmfHdr, sizeof(BITMAPFILEHEADER));//構(gòu)造BITMAPINFOHEADER并復(fù)制到BMP內(nèi)存塊BITMAPINFOHEADER bmiHdr;memset(&bmiHdr, 0, sizeof(BITMAPINFOHEADER));bmiHdr.biBitCount = 8;bmiHdr.biClrImportant = 0;bmiHdr.biClrUsed = 0;bmiHdr.biCompression = 0;bmiHdr.biHeight = m_sizeDoc.cy;bmiHdr.biPlanes = 1;bmiHdr.biSize = sizeof(BITMAPINFOHEADER);bmiHdr.biSizeImage = 0;bmiHdr.biWidth = m_sizeDoc.cx;bmiHdr.biXPelsPerMeter = 2834;bmiHdr.biYPelsPerMeter = 2834;memmove((BITMAPFILEHEADER*)pDIB + 1, &bmiHdr, sizeof(BITMAPINFOHEADER));//構(gòu)造256個(gè)RGBQUAD并復(fù)制到BMP內(nèi)存塊RGBQUAD* pRgbQuad = (RGBQUAD*)(pDIB + sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER));RGBQUAD* pOldQuad = pRgbQuad;RGBQUAD rgbQuad;memset(&rgbQuad, 0, sizeof(RGBQUAD));for(i=0; i<256; i++){rgbQuad.rgbBlue = i;rgbQuad.rgbGreen = i;rgbQuad.rgbRed = i;rgbQuad.rgbReserved = 0;pRgbQuad = pOldQuad + i;memmove(pRgbQuad, &rgbQuad, sizeof(RGBQUAD));}//填充所有像素?cái)?shù)據(jù), 顛倒圖象數(shù)據(jù)從最后一行開(kāi)始讀起int j = 0;for(i=m_sizeDoc.cy-1; i>=0; i--){file.Seek(sizeof(IFH) + i*m_sizeDoc.cx, CFile::begin);file.Read((BYTE*)(pRgbQuad + 1) + j*m_sizeDoc.cx, m_sizeDoc.cx);j++;}
初始化BMP調(diào)色板,為顯示BMP文件做準(zhǔn)備
//初始化專(zhuān)用調(diào)色板BYTE buf[2+2+4*256];LOGPALETTE* pPal = (LOGPALETTE*)buf;pPal->palVersion = 0x300;pPal->palNumEntries = 256;for(i=0; i<255; i++){pPal->palPalEntry[i].peBlue = i;pPal->palPalEntry[i].peFlags = 0;pPal->palPalEntry[i].peGreen = i;pPal->palPalEntry[i].peRed = i;}m_palDIB.CreatePalette(pPal);
最后是OnOpenDocument成員函數(shù)返回前的清理工作
GlobalUnlock(m_hDIB);delete []pde;return TRUE;
  至此,TIF文件信息已轉(zhuǎn)換為BMP圖像并保存在全局內(nèi)存塊中了,接下來(lái)就可以在OnDraw中調(diào)用WinAPI函數(shù)StretchDIBits來(lái)顯示它。
if(NULL == pDoc->m_hDIB){return;}HDC hdc = pDC->m_hDC;BYTE* pBuf = (BYTE*)GlobalLock(pDoc->m_hDIB);pBuf += sizeof(BITMAPFILEHEADER);BYTE* pData = pBuf + sizeof(BITMAPINFOHEADER) + 256*sizeof(RGBQUAD);CPalette* pOldPal = pDC->SelectPalette(&pDoc->m_palDIB, TRUE);pDC->RealizePalette();::SetStretchBltMode(hdc, COLORONCOLOR);::StretchDIBits(hdc, 10, 10, pDoc->m_sizeDoc.cx, pDoc->m_sizeDoc.cy,0, 0, pDoc->m_sizeDoc.cx, pDoc->m_sizeDoc.cy, pData,(BITMAPINFO*)pBuf, DIB_RGB_COLORS, SRCCOPY);pDC->SelectPalette(pOldPal, FALSE);GlobalUnlock(pDoc->m_hDIB);
最后別忘了在文檔類(lèi)析構(gòu)函數(shù)~CTiffTestDoc中銷(xiāo)毀全局內(nèi)存塊
if(NULL != m_hDIB){GlobalFree(m_hDIB);m_hDIB = NULL;}
此文轉(zhuǎn)載自:http://www.image2003.com
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶(hù)發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
TIF圖像數(shù)據(jù)結(jié)構(gòu)
JPEG系列二 JPEG文件中的EXIF(上)
| 天極Yesky - 全球中文IT第一門(mén)戶(hù) - 軟件 - VC數(shù)字圖像處理編程講座之三
VC下使用LibTiff處理TIFF文件
VC++圖像處理編程 - LiteQ的日志 - 網(wǎng)易博客
保存MFC的CBitmap對(duì)象中的圖象到一個(gè)BMP文件中
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服