频道栏目
首页 > 资讯 > C# > 正文

C# 生成图片缩略图

14-10-27        来源:[db:作者]  
收藏   我要投稿

最近项目有部分需求,是关于图片操作部分的, 大致的功能就是图片的保存和展示。但是直接操作原图,程序运行效率太慢。而且如果传输数据量过大的话,可能直接导致调用WCF服务失败的问题。

为了解决这个问题,决定采用缩略图的方法。保存数据的时候保存原图和其缩略图。但主界面展示的时候只加载缩略图,点击缩略图后再显示其原图。这样就避免了一进入主界面就加载大量数据,提高了效率。

那么问题就来了,怎么将原图进行处理变成缩略图呢?

下面提供了一个图片处理的类,用来生成缩略图。对GetReducedImage函数进行4次重载来完成不同的需求。

using System.IO;
using System.Drawing;
using System.Drawing.Imaging;

///    
/// 图片处理类   
/// 1、生成缩略图片或按照比例改变图片的大小和画质   
/// 2、将生成的缩略图放到指定的目录下   
///    
public class ImageClass
{
    public Image ResourceImage;
    private int ImageWidth;
    private int ImageHeight;

    public string ErrMessage;

    ///    
    /// 类的构造函数   
    ///    
    /// 图片文件的全路径名称   
    public ImageClass(string ImageFileName)
    {
        ResourceImage = Image.FromFile(ImageFileName);
        ErrMessage = "";
    }

    public bool ThumbnailCallback()
    {
        return false;
    }

    ///    
    /// 生成缩略图重载方法1,返回缩略图的Image对象   
    ///    
    /// 缩略图的宽度   
    /// 缩略图的高度   
    /// 缩略图的Image对象   
    public Image GetReducedImage(int Width, int Height)
    {
        try
        {
            Image ReducedImage;

            Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);

            ReducedImage = ResourceImage.GetThumbnailImage(Width, Height, callb, IntPtr.Zero);

            return ReducedImage;
        }
        catch (Exception e)
        {
            ErrMessage = e.Message;
            return null;
        }
    }

    ///    
    /// 生成缩略图重载方法2,将缩略图文件保存到指定的路径   
    ///    
    /// 缩略图的宽度   
    /// 缩略图的高度   
    /// 缩略图保存的全文件名,(带路径),参数格式:D:Images ilename.jpg   
    /// 成功返回true,否则返回false   
    public bool GetReducedImage(int Width, int Height, string targetFilePath)
    {
        try
        {
            Image ReducedImage;

            Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);

            ReducedImage = ResourceImage.GetThumbnailImage(Width, Height, callb, IntPtr.Zero);
            ReducedImage.Save(@targetFilePath, ImageFormat.Jpeg);

            ReducedImage.Dispose();

            return true;
        }
        catch (Exception e)
        {
            ErrMessage = e.Message;
            return false;
        }
    }

    ///    
    /// 生成缩略图重载方法3,返回缩略图的Image对象   
    ///    
    /// 缩略图的宽度百分比 如:需要百分之80,就填0.8     
    /// 缩略图的Image对象   
    public Image GetReducedImage(double Percent)
    {
        try
        {
            Image ReducedImage;

            Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);

            ImageWidth = Convert.ToInt32(ResourceImage.Width * Percent);
            ImageHeight = Convert.ToInt32(ResourceImage.Width * Percent);

            ReducedImage = ResourceImage.GetThumbnailImage(ImageWidth, ImageHeight, callb, IntPtr.Zero);

            return ReducedImage;
        }
        catch (Exception e)
        {
            ErrMessage = e.Message;
            return null;
        }
    }

    ///    
    /// 生成缩略图重载方法4,返回缩略图的Image对象   
    ///    
    /// 缩略图的宽度百分比 如:需要百分之80,就填0.8     
    /// 缩略图保存的全文件名,(带路径),参数格式:D:Images ilename.jpg   
    /// 成功返回true,否则返回false   
    public bool GetReducedImage(double Percent, string targetFilePath)
    {
        try
        {
            Image ReducedImage;

            Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(ThumbnailCallback);

            ImageWidth = Convert.ToInt32(ResourceImage.Width * Percent);
            ImageHeight = Convert.ToInt32(ResourceImage.Width * Percent);

            ReducedImage = ResourceImage.GetThumbnailImage(ImageWidth, ImageHeight, callb, IntPtr.Zero);

            ReducedImage.Save(@targetFilePath, ImageFormat.Jpeg);

            ReducedImage.Dispose();

            return true;
        }
        catch (Exception e)
        {
            ErrMessage = e.Message;
            return false;
        }
    }

}

效果图:

用GetReducedImage(double Percent)方法测试了一下,传入缩略百分比为 0.05

原图大小为1M,处理后的图片大小仅几十KB,程序运行效率的确提高了不少。

相关TAG标签
上一篇:Java程序员的JavaScript学习笔记(8——jQuery选择器)
下一篇:(三)underscore.js框架Objects类API学习
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站