中秋到了,首先祝各位猿友节日快乐!!!

  本博文的原名称是“跟我一起用C#压缩照片上传到各种空间”,评论上有人开骂,没办法我这人就是自信霸气,但是既然有人提出来我还是改掉吧,如果文章写得不好的地方欢迎大家指正,如果是单纯骂人的话我想除了显现出骂人者的不良形象外对我无任何消极影响。

  本人一般也很少上传照片之类的女生喜欢玩的东西,但是偶尔还是要传一传的,为什么?因为现在与各种以前的朋友同学都很少联系,但是只要一发有个人照片的微博或日志便引来各种鲜花鸡蛋。

  周末和几个同学去了西涌露营,这么美丽的海滩不上传照片分享着实可惜,可是现在的相机拍出来的照片很大,特别是单反,而咱们的网络带宽又何其可怜,所以先压缩再上传会是非常好的选择,可是呢这么多张照片一张张压缩太麻烦了(鄙人对作图是小白,不懂得使用做图工具),而咱是码农,码农就要用码农的方式,于是乎就想做个程序了。

  好了废话了那么多开工了。

  第一次迭代开始,先完成单张相片压缩的Demo。我始终坚信好的代码是重构出来的,因而在这里我将使用迭代开发的思想逐步完成这个程序。先看下第一次迭代的代码

        static void Main(string[] args)
{
string savePath = @"E:\2013相片\上传前\";
string sourcePath = @"E:\2013相片\QQ空间使用\";
string sourceName = "DSC_0216.JPG";
int scale = ; Image img = Image.FromFile(sourcePath + sourceName);
int width = img.Width / scale;
int height = img.Height / scale; Image imgNew = new Bitmap(width, height);
Graphics g = Graphics.FromImage(imgNew);
g.DrawImage(img, new System.Drawing.Rectangle(, , width, height),
new System.Drawing.Rectangle(, , img.Width, img.Height),
System.Drawing.GraphicsUnit.Pixel); imgNew.Save(savePath + "a.jpg", ImageFormat.Jpeg);
}

首次迭代代码

  这样就保证了这个代码已经能处理单张照片了。

  第二次迭代,对其进行重构。

经过分析,该功能的实现需要两步,第一获取要缩小的图片集合,第二就是缩小图片的逻辑,故而就有了以下重构后的代码

class Program
{
static readonly string[] IMAGE_EXTNAME = new string[] { "jpg"};
static void Main(string[] args)
{
string savePath = @"E:\2013相片\上传前\";
string sourcePath = @"E:\2013相片\QQ空间使用\";
int scale = ; List<string> imageNames = GetImageNames(sourcePath);
if (imageNames != null && imageNames.Count > )
{
foreach (var item in imageNames)
{
SaveSmallPhoto(sourcePath + item, scale, savePath + item);
}
}
} /// <summary>
/// 获取路径下所有符合指定图片后缀文件名
/// </summary>
/// <param name="path">路径</param>
/// <returns></returns>
static List<string> GetImageNames(string path)
{
string[] fileNames = Directory.GetFiles(path);
if (fileNames == null || fileNames.Length == )
{
return null;
} List<string> imageNames = new List<string>();
foreach (var item in fileNames)
{
if (ExistsInExtName(item, IMAGE_EXTNAME))
{
imageNames.Add(item.Substring(item.LastIndexOf('\\') + ));
}
} return imageNames;
} /// <summary>
/// 判断文件名是否符合指定后缀名
/// </summary>
/// <param name="name">文件名</param>
/// <param name="extNames">符合要求的后缀名</param>
/// <returns></returns>
static bool ExistsInExtName(string name, string[] extNames)
{
if (string.IsNullOrEmpty(name) || extNames == null || extNames.Length == )
{
return false;
} foreach (var item in extNames)
{
if (name.ToLower().EndsWith(item))
{
return true;
}
} return false;
} /// <summary>
/// 将图片按比例缩小保存
/// </summary>
/// <param name="fromPath">原图片路径名</param>
/// <param name="scale">缩小比例</param>
/// <param name="toPath">缩小后保存的路径名</param>
static void SaveSmallPhoto(string fromPath, int scale, string toPath)
{
int width, height;
using (Image img = Image.FromFile(fromPath))
{
width = img.Width / scale;
height = img.Height / scale; using (Image imgNew = new Bitmap(width, height))
{
using (Graphics g = Graphics.FromImage(imgNew))
{
g.DrawImage(img, new Rectangle(, , width, height),
new Rectangle(, , img.Width, img.Height), System.Drawing.GraphicsUnit.Pixel);
} imgNew.Save(toPath, ImageFormat.Jpeg);
}
}
}
}

终结代码

  是不是很简单啊?在这里使用的一些路径比例的变量,可将其写在配置文件,后续再压缩照片,只要修改相应配置即可轻松实现。

  完了之后,大家有更好的关于压缩照片的办法不妨拿出来分享下!

  好了过程完毕上传张周末去深圳西涌玩的照片吧(照片是全景拍摄的,但是不知道为啥上传后不能全看到)

用C#缩小照片上传到各种空间的更多相关文章

  1. css实现照片上传的加号框

    css实现照片上传的加号框    

  2. Android实现批量照片上传至server,拍照或者从相冊选择

    近期因为项目需求,须要完毕批量照片上传,折腾了一段时间,最终完毕了,达到了例如以下效果 主界面主要有GridView组成和button组成,当按下一个格点时,会调用相机或者相冊,拍照或者选择相冊照片, ...

  3. Android 照片上传

    解释全在代码中: // 拍照上传 private OnClickListener mUploadClickListener = new OnClickListener() { public void ...

  4. 微信调用照相拍照等 js 接口的权限配置 和 照片上传和下载实现

    直接上代码: 1. 前端调试代码: <html> <head> <meta http-equiv="Content-Type" content=&qu ...

  5. android小文章——手机照片上传服务器方法

    手机上传:http://blog.csdn.net/bitter_2014/article/details/40618587

  6. MUI 拍照或选取照片上传作为头像

    1.第一种方法是用H5来实现的 HTML: <label> <input style="opacity: 0;" type="file" ac ...

  7. python-函数进阶-动态传参,名称空间,作用域的问题

    一.函数的动态的动态参数 动态参数分为两种:动态接收位置参数.动态接收关键字参数. 1.*args  位置参数动态传参 # 顺序: 位置参数=>*args(arguments) => 默认 ...

  8. 一文了解H5照片上传过程

    一.选择拍照或文件 HTML: 使用<input>标签, type设为"file"选择文件, accept设为"image/*"选择文件为图片类型和 ...

  9. springboot中的照片上传工具类

    public class UploadImgUtils { private static String savePath = ""; /** * 上传照片工具类 * * @para ...

随机推荐

  1. ClickOnce部署(4):下载多个安装包

    有时候,我们可能会一次性发布多个安装包,当然在网页上多加几个链接让用户逐个安装也是可取的.不过,也可以弄得更方便些,即用户先安装一个,作为一个"引导程序",然后通过这个程序去下载安 ...

  2. contains与compareDocumentPosition

    Sizzle中有一个contains方法(jQuery.contains),用来遍历是否包含指定的元素 IE率先引入一个contains()方法,可以在节点中查找某一个节点是不是当前节点的厚点,如果 ...

  3. jQuery 2.0.3 源码分析 Deferred概念

    JavaScript编程几乎总是伴随着异步操作,传统的异步操作会在操作完成之后,使用回调函数传回结果,而回调函数中则包含了后续的工作.这也是造成异步编程困难的主要原因:我们一直习惯于“线性”地编写代码 ...

  4. 前端MVC框架Backbone 1.1.0源码分析(一)

    前言 如何定义库与框架 前端的辅助工具太多太多了,那么我们是如何定义库与框架? jQuery是目前用的最广的库了,但是整体来讲jQuery目的性很也明确针对“DOM操作”,当然自己写一个原生态方法也能 ...

  5. .Net 转战 Android 4.4 日常笔记(2)--HelloWorld入门程序

    我不知道人们为什么那么喜欢用HelloWorld来做为自己的第一个程序入门,为什么不是hello **其他的东西或者hi. 一.打开ADT 的Eclipse开发工具新建一个Android项目 New- ...

  6. mac下安装tomcat

    在window下面搭建tomcat环境很简单,那是因为我们不熟悉mac系统,当我们习惯了命令行的时候,也是so easy,只要通过以下几个步骤就可以解决,本人亲测可用,不会可以留言. 1.进入apch ...

  7. 2014年百度之星程序设计大赛 - 初赛(第二轮)Chess

    题目描述:小度和小良最近又迷上了下棋.棋盘一共有N行M列,我们可以把左上角的格子定为(1,1),右下角的格子定为(N,M).在他们的规则中,“王”在棋盘上的走法遵循十字路线.也就是说,如果“王”当前在 ...

  8. pixi.js教程中文版--基础篇

    前言 Pixi.js使用WebGL,是一个超快的HTML5 2D渲染引擎.作为一个Javascript的2D渲染器,Pixi.js的目标是提供一个快速的.轻量级而且是兼任所有设备的2D库.提供无缝 C ...

  9. CSS魔法堂:重拾Border之——更广阔的遐想

    前言  当CSS3推出border-radius属性时我们是那么欣喜若狂啊,一想到终于不用再添加额外元素来模拟圆角了,但发现border-radius还分水平半径和垂直半径,然后又发现border-t ...

  10. 悟透JavaScript

    要理解JavaScript,你得首先放下对象和类的概念,回到数据和代码的本原.前面说过,编程世界只有数据和代码两种基本元素,而这两种元素又有着纠缠不清的关系.JavaScript就是把数据和代码都简化 ...