asp.net MVC上传图片完整方法
2013-10-30 10:46
337 查看
图片上传 自动创建文件夹并重命名(带缩略图)
后台:
缩略图 Code
后台:
#region 生成缩略图 /**/ /// <summary> /// 生成缩略图 /// </summary> /// <param name="originalImagePath">源图路径(物理路径)</param> /// <param name="thumbnailPath">缩略图路径(物理路径)</param> /// <param name="width">缩略图宽度</param> /// <param name="height">缩略图高度</param> /// <param name="mode">生成缩略图的方式</param> public static void MakeThumbnail(string originalImagePath, string thumbnailPath, int width, int height, string mode) { System.Drawing.Image originalImage = System.Drawing.Image.FromFile(originalImagePath); int towidth = width; int toheight = height; int x = 0; int y = 0; int ow = originalImage.Width; int oh = originalImage.Height; switch (mode) { case "HW"://指定高宽缩放(可能变形) break; case "W"://指定宽,高按比例 toheight = originalImage.Height * width / originalImage.Width; break; case "H"://指定高,宽按比例 towidth = originalImage.Width * height / originalImage.Height; break; case "Cut"://指定高宽裁减(不变形) if ((double)originalImage.Width / (double)originalImage.Height > (double)towidth / (double)toheight) { oh = originalImage.Height; ow = originalImage.Height * towidth / toheight; y = 0; x = (originalImage.Width - ow) / 2; } else { ow = originalImage.Width; oh = originalImage.Width * height / towidth; x = 0; y = (originalImage.Height - oh) / 2; } break; default: break; } //新建一个bmp图片 System.Drawing.Image bitmap = new System.Drawing.Bitmap(towidth, toheight); //新建一个画板 System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(bitmap); //设置高质量插值法 g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.High; //设置高质量,低速度呈现平滑程度 g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality; //清空画布并以透明背景色填充 g.Clear(System.Drawing.Color.Transparent); //在指定位置并且按指定大小绘制原图片的指定部分 g.DrawImage(originalImage, new System.Drawing.Rectangle(0, 0, towidth, toheight), new System.Drawing.Rectangle(x, y, ow, oh), System.Drawing.GraphicsUnit.Pixel); try { //以jpg格式保存缩略图 bitmap.Save(thumbnailPath, System.Drawing.Imaging.ImageFormat.Jpeg); } catch (System.Exception e) { throw e; } finally { originalImage.Dispose(); bitmap.Dispose(); g.Dispose(); } } #endregion
缩略图 Code
相关文章推荐
- FCKeditor 图片上传进度条不动的解决方法
- 数据包上传到shopex商城后图片显示有问题的解决方法
- 将图片从PDA端上传到Web服务器的方法
- php完整图片上传代码
- input标签上传图片到后端前用H5的FileReader 方法实现图片的显示
- vue中使用axios post上传头像/图片并实时显示到页面的方法
- ios中摄像头/相册获取图片,压缩图片,上传服务器方法总结
- JavaScript上传图片的方法 判断图片的格式和大小、获取图片的base64编码
- iOS 上传图片方法总结
- jquery实现图片上传之前预览的方法
- 从零开始学习Node.js系列教程三:图片上传和显示方法示例
- springMVC使用ajaxFailUpload上传图片的方法
- IOS上传图片的方法
- IOS上传图片的方法
- DZ6上传图片附件无法显示,解决方法
- .Net实现上传图片按比例自动缩小或放大的方法
- FCKeditor上传图片提示“没有权限”的解决方法(.net)
- AFNetworking 3 批量上传图片的 3 种方法
- node.js中实现kindEditor图片上传功能的方法教程