?? dibimage.h
字號:
// DibImage.h: interface for the CDibImage class.
//
//////////////////////////////////////////////////////////////////////
#if !defined(AFX_DIBIMAGE_H__254F3D1E_BB20_40DA_AE07_E8E0219DFA8C__INCLUDED_)
#define AFX_DIBIMAGE_H__254F3D1E_BB20_40DA_AE07_E8E0219DFA8C__INCLUDED_
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
DECLARE_HANDLE(HDIB); // DIB句柄
#define PALVERSION 0x300 // DIB常量
/* DIB宏 */
// 判斷是否是Win 3.0的DIB
#define IS_WIN30_DIB(lpbi) ((*(LPDWORD)(lpbi)) == sizeof(BITMAPINFOHEADER))
// 計算矩形區(qū)域的寬度
#define RECTWIDTH(lpRect) ((lpRect)->right - (lpRect)->left)
// 計算矩形區(qū)域的高度
#define RECTHEIGHT(lpRect) ((lpRect)->bottom - (lpRect)->top)
// 在計算圖像大小時,采用公式:biSizeImage = biWidth' × biHeight。
// 是biWidth',而不是biWidth,這里的biWidth'必須是4的整倍數(shù),表示
// 大于或等于biWidth的,離4最近的整倍數(shù)。WIDTHBYTES就是用來計算
// biWidth'
#define WIDTHBYTES(bits) (((bits) + 31) / 32 * 4)
// Dib文件頭標志(字符串"BM",寫DIB時用到該常數(shù))
#define DIB_HEADER_MARKER ((WORD) ('M' << 8) | 'B')
// 圖像幾何變換函數(shù)//////////////////////////////////////////
// 常數(shù)π
#define PI 3.1415926535
//角度到弧度轉(zhuǎn)化的宏
#define RADIAN(angle) ((angle)*PI/180.0)
/////////////////////////////////////////////////////////////
// 圖像正交變換函數(shù)//////////////////////////////////////////
#include <complex>
using namespace std;
/////////////////////////////////////////////////////////////
class CDibImage
{
// Constructor and Destructor ///////////////////////////////
public:
CDibImage();
virtual ~CDibImage();
// function /////////////////////////////////////////////////
public:
// DIB(Independent Bitmap) 函數(shù)
BOOL PaintDIB (HDC, LPRECT, HDIB, LPRECT, CPalette* pPal);
BOOL CreateDIBPalette(HDIB hDIB, CPalette* cPal);
LPSTR FindDIBBits (LPSTR lpbi);
DWORD DIBWidth (LPSTR lpDIB);
DWORD DIBHeight (LPSTR lpDIB);
WORD PaletteSize (LPSTR lpbi);
WORD DIBNumColors (LPSTR lpbi);
HGLOBAL CopyHandle (HGLOBAL h);
BOOL SaveDIB (HDIB hDib, CFile& file);
HDIB ReadDIBFile(CFile& file);
// 圖像點運算函數(shù)
BOOL LinerTrans(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, FLOAT fA,
FLOAT fB);
BOOL ThresholdTrans(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, BYTE bThre);
BOOL WindowTrans(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, BYTE bLow,
BYTE bUp);
BOOL GrayStretch(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, BYTE bX1,
BYTE bY1, BYTE bX2, BYTE bY2);
BOOL InteEqualize(LPSTR lpDIBBits, LONG lWidth, LONG lHeight);
// 圖像幾何變換函數(shù)
BOOL TranslationDIB1 (LPSTR lpDIBBits, LONG lWidth, LONG lHeight,
LONG lXOffset, LONG lYOffset);
BOOL TranslationDIB (LPSTR lpDIBBits, LONG lWidth, LONG lHeight,
LONG lXOffset, LONG lYOffset);
BOOL MirrorDIB(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, BOOL bDirection);
BOOL TransposeDIB(LPSTR lpbi);
HGLOBAL ZoomDIB(LPSTR lpbi, float fXZoomRatio, float fYZoomRatio);
HGLOBAL RotateDIB(LPSTR lpbi, int iRotateAngle);
HGLOBAL RotateDIB2(LPSTR lpbi, int iRotateAngle);
unsigned char Interpolation (LPSTR lpDIBBits, LONG lWidth, LONG lHeight,
FLOAT x, FLOAT y);
// 圖像正交變換函數(shù)
VOID FFT(complex<double> * TD, complex<double> * FD, int r);
VOID IFFT(complex<double> * FD, complex<double> * TD, int r);
VOID DCT(double *f, double *F, int power);
VOID IDCT(double *F, double *f, int power);
VOID WALSH(double *f, double *F, int r);
VOID IWALSH(double *F, double *f, int r);
BOOL Fourier(LPSTR lpDIBBits, LONG lWidth, LONG lHeight);
BOOL DIBDct(LPSTR lpDIBBits, LONG lWidth, LONG lHeight);
BOOL DIBWalsh(LPSTR lpDIBBits, LONG lWidth, LONG lHeight);
BOOL DIBWalsh1(LPSTR lpDIBBits, LONG lWidth, LONG lHeight);
};
#endif // !defined(AFX_DIBIMAGE_H__254F3D1E_BB20_40DA_AE07_E8E0219DFA8C__INCLUDED_)
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -