C#生成缩略图不失真的方法

2024-05-04 02:18

本文主要是介绍C#生成缩略图不失真的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近一个手持机项目有个需求,因为物料图片的大小不一,有的很大显示到手持机上会只显示图片的一部分,界面显得非常乱,很影响客户的体验度。所以需要一个方法,将上传到服务器上的图片进行处理,按照一定的大小格式进行保存。

下面提供了两种获取图片缩略图的方法,供大家参考。

方法一:通过调用Image对象的自带方法GetThumbnailImage()进行图片转换

        /// <summary>/// 生成缩略图重载方法,返回缩略图的Image对象/// </summary>/// <param name="width">缩略图的宽度</param>/// <param name="height">缩略图的高度</param>/// <param name="imageFrom">原Image对象</param>/// <returns>缩略图的Image对象</returns>public Image GetReducedImage2(int width, int height, Image imageFrom){// 源图宽度及高度 int imageFromWidth = imageFrom.Width;int imageFromHeight = imageFrom.Height;try{// 生成的缩略图实际宽度及高度.如果指定的高和宽比原图大,则返回原图;否则按照指定高宽生成图片if (width >= imageFromWidth && height >= imageFromHeight){return imageFrom;}else{Image.GetThumbnailImageAbort callb = new Image.GetThumbnailImageAbort(() => { return false; });//调用Image对象自带的GetThumbnailImage()进行图片缩略Image reducedImage = imageFrom.GetThumbnailImage(width, height, callb, IntPtr.Zero);//将图片以指定的格式保存到到指定的位置reducedImage.Save(@"E:\640x480.png", ImageFormat.Png);return reducedImage;}}catch (Exception){//抛出异常throw new Exception("转换失败,请重试!");}}

方法二:采用双三次插值法,执行预筛选以确保高质量的收缩,此模式可产生质量教高的转换图像。

        /// <summary>/// 按照指定的高和宽生成相应的规格的图片,采用此方法生成的缩略图片不会失真/// </summary>/// <param name="width">指定宽度</param>/// <param name="height">指定高度</param>/// <param name="imageFrom">原图片</param>/// <returns>返回新生成的图</returns>public static Image GetReducedImage(int width, int height, Image imageFrom){// 源图宽度及高度 int imageFromWidth = imageFrom.Width;int imageFromHeight = imageFrom.Height;// 生成的缩略图实际宽度及高度.如果指定的高和宽比原图大,则返回原图;否则按照指定高宽生成图片if (width >= imageFromWidth && height >= imageFromHeight){return imageFrom;}else{// 生成的缩略图在上述"画布"上的位置int X = 0;int Y = 0;// 创建画布Bitmap bmp = new Bitmap(width, height, PixelFormat.Format24bppRgb);bmp.SetResolution(imageFrom.HorizontalResolution, imageFrom.VerticalResolution);using (Graphics g = Graphics.FromImage(bmp)){// 用白色清空 g.Clear(Color.White);// 指定高质量的双三次插值法。执行预筛选以确保高质量的收缩。此模式可产生质量最高的转换图像。 g.InterpolationMode = InterpolationMode.HighQualityBicubic;// 指定高质量、低速度呈现。 g.SmoothingMode = SmoothingMode.HighQuality;// 在指定位置并且按指定大小绘制指定的 Image 的指定部分。 g.DrawImage(imageFrom, new Rectangle(X, Y, width, height),new Rectangle(0, 0, imageFromWidth, imageFromHeight), GraphicsUnit.Pixel);//将图片以指定的格式保存到到指定的位置bmp.Save(@"E:\640x480.png", ImageFormat.Png);return bmp;}}}

先分享这两种方法,大家可以尝试。

这篇关于C#生成缩略图不失真的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/958139

相关文章

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D