Chinaunix首页 | 论坛 | 博客
  • 博客访问: 523502
  • 博文数量: 576
  • 博客积分: 40000
  • 博客等级: 大将
  • 技术积分: 5020
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-13 14:47
文章分类

全部博文(576)

文章存档

2011年(1)

2008年(575)

我的朋友

分类:

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图像拷贝调色板

3、现在,进入最重要的一环,在FCObjImage类中添加方法:
  void SinglePixelProcessProc (FCSinglePixelProcessBase & PixelProcessor, FCObjProgress * progress = NULL)
  并把下面的实现代码拷到FCObjImage类中:
//================================================================
void  FCObjImage::SinglePixelProcessProc (FCSinglePixelProcessBase & PixelProcessor, FCObjProgress * progress)
{
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) ;
}//================================================================
4、修改库里的 PixelProcessor.cpp 文件,把FCObjImage所在的.h文件包含进去。

   现在,您就可以通过如下方法调用本库:
  imgTest.SinglePixelProcessProc (FCPixelGrayscale()) ;
  imgTest.SinglePixelProcessProc (FCPixelInvert()) ;
  ......
2004/3/27  Crazybit


--------------------next---------------------

阅读(399) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~