Copyrect的使用

Copyrect的使用(图片复制、放大、以及做图片放大镜等)
一、从一个选取一个区域中的图象到另一个图象组件中的固定区域
procedure TForm1.Button1Click(Sender: TObject);
var
  rtDest, rtSource: TRect;
  rtIndex: Integer;
begin
  rtDest := Rect(0, 0, 200, 200); //在图象二中选取的区域,定义的坐标是相对于Image2的
  rtSource := Rect(0, 0, 50 , 41);//在图象一中选取的区域,定义的坐标是相对于Image1的
  Image2.Canvas.CopyRect(rtDest,.Canvas,rtSource);
 end;
注意:
1、 区域(Rect)坐标的定义,是相对于它的父控件。
2、 可以起到图象放大作用。如果图象一的选取区域小于图象二中的选取区域,那么图一选取区域中的图象,拉伸填充到图象二中的选取区域。(图象区域相同的复制不会造成图象失真,如果变大或者变小,就容易造成失真)
3、 相片的拷贝只限于BMP图片

二、如果要拷贝非bmp图片可以用以下方法
procedure TForm1.Button3Click(Sender: TObject);
var
      Bitmap:   TBitmap;
      MyRect,   MyOther:   TRect;
  begin
      MyRect   :=   Rect(0,0,900,900);
      MyOther   :=   Rect(0,0,300,300);
      Bitmap   :=   TBitmap.Create;
      bitmap.Assign(Image1.picture.Graphic);//转换文件格式成bmp后保存到bitmap中,这样就能用CopyRect了
      Image2.Canvas.BrushCopy(MyOther,   bitmap,   MyRect,   clBlack);  //这行与下行的意思基本相同,选择其一即可
      Image2.Canvas.CopyRect(MyOther,bitmap.Canvas,MyRect);
      Bitmap.Free;
  end;
end.
三、如何将外部图形保存在bitmap里面呢?
例子程序
var
  b: bmp;
begin
  b.b := TBitmap.Create;
  b.b.Assign(Image1.picture.Bitmap);
end;


【图象列表】:
var
  ImageList: TList;
begin
  ImageList := TList.Create;
  ImageList.Add(Image1.Picture.Bitmap);
  Image2.Picture.Bitmap := TBitMap(ImageList.Items[0]);
end;

四、实现图象局部放大的原理和方法

研究了好几个小时,试过了各种函数,想做图片分辨率的调整,不是效果与期望不符就是运行出错,差一点准备发飚,自己写一个抽样缩小和插值放大的函数,却鬼使神差地看了下被我忽略这篇文章……我的妈呀,快搞疯了,不过就是这么一句话而已!

·算法原理
 
在Delphi中,可利用类Tcanvas的CopyRect方法实现图象的放大和缩小。其功能是将源画布上的一个指定矩形区域(简称源矩形)内的象素,拷贝到目的画布上的一个指定矩形区域(简称目的矩形)中。亦可称之为象素块复制,如图1所示。 
由CopyMode属性确定拷贝的模式。在直接拷贝模式(cmSrcCopy)下,当源矩形与目的矩形相等时,图象不变;若源矩形大于目的矩形,图象则缩小;而当源矩形小于目的矩形时,图象便被放大(在目的矩形中扩展)。源矩形与目的矩形大小之比,决定图象的缩放倍数。CopyRect方法声明如下: 
Procedure CopyRect(const Dest: TRect; Canvas: TCanvas; const Source:   Trect); 
其中参数,Dest为目的矩形,Canvas是源画布,Source为源矩形。
·实现步骤
   ·新建应用程序主目录C:\Magnifier及其子目录Images,将事先制作好的位图图象Picture.bmp存入Images目录?纠校琍icture.bmp的大小为260*310象素。
  ·启动Delphi IDE,新建项目Magnifier.dpr,主窗体单元命名为Main.pas,存入C:\Magnifier目录。在主窗体上放置一个TPanel组件,并在其中加入两个TImage组件。两个TImage组件分别命名为ForeImage和BackImage,前者重叠于后者之上,并且都装入Picture.bmp位图。

·在主单元Main.pas的implementation段声明常量和变量:
 
const 
sSide=30;  
dSide=45; 
var 
msHide: Boolean; 
OldX, OldY, NewX, NewY: Integer; 
DestRect, SourceRect : TRect;  
其中,常量sSide和dSide用以控制"放大镜"的大小和放大倍数;变量msHide控制光标(鼠标)的隐藏和打开;其它变量用以确定放大部位。
·建立主窗体MainForm的OnCreate事件,加入下列语句,以初始化变量及设置复制模式:
 
msHide:=True; 
Canvas.CopyMode:=cmSrcCopy;
  ·创建主窗体MainForm的OnKeyPress事件处理程序,在其begin与end之间输入语句"Close;",当按任意键时结束程序运行。
  ·定义过程ImageCopy,用于处理图象的放大和恢复,当移动鼠标时调用。这是实现图象局部放大最重要的过程,源代码如下。
 
procedure TMainForm.ImageCopy(BoxCenterX,   BoxCenterY, BoxSide: Integer); 
begin 
with SourceRect do 
begin 
Left:=BoxCenterX-BoxSide; 
Top:=BoxCenterY-BoxSide; 
Right:=BoxCenterX+BoxSide; 
Bottom:=BoxCenterY+BoxSide; 
end; 
with DestRect do 
begin 
Left:=BoxCenterX-dSide; 
Top:=BoxCenterY-dSide; 
Right:=BoxCenterX+dSide; 
Bottom:=BoxCenterY+dSide; 
end; 
ForeImage.Canvas.CopyRect(DestRect, BackImage.Canvas, SourceRect); 
end; 
注意,别忘了在Main.pas的"type"中声明过程ImageCopy。
  ·创建ForeImage的OnMouseMove事件处理程序,当鼠标在图象上移动时,获取其位置,并作为过程调用的实参。此时,光标隐藏,"放大镜"出现。随着"放大镜"的移动,图象新的部位被放大,滑过的部位又恢复原状。以下为begin与end之间的代码:
 
NewX:=X; 
NewY:=Y; 
if msHide then 
begin 
OldX:=NewX; 
OldY:=NewY; 
msHide:=False; 
ShowCursor(False);  
end else 
begin 
ImageCopy(OldX, OldY, dSide); 
end; 
ImageCopy(NewX, NewY, sSide); 
OldX:=NewX; 
OldY:=NewY;
·建立主窗体MainForm的OnMouseMove事件处理程序,当鼠标移开图象时,"放大镜"隐藏,光标重新出现。源代码片段如下:
if not msHide then
begin
msHide:=True;
ShowCursor(True);
ImageCopy(OldX, OldY, dSide);
end;
·技术剖析
以上介绍了利用了画布的CopyRect方法,将图象以象素块从后台隐藏的TImage组件画布上向前台TImage组件的画布上拷贝,以实现图象的放大与恢复的技术。由于这一技术的采用,在图象放大前不需要存储象素,此后直接从后台TImage组件画布上恢复图象。不仅节省了内存资源,也确保了对图象的局部进行平滑、无闪烁地放大。同时,程序源代码也简洁、明了。


五、一个放大镜的原程序

procedure TMainForm.ImageCopy(BoxCenterX, BoxCenterY, BoxSide: Integer);
begin
with SourceRect do
begin
Left:=BoxCenterX-BoxSide;
Top:=BoxCenterY-BoxSide;
Right:=BoxCenterX+BoxSide;
Bottom:=BoxCenterY+BoxSide;
end;

with DestRect do
begin
Left:=BoxCenterX-dSide;
Top:=BoxCenterY-dSide;
Right:=BoxCenterX+dSide;
Bottom:=BoxCenterY+dSide;
end;

ForeImage.Canvas.CopyRect(DestRect, BackImage.Canvas, SourceRect);
end;

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值