您的位置:首页 > 其它

[收藏]使用GDI+绘制高质量图和字体

2008-03-12 13:32 721 查看

使用GDI+绘制高质量图和字体

对于GDI+,在正常的操作,Bitmap-- Graphcis -- DrawImage或者DrawString ,生成图片的话,会产生很多杂点,或者是图片质量不稳定..尤其是在读取图片后,生成缩略图之后,文件会被压缩而失真..

主要原因是因为没有重新设置Graphics的几个属性..

1.Graphics.SmoothingMode属性: 例如SmoothingMode.HighQuality可以产生高质量图片,但是效率低.

2.Graphics.CompositingQuality 属性: 例如:CompositingQuality.HighQuality也是产生高质量图,效率低下.

3.Graphics.InterpolationMode 属性,例如:InterpolationMode.HighQualityBicubic与前两个也是同样的效果.

这三个属性的值都是enum,具体的enum参数可以查看MSDN的说明..在这里就我不赘述..
如果是对图片进行放大,缩小,可以调整Graphics.CompositingQuality 和Graphics.InterpolationMode 两个属性..如果是图片生成,则可以调整Graphics.SmoothingMode属性..

另外一个问题就是关于文字生成的..按照正常的模式生成的文字,可以很明显的看到文字带有锯齿..解决的办法也是需要修改Graphics的一个属性: Graphics.TextRenderingHint...注意一点,修改TextRenderingHint的话,需要引入System.Drawing.Text,例如:Graphics.TextRenderingHint = System.Drawing.Text.TextRenderingHint.ClearTypeGridFit;

经过对这四个属性的修改,操作大部分的图片之后,产生的结果都是比较让人满意的..

在这里提供一个简单的例子..是生成印章签名的效果..提供四种字体选择..并产生一个图片..如果你的机器中没有安装指定的几种字体,你需要把字体修改一下...直接把代码拷贝..就可以看到效果...

ASPX页面:


程序代码
<%@ Page language="c#" Codebehind="underWrite.aspx.cs" AutoEventWireup="false" Inherits="testItem.movie.underWrite" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
<HEAD>
<title>underWrite</title>
<meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
<meta name="CODE_LANGUAGE" Content="C#">
<meta name="vs_defaultClientScript" content="JavaScript">
<meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
</HEAD>
<body MS_POSITIONING="GridLayout">
<form id="Form1" method="post" runat="server">
<asp:Image id="Image1" style="Z-INDEX: 101; LEFT: 208px; POSITION: absolute; TOP: 360px" runat="server"></asp:Image>
<asp:HyperLink id="HyperLink1" style="Z-INDEX: 105; LEFT: 304px; POSITION: absolute; TOP: 312px"
runat="server" NavigateUrl="../mv/index.html">大头帖</asp:HyperLink>
<asp:TextBox id="name" style="Z-INDEX: 104; LEFT: 208px; POSITION: absolute; TOP: 144px" runat="server"
MaxLength="4"></asp:TextBox>
<asp:RadioButtonList id="fontType" style="Z-INDEX: 103; LEFT: 208px; POSITION: absolute; TOP: 184px"
runat="server" Width="240px">
<asp:ListItem Value="方正黄草简体" Selected="True">方正黄草简体</asp:ListItem>
<asp:ListItem Value="汉鼎繁淡古">汉鼎繁淡古</asp:ListItem>
<asp:ListItem Value="汉鼎繁印篆">汉鼎繁印篆</asp:ListItem>
<asp:ListItem Value="经典繁桟亭">经典繁桟亭</asp:ListItem>
</asp:RadioButtonList>
<asp:Button id="bu" style="Z-INDEX: 102; LEFT: 208px; POSITION: absolute; TOP: 312px" runat="server"
Text=" 刻 字 "></asp:Button>
</form>
</body>
</HTML>

CS文件:


程序代码
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Drawing.Drawing2D;
using System.IO;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;

namespace testItem.movie
{
/**//// <summary>
/// 生成印章签名
/// </summary>
public class underWrite : System.Web.UI.Page
{
protected System.Web.UI.WebControls.Image Image1;
protected System.Web.UI.WebControls.RadioButtonList fontType;
protected System.Web.UI.WebControls.HyperLink HyperLink1;
protected System.Web.UI.WebControls.Button bu;
protected System.Web.UI.WebControls.TextBox name;

private void Page_Load(object sender, System.EventArgs e)
{
Image1.Visible = false;
}

Web 窗体设计器生成的代码#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

/**//// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.bu.Click += new System.EventHandler(this.Button1_Click);
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion

private void Button1_Click(object sender, System.EventArgs e)
{
string Name = name.Text;
if ( Name.Length < 4 ) {
Response.Write( "请输入最少4个字符!" );
return;
}

string FontName = fontType.SelectedValue;

int fontSize = 36;
int x = 10;
int y = 10;

switch( FontName ) {
case "方正黄草简体":
x = -8;
y = -2;
fontSize = 42;
break;

case "汉鼎繁淡古":
x = -10;
y = -2;
break;

case "汉鼎繁印篆":
x = -15;
y = -2;
break;

case "经典繁桟亭":
fontSize = 34;
x = -10;
y = -3;
break;
}

Bitmap bm = new Bitmap(110,100,System.Drawing.Imaging.PixelFormat.Format32bppArgb);
Font font = new Font(FontName,fontSize,FontStyle.Bold);

Graphics g = Graphics.FromImage( bm );

g.TextRenderingHint = System.Drawing.Text.TextRenderingHint.ClearTypeGridFit;

/**//* 这里的三个属性可以根据情况开放.
*
//g.CompositingQuality = CompositingQuality.HighQuality;
//g.SmoothingMode = SmoothingMode.HighQuality;
//g.InterpolationMode = InterpolationMode.HighQualityBicubic;

*/
g.Clear(Color.Red); //赋予图像一个背景色

g.DrawString( Name.Substring(2,1),font,new SolidBrush(Color.White),0,2 );
g.DrawString( Name.Substring(3,1),font,new SolidBrush(Color.White),0,45-y );
g.DrawString( Name.Substring(0,1),font,new SolidBrush(Color.White),35-x,2 );
g.DrawString( Name.Substring(1,1),font,new SolidBrush(Color.White),35-x,45-y );
g.Dispose();
//设置保存路径
bm.Save( Server.MapPath("../upload/c.jpg"),System.Drawing.Imaging.ImageFormat.Jpeg );
bm.Dispose();
//显示产生的图片
Image1.ImageUrl = Server.MapPath("../upload/c.jpg") ;
Image1.Visible = true;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: