Asp.Net上传图片同时生成高清晰缩略图
在asp.net中,上传图片功能或者是常用的,生成缩略图也是常用的。baidu或者google,c#的方法也是很多的,但是一用却发现缩略图不清晰啊,缩略图片太大之类的事情,下面是我在处理图片上的代码,效果不错,所以拿出来分享,(效果能达到一些绘图软件的效果)
代码如下:
///<summary>
///asp.net上传图片并生成缩略图
///</summary>
///<paramname="upImage">HtmlInputFile控件</param>
///<paramname="sSavePath">保存的路径,些为相对服务器路径的下的文件夹</param>
///<paramname="sThumbExtension">缩略图的thumb</param>
///<paramname="intThumbWidth">生成缩略图的宽度</param>
///<paramname="intThumbHeight">生成缩略图的高度</param>
///<returns>缩略图名称</returns>
publicstringUpLoadImage(HtmlInputFileupImage,stringsSavePath,stringsThumbExtension,intintThumbWidth,intintThumbHeight)
{
stringsThumbFile="";
stringsFilename="";
if(upImage.PostedFile!=null)
{
HttpPostedFilemyFile=upImage.PostedFile;
intnFileLen=myFile.ContentLength;
if(nFileLen==0)
return"没有选择上传图片";
//获取upImage选择文件的扩展名
stringextendName=System.IO.Path.GetExtension(myFile.FileName).ToLower();
//判断是否为图片格式
if(extendName!=".jpg"&&extendName!=".jpge"&&extendName!=".gif"&&extendName!=".bmp"&&extendName!=".png")
return"图片格式不正确";
byte[]myData=newByte[nFileLen];
myFile.InputStream.Read(myData,0,nFileLen);
sFilename=System.IO.Path.GetFileName(myFile.FileName);
intfile_append=0;
//检查当前文件夹下是否有同名图片,有则在文件名+1
while(System.IO.File.Exists(System.Web.HttpContext.Current.Server.MapPath(sSavePath+sFilename)))
{
file_append++;
sFilename=System.IO.Path.GetFileNameWithoutExtension(myFile.FileName)
+file_append.ToString()+extendName;
}
System.IO.FileStreamnewFile
=newSystem.IO.FileStream(System.Web.HttpContext.Current.Server.MapPath(sSavePath+sFilename),
System.IO.FileMode.Create,System.IO.FileAccess.Write);
newFile.Write(myData,0,myData.Length);
newFile.Close();
//以上为上传原图
try
{
//原图加载
using(System.Drawing.ImagesourceImage=System.Drawing.Image.FromFile(System.Web.HttpContext.Current.Server.MapPath(sSavePath+sFilename)))
{
//原图宽度和高度
intwidth=sourceImage.Width;
intheight=sourceImage.Height;
intsmallWidth;
intsmallHeight;
//获取第一张绘制图的大小,(比较原图的宽/缩略图的宽和原图的高/缩略图的高)
if(((decimal)width)/height<=((decimal)intThumbWidth)/intThumbHeight)
{
smallWidth=intThumbWidth;
smallHeight=intThumbWidth*height/width;
}
else
{
smallWidth=intThumbHeight*width/height;
smallHeight=intThumbHeight;
}
//判断缩略图在当前文件夹下是否同名称文件存在
file_append=0;
sThumbFile=sThumbExtension+System.IO.Path.GetFileNameWithoutExtension(myFile.FileName)+extendName;
while(System.IO.File.Exists(System.Web.HttpContext.Current.Server.MapPath(sSavePath+sThumbFile)))
{
file_append++;
sThumbFile=sThumbExtension+System.IO.Path.GetFileNameWithoutExtension(myFile.FileName)+
file_append.ToString()+extendName;
}
//缩略图保存的绝对路径
stringsmallImagePath=System.Web.HttpContext.Current.Server.MapPath(sSavePath)+sThumbFile;
//新建一个图板,以最小等比例压缩大小绘制原图
using(System.Drawing.Imagebitmap=newSystem.Drawing.Bitmap(smallWidth,smallHeight))
{
//绘制中间图
using(System.Drawing.Graphicsg=System.Drawing.Graphics.FromImage(bitmap))
{
//高清,平滑
g.InterpolationMode=System.Drawing.Drawing2D.InterpolationMode.High;
g.SmoothingMode=System.Drawing.Drawing2D.SmoothingMode.HighQuality;
g.Clear(Color.Black);
g.DrawImage(
sourceImage,
newSystem.Drawing.Rectangle(0,0,smallWidth,smallHeight),
newSystem.Drawing.Rectangle(0,0,width,height),
System.Drawing.GraphicsUnit.Pixel
);
}
//新建一个图板,以缩略图大小绘制中间图
using(System.Drawing.Imagebitmap1=newSystem.Drawing.Bitmap(intThumbWidth,intThumbHeight))
{
//绘制缩略图http://www.cnblogs.com/sosoft/
using(System.Drawing.Graphicsg=System.Drawing.Graphics.FromImage(bitmap1))
{
//高清,平滑
g.InterpolationMode=System.Drawing.Drawing2D.InterpolationMode.High;
g.SmoothingMode=System.Drawing.Drawing2D.SmoothingMode.HighQuality;
g.Clear(Color.Black);
intlwidth=(smallWidth-intThumbWidth)/2;
intbheight=(smallHeight-intThumbHeight)/2;
g.DrawImage(bitmap,newRectangle(0,0,intThumbWidth,intThumbHeight),lwidth,bheight,intThumbWidth,intThumbHeight,GraphicsUnit.Pixel);
g.Dispose();
bitmap1.Save(smallImagePath,System.Drawing.Imaging.ImageFormat.Jpeg);
}
}
}
}
}
catch
{
//出错则删除
System.IO.File.Delete(System.Web.HttpContext.Current.Server.MapPath(sSavePath+sFilename));
return"图片格式不正确";
}
//返回缩略图名称
returnsThumbFile;
}
return"没有选择图片";
}
HtmlInputFile控件我想大家都应该知道的,就是inputtype=file....
下面把调用代码也一起C上来
<%@PageLanguage="C#"AutoEventWireup="true"CodeFile="Default2.aspx.cs"Inherits="Default2"%> <!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlns="http://www.w3.org/1999/xhtml"> <headrunat="server"> <title>图片上传-柯乐义</title> </head> <body> <formid="form1"runat="server"> <div> <inputid="File1"runat="server"type="file"/></div><asp:ButtonID="Button1"runat="server"OnClick="Button1_Click"Text="Button"/> </form> </body> </html>
protectedvoidButton1_Click(objectsender,EventArgse)
{
stringa=this.UpLoadImage(this.File1,"UpLoad/","thumb_",118,118);
}
这样就会在你的UpLoad文件夹下多出两张图片,一张是原图,一张是缩略图。
提供一个更好的算法,由于没有时间去测试和调试,仅供参考
即,在第一步等比例缩小的时候,可以分多次,即把原图到上面代码的中间图以百分比缩小,
例如:原图为500*500我要缩略成100*80,上面代码程序会先绘制一张100*100的中间图,再在这图片上绘制100*80的,在绘制100*100中间图之前如果先绘300*300的中间图,再在300*300的基础上再绘100*100然后再绘100*80这样会比我上面的代码效果更好,图片更清晰,即中间图越多,效果越好,大家可以去试试。