中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > Visual C++ > 图形图像与多媒体
通用图像类算法扩充库
作者:未知 时间:2005-07-20 14:15 出处:VC知识库 责编:chinaitpower
              摘要:通用图像类算法扩充库

通用图像类算法扩充库


作者:Crazybit
主页:www.crazy-bit.com

下载源代码


  这是一个比较另类的图像库,它本身并不提供对图像对象的封装,只以类似插件的形式为您提供图像处理算法的封装和进度显示,而图像对象的封装则需由用户来提供。本图像库平台无关,理论上它可以应用于任何已有的C++图像类上。(具体原理请参看本人拙作:Crazybit开发手记(一):设计之数据结构和算法的分离)。

使用方法

  为了使用本图像库,您必须对手头的图像类做一些简单的修改(考虑到效率的因素,我并没有提供一个虚接口供大家继承,而是通过让用户自己修改代码来实现之。):

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

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有