分类:
2008-10-14 14:51:58
通用图像类算法扩充库
作者:
主页:
这是一个比较另类的图像库,它本身并不提供对图像对象的封装,只以类似插件的形式为您提供图像处理算法的封装和进度显示,而图像对象的封装则需由用户来提供。本图像库平台无关,理论上它可以应用于任何已有的C++图像类上。(具体原理请参看本人拙作:)。
使用方法
为了使用本图像库,您必须对手头的图像类做一些简单的修改(考虑到效率的因素,我并没有提供一个虚接口供大家继承,而是通过让用户自己修改代码来实现之。):
1、从现有图像类(如CxImage、CDib...)派生出FCObjImage(我想您的类也叫这个名字的概率应该比火星有水的概率要低^-^)。
2、.您必须在FCObjImage类中实现以下函数(大多是很简单的取属性操作):
原型
|
功能说明
|
FCObjImage () | 默认构造函数 |
FCObjImage (const FCObjImage & img) | 拷贝构造函数 |
FCObjImage & operator= (const FCObjImage & imgSrc) | 赋值操作 |
BOOL IsValidImage () const | 本图像对象是否有效 |
UINT16 ColorBits () const | 图像的颜色位数(1,4,8,16,24,32) |
DWORD GetPitch () const | 图像每行字节数 |
BYTE * GetBits (int iLine = 0) const | 取得第 iLine 行指针, 左上角为(0,0), 自上而下 |
BYTE * GetBits (int x, int y) const | 取得 (x,y) 点的指针, 左上角为(0,0), 自上而下,自左而右 |
bool IsInside (int x, int y) const | 坐标(x,y)是否在图像内部 |
int Width () const | 宽 |
int Height () const | 高 |
BOOL Create (int iWidth, int iHeight, WORD wColorBit) | 创建一副空图像 |
static void fooCopyPalette (FCObjImage & DibDest, const FCObjImage & DibSrc) | <=8bit图像拷贝调色板 |
void SinglePixelProcessProc (FCSinglePixelProcessBase & PixelProcessor, FCObjProgress * progress = NULL)并把下面的实现代码拷到FCObjImage类中:
//================================================================ void FCObjImage::SinglePixelProcessProc (FCSinglePixelProcessBase & PixelProcessor, FCObjProgress * progress)4、修改库里的 PixelProcessor.cpp 文件,把FCObjImage所在的.h文件包含进去。
{
if (!PixelProcessor.ValidateColorBits (this))
return ;
// 计算处理区域
RECT rcImg = {0,0,Width(),Height()}, rcBlock, rcDest ;
if (PixelProcessor.GetProcessRect() == NULL)
::CopyRect (&rcBlock, &rcImg) ;
else
::CopyRect (&rcBlock, PixelProcessor.GetProcessRect()) ;
if (::IntersectRect (&rcDest, &rcImg, &rcBlock) == 0)
return ; // 处理区域为空
// 处理前准备工作
int nSpan = ColorBits() / 8 ; // 每象素字节数1, 2, 3, 4
PixelProcessor.OnEnterProcess (this, rcDest) ;
// 遍历处理区域像素
for (int y=rcDest.top ; y < rcDest.bottom ; y++)
{
BYTE * pPixel = GetBits (rcDest.left, y) ;
for (int x=rcDest.left ; x < rcDest.right ; x++, pPixel += nSpan)
{
PixelProcessor.ProcessPixel (this, x, y, pPixel) ;
}
if (progress != NULL)
progress->SetProgress (y * 100 / Height()) ;
}
// 收尾工作
PixelProcessor.OnLeaveProcess (this) ;
}//================================================================
imgTest.SinglePixelProcessProc (FCPixelGrayscale()) ; imgTest.SinglePixelProcessProc (FCPixelInvert()) ; ......2004/3/27 Crazybit