GDI+相关的作图,每种语言都有其自身的封装类,但本质上是一样的,下面这篇文章写的非常好,对于C#的Graphics类也是使用的,所以转载了,原文在这里:

http://www.cnblogs.com/del/archive/2009/12/22/1630120.html

相关内容有:


IGPGraphics.SmoothingMode;            { 绘图质量 }
IGPGraphics.InterpolationMode;        { 插补模式 }
IGPGraphics.CompositingMode;          { 前景色与背景色的合成混合模式 }
IGPGraphics.CompositingQuality;      { 图像合成质量 }
IGPGraphics.PixelOffsetMode;          { 像素的偏移模式 } { 文本的呈现质量要用 }
IGPGraphics.TextRenderingHint;        { 文本呈现模式 }
IGPGraphics.TextContrast;            { 文本灰度校正值(消除锯齿和 ClearType 文本的伽玛值校正) }

相关参数:


SmoothingMode { 对直线、曲线和已填充区域的边缘采用锯齿消除功能, 它不能控制路径渐变画笔 }
Invalid    // 一个无效模式 
Default    // 不消除锯齿, 等效于 HighSpeed、None
HighSpeed  // 不消除锯齿 
HighQuality // 消除锯齿, 等效于 AntiAlias
None        // 不消除锯齿 
AntiAlias  // 消除锯齿
InterpolationMode { 插补模式确定如何计算两个像素点之间的中间值 }
Invalid            // 等效于 QualityMode 枚举的 Invalid 元素.
Default            // 默认模式.
Low                // 低质量插值法.
High                // 高质量插值法.
Bilinear            // 双线性插值法; 不进行预筛选; 将图像收缩为原始大小的 50% 以下时此模式不适用.
Bicubic            // 双三次插值法; 不进行预筛选; 将图像收缩为原始大小的 25% 以下时此模式不适用.
NearestNeighbor    // 最临近插值法.
HighQualityBilinear // 高质量的双线性插值法; 执行预筛选以确保高质量的收缩.
HighQualityBicubic  // 高质量的双三次插值法; 执行预筛选以确保高质量的收缩; 可产生质量最高的转换图像.
CompositingMode { 颜色合成模式 }
SourceOver  // 与背景色混合; 该混合由透明度确定
SourceCopy  // 改写背景色
CompositingQuality { 图像合成时, 源像素与目标像素和合成方式 }
Invalid        // 无效质量
Default        // 默认质量
HighSpeed      // 高速度、低质量
HighQuality    // 高质量、低速度复合
GammaCorrected // 使用灰度校正
AssumeLinear  // 假定线性值
PixelOffsetMode { 像素偏移模式 }
Invalid    // 无效模式.
Default    // 默认模式.
HighSpeed  // 高速度、低质量呈现.
HighQuality // 高质量、低速度呈现.
None        // 没有任何像素偏移.
Half        // 像素在水平和垂直距离上均偏移 -0.5 个单位, 以进行高速锯齿消除.

SmoothingMode 测试:


uses GdiPlus;

procedure TForm1.FormPaint(Sender: TObject);
var   Graphics: IGPGraphics;   Pen: IGPPen;   Rect: TGPRectF;   i: Integer;
begin   Graphics := TGPGraphics.Create(Handle);   Pen := TGPPen.Create($FFB22222, 4);   Rect.Initialize(ClientWidth * 3/8, ClientHeight * 3/8, ClientWidth / 4, ClientHeight / 4);   for i := 0 to 4 do   begin     Graphics.SmoothingMode := TGPSmoothingMode(i);     Graphics.DrawEllipse(Pen, Rect);     Rect.Inflate(ClientWidth / 14, ClientHeight / 14);   end;
end;

InterpolationMode 测试:


uses GdiPlus;

procedure TForm1.FormPaint(Sender: TObject);
var   Graphics: IGPGraphics;   Image: IGPImage;   Rect: TGPRectF;   i: Integer;
begin   Graphics := TGPGraphics.Create(Handle);   Image := TGPImage.Create('C:\GdiPlusImg\Grapes.jpg');   Rect.Initialize(10, 10, Image.Width * 0.5, Image.Height * 0.5);   for i := 0 to 7 do   begin     Graphics.InterpolationMode := TGPInterpolationMode(i);     Graphics.DrawImage(Image, Rect);     Rect.Offset(Rect.Width + 10, 0);     if Rect.X + Rect.Width > ClientWidth then     begin       Rect.X := 10;       Rect.Offset(0, Rect.Height + 10);     end;   end;
end; procedure TForm1.FormResize(Sender: TObject);
begin   Repaint;
end;

CompositingMode 测试:


uses GdiPlus;

procedure TForm1.FormPaint(Sender: TObject);
var   Graphics: IGPGraphics;   Brush: IGPLinearGradientBrush;   Rect: TGPRect;
begin   Graphics := TGPGraphics.Create(Handle);   Rect.Initialize(20, 20, 200, 60);   Brush := TGPLinearGradientBrush.Create(Rect, $FFA52A2A, $FFFFFF00, 0);   Graphics.CompositingMode := CompositingModeSourceOver; //默认模式   Graphics.FillRectangle(Brush, Rect);   Brush := TGPLinearGradientBrush.Create(Rect, $80A52A2A, $80FFFF00, 0);   Graphics.CompositingMode := CompositingModeSourceOver;   Rect.Offset(0, 20 + Rect.Height);   Graphics.FillRectangle(Brush, Rect);   Graphics.CompositingMode := CompositingModeSourceCopy;   Rect.Offset(0, 20 + Rect.Height);   Graphics.FillRectangle(Brush, Rect);
end;

CompositingQuality 测试:


uses GdiPlus;

procedure TForm1.FormPaint(Sender: TObject);
var   Graphics: IGPGraphics;   Image: IGPImage;   Rect: TGPRectF;   Brush: IGPSolidBrush;   i: Integer;
begin   Graphics := TGPGraphics.Create(Handle);   Image := TGPImage.Create('C:\GdiPlusImg\Grapes.jpg');   Rect.Initialize(10, 10, Image.Width * 0.75, Image.Height * 0.75);   Brush := TGPSolidBrush.Create($800000FF);   for i := 0 to 4 do   begin     Graphics.CompositingQuality := TGPCompositingQuality(i);     Graphics.DrawImage(Image, Rect);     Graphics.FillRectangle(Brush, Rect);     Rect.Offset(Rect.Width + 10, 0);     if Rect.X + Rect.Width > ClientWidth then     begin       Rect.X := 10;       Rect.Offset(0, Rect.Height + 10);     end;   end;
end; procedure TForm1.FormResize(Sender: TObject);
begin   Repaint;
end;

PixelOffsetMode 测试:


uses GdiPlus;

procedure TForm1.FormPaint(Sender: TObject);
var   Graphics: IGPGraphics;   BrushBack: IGPHatchBrush;   Brush: IGPSolidBrush;   Rect: TGPRectF;   i: Integer;
begin   Graphics := TGPGraphics.Create(Handle);   BrushBack := TGPHatchBrush.Create(HatchStyleCross, $FFD0D0D0, $FFFFFFFF);   Graphics.FillRectangle(BrushBack, TGPRect.Create(ClientRect));   Rect.Initialize(0.34, 1, 5.1, 1.3);   Brush := TGPSolidBrush.Create($80FF0000);   Graphics.ScaleTransform(27.3, 17.3);   for i := 0 to 4 do   begin     Graphics.PixelOffsetMode := TGPPixelOffsetMode(i);     Graphics.FillRectangle(Brush, Rect);     Rect.Offset(0, Rect.Height + 1);   end;
end;

另外在补充一个万一老师的GDI+的学习文章列表地址,虽然是用Delphi写的,但是还是有参考意义:

http://www.cnblogs.com/del/category/113557.html

【转】Graphics 关于呈现质量与合成模式的更多相关文章

  1. JAVA设计模式之合成模式

    在阎宏博士的<JAVA与模式>一书中开头是这样描述合成(Composite)模式的: 合成模式属于对象的结构模式,有时又叫做“部分——整体”模式.合成模式将对象组织到树结构中,可以用来描述 ...

  2. 合成模式(Composite)-结构型

    原理 合成模式属于对象的结构模式,有时又叫做“部分——整体”模式.合成模式将对象组织到树结构中,可以用来描述整体与部分的关系.合成模式可以使客户端将单纯元素与复合元素同等看待. 有时候又叫做部分-整体 ...

  3. 设计模式_Composite_合成模式

    形象例子: Mary今天过生日.“我过生日,你要送我一件礼物.”“嗯,好吧,去 商店,你自己挑.”“这件T恤挺漂亮,买,这条裙子好看,买,这个包也不错,买.”“喂,买了三件了呀,我只答应送一件礼物的哦 ...

  4. Java设计模式-合成模式

    合成模式有时也叫组合模式,对象组合成树形结构以表示"部分-整体"的层次结构,组合模式使得用户对单个对象和组合对象的使用具有一致性.掌握组合模式的重点是要理解清楚 "部分/ ...

  5. java设计模式---合成模式3

    实例 下面以一个逻辑树为例子,以上面的原理图为蓝本,看看如何实现并如何使用这个树,这个结构很简单,但是如何去使用树,遍历树.为我所用还是有一定难度的.   这里主要用到树的递归遍历,如何递归.如何控制 ...

  6. java设计模式---合成模式2

    合成模式属于对象的结构模式,有时又叫做"部分--整体"模式.合成模式将对象组织到树结构中,可以用来描述整体与部分的关系.合成模式可以使客户端将单纯元素与复合元素同等看待. 合成模式 ...

  7. 组合模式 合成模式 COMPOSITE 结构型 设计模式(十一)

    组合模式(合成模式 COMPOSITE) 意图 将对象组合成树形结构以表示“部分-整体”的层次结构. Composite使得用户对单个对象和组合对象的使用具有一致性.   树形结构介绍 为了便于理解, ...

  8. Java设计模式(六)合成模式 享元模式

    (十一)合成模式 Composite 合成模式是一组对象的组合,这些对象能够是容器对象,也能够是单对象.组对象同意包括单对象,也能够包括其它组对象,要为组合对象和单对象定义共同的行为.合成模式的意义是 ...

  9. 《JAVA与模式》之合成模式

    在阎宏博士的<JAVA与模式>一书中开头是这样描述合成(Composite)模式的: 合成模式属于对象的结构模式,有时又叫做“部分——整体”模式.合成模式将对象组织到树结构中,可以用来描述 ...

随机推荐

  1. http 状态码 码表

    HTTP状态码详解 - 查询资料 1xx消息 这一类型的状态码,代表请求已被接受,需要继续处理.这类响应是临时响应,只包含状态行和某些可选的响应头信息,并以空行结束.由于HTTP/1.0协议中没有定义 ...

  2. jmeter 正则获取参数集合和ForEach控制器结合使用

    怎么把第一个请求获取的返回的多个id,在第二个请求中逐个以单个id作为请求参数来请求? 为了解决这个问题,模拟下该场景 1.请求www.163.com 主页,获取响应中的所有数字,这个获取的数字集合暂 ...

  3. python selenium 使用unittest 示例

    python selenium 使用unittest 示例 并等待某个元素示例 from selenium.webdriver.support.ui import WebDriverWait from ...

  4. 使用 properties 配置文件装配 bean 的方式

    在spring中将bean 注册到spring 容器中常见的有三种方式(两类): 先说明配置文件内容:application.yml,有一段配置如下 persons: youtube: name: y ...

  5. 双系统(win8.1+ubuntu14.04)删除win下分区导致grub rescue解决方案

    几个grub rescue下的命令的含义: set 设置环境变量 ls 查看设备 insmod 加载模块 root 指定用于启动系统的分区 prefix 设定grub启动路径 操作流程: 1.  先使 ...

  6. MYSQL拒绝访问:not allowed to connect解决方法

    分享下MYSQL拒绝访问报错not allowed to connect的解决方法. 可以在其它任何的主机上以root身份登录 mysql报如下错误,截取部分, message from server ...

  7. [svc]ssh批量分发key/批量用户管理

    centos6 sshpass批量分发key yum install sshpass -y ssh-keygen -t dsa -f ~/.ssh/id_dsa -P "" 命令说 ...

  8. 分布式缓存Memcache和Redis

    引言 针对于如今计算机的CPU和网络设施,相应用程序来说,运行效率的瓶颈.已经不是代码的长度(实现同一个功能)和带宽了,而是,代码訪问资源的过程.即:让我们的程序慢下来的罪魁祸首就是IO操作. 程序从 ...

  9. rpmverify命令用来验证已安装的rpm软件包的正确性

    -Va:验证所有软件包: 来自: http://man.linuxde.net/rpmverify -Va:验证所有软件包: [root@DB ~]# rpmverify -Va ....L.... ...

  10. localtime 和 localtime_r

    #include <cstdlib> #include <iostream> #include <time.h> #include <stdio.h> ...