`
greenwen
  • 浏览: 220461 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

图片上传压缩处理

    博客分类:
  • java
 
阅读更多
源自:http://www.iteye.com/topic/266585
/**
 *  缩略图实现,将图片(jpg、bmp、png、gif等等)真实的变成想要的大小
 */
package com.joewalker.test;

import java.awt.Image;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import javax.imageio.ImageIO;
import com.sun.image.codec.jpeg.JPEGCodec;
import com.sun.image.codec.jpeg.JPEGImageEncoder;

/*******************************************************************************
 * 缩略图类(通用) 本java类能将jpg、bmp、png、gif图片文件,进行等比或非等比的大小转换。 具体使用方法
 * compressPic(大图片路径,生成小图片路径,大图片文件名,生成小图片文名,生成小图片宽度,生成小图片高度,是否等比缩放(默认为true))
 */
 public class CompressPicDemo { 
	 private File file = null; // 文件对象 
	 private String inputDir; // 输入图路径
	 private String outputDir; // 输出图路径
	 private String inputFileName; // 输入图文件名
	 private String outputFileName; // 输出图文件名
	 private int outputWidth = 100; // 默认输出图片宽
	 private int outputHeight = 100; // 默认输出图片高
	 private boolean proportion = true; // 是否等比缩放标记(默认为等比缩放)
	 public CompressPicDemo() { // 初始化变量
		 inputDir = ""; 
		 outputDir = ""; 
		 inputFileName = ""; 
		 outputFileName = ""; 
		 outputWidth = 100; 
		 outputHeight = 100; 
	 } 
	 public void setInputDir(String inputDir) { 
		 this.inputDir = inputDir; 
	 } 
	 public void setOutputDir(String outputDir) { 
		 this.outputDir = outputDir; 
	 } 
	 public void setInputFileName(String inputFileName) { 
		 this.inputFileName = inputFileName;
	 } 
	 public void setOutputFileName(String outputFileName) { 
		 this.outputFileName = outputFileName; 
	 } 
	 public void setOutputWidth(int outputWidth) {
		 this.outputWidth = outputWidth; 
	 } 
	 public void setOutputHeight(int outputHeight) { 
		 this.outputHeight = outputHeight; 
	 } 
	 public void setWidthAndHeight(int width, int height) { 
		 this.outputWidth = width;
		 this.outputHeight = height; 
	 } 
	 
	 /* 
	  * 获得图片大小 
	  * 传入参数 String path :图片路径 
	  */ 
	 public long getPicSize(String path) { 
		 file = new File(path); 
		 return file.length(); 
	 }
	 
	 // 图片处理 
	 public String compressPic() { 
		 try { 
			 //获得源文件 
			 file = new File(inputDir + inputFileName); 
			 if (!file.exists()) { 
				 return ""; 
			 } 
			 Image img = ImageIO.read(file); 
			 // 判断图片格式是否正确 
			 if (img.getWidth(null) == -1) {
				 System.out.println(" can't read,retry!" + "<BR>"); 
				 return "no"; 
			 } else { 
				 int newWidth; int newHeight; 
				 // 判断是否是等比缩放 
				 if (this.proportion == true) { 
					 // 为等比缩放计算输出的图片宽度及高度 
					 double rate1 = ((double) img.getWidth(null)) / (double) outputWidth + 0.1; 
					 double rate2 = ((double) img.getHeight(null)) / (double) outputHeight + 0.1; 
					 // 根据缩放比率大的进行缩放控制 
					 double rate = rate1 > rate2 ? rate1 : rate2; 
					 newWidth = (int) (((double) img.getWidth(null)) / rate); 
					 newHeight = (int) (((double) img.getHeight(null)) / rate); 
				 } else { 
					 newWidth = outputWidth; // 输出的图片宽度 
					 newHeight = outputHeight; // 输出的图片高度 
				 } 
			 	BufferedImage tag = new BufferedImage((int) newWidth, (int) newHeight, BufferedImage.TYPE_INT_RGB); 
			 	
			 	/*
				 * Image.SCALE_SMOOTH 的缩略算法 生成缩略图片的平滑度的
				 * 优先级比速度高 生成的图片质量比较好 但速度慢
				 */ 
			 	tag.getGraphics().drawImage(img.getScaledInstance(newWidth, newHeight, Image.SCALE_SMOOTH), 0, 0, null);
			 	FileOutputStream out = new FileOutputStream(outputDir + outputFileName);
			 	// JPEGImageEncoder可适用于其他图片类型的转换 
			 	JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(out); 
			 	encoder.encode(tag); 
			 	out.close(); 
			 } 
		 } catch (IOException ex) { 
			 ex.printStackTrace(); 
		 } 
		 return "ok"; 
	} 
 	public String compressPic (String inputDir, String outputDir, String inputFileName, String outputFileName) { 
 		// 输入图路径 
 		this.inputDir = inputDir; 
 		// 输出图路径 
 		this.outputDir = outputDir; 
 		// 输入图文件名 
 		this.inputFileName = inputFileName; 
 		// 输出图文件名
 		this.outputFileName = outputFileName; 
 		return compressPic(); 
 	} 
 	public String compressPic(String inputDir, String outputDir, String inputFileName, String outputFileName, int width, int height, boolean gp) { 
 		// 输入图路径 
 		this.inputDir = inputDir; 
 		// 输出图路径 
 		this.outputDir = outputDir; 
 		// 输入图文件名 
 		this.inputFileName = inputFileName; 
 		// 输出图文件名 
 		this.outputFileName = outputFileName; 
 		// 设置图片长宽
 		setWidthAndHeight(width, height); 
 		// 是否是等比缩放 标记 
 		this.proportion = gp; 
 		return compressPic(); 
 	} 
 	
 	// main测试 
 	// compressPic(大图片路径,生成小图片路径,大图片文件名,生成小图片文名,生成小图片宽度,生成小图片高度,是否等比缩放(默认为true))
 	public static void main(String[] arg) { 
 		CompressPicDemo mypic = new CompressPicDemo(); 
 		System.out.println("输入的图片大小:" + mypic.getPicSize("e:\\1.jpg")/1024 + "KB"); 
 		int count = 0; // 记录全部图片压缩所用时间
 		for (int i = 0; i < 100; i++) { 
 			int start = (int) System.currentTimeMillis();	// 开始时间 
 			mypic.compressPic("e:\\", "e:\\test\\", "1.jpg", "r1"+i+".jpg", 120, 120, true); 
 			int end = (int) System.currentTimeMillis(); // 结束时间 
 			int re = end-start; // 但图片生成处理时间 
 			count += re; System.out.println("第" + (i+1) + "张图片压缩处理使用了: " + re + "毫秒"); 
 			System.out.println("输出的图片大小:" + mypic.getPicSize("e:\\test\\r1"+i+".jpg")/1024 + "KB"); 
 		}
 		System.out.println("总共用了:" + count + "毫秒"); 
 	} 
 }

分享到:
评论

相关推荐

    图片上传压缩处理源码

    根据给定文件的信息,本文将深入探讨“图片上传压缩处理”的相关知识点,包括该功能的重要性、实现原理以及具体的代码分析。 ### 图片上传压缩处理的重要性 在互联网应用中,图片是用户界面的重要组成部分之一。...

    移动端 Vue+Vant 的Uploader 实现上传、压缩、旋转图片功能

    该功能主要针对移动端用户,提供了便捷的图片上传、压缩及旋转处理。以下是一些相关知识点: 1. Vue.js框架:Vue是一套用于构建用户界面的渐进式JavaScript框架,主要用于开发单页面应用程序(SPA)。它允许开发者...

    单张图片上传压缩

    本文将深入探讨“单张图片上传压缩”的相关知识点。 1. **图片格式与压缩原理** - 常见的图片格式有JPEG、PNG、GIF等,其中JPEG适用于照片类图像,因为它支持有损压缩,能显著减小文件大小。PNG则适合图标、设计稿...

    Element 图片上传封装图片质量压缩上传

    这样,在图片上传之前,会先进行压缩处理,确保图片尺寸和质量符合我们的设定。 以下是一个简化的示例代码: ```javascript ref="upload" :action="uploadUrl" :before-upload="beforeUpload" :on-success=...

    移动端图片上传压缩

    本文将深入探讨移动端图片上传压缩的相关知识点,包括压缩技术的选择、压缩策略、性能优化以及兼容性问题。 首先,我们需要了解图片的格式,常见的有JPEG、PNG、WebP等。JPEG适用于照片类图片,支持有损压缩,能...

    asp拍照,上传压缩处理图片

    通过以上技术手段,可以在ASP环境中构建一个功能完善的图片上传系统,既支持用户从本地选择图片,也能直接拍照上传,并对图片进行压缩处理,提高网站效率。同时,确保系统安全性和用户体验是设计过程中不可忽视的...

    H5 上传图片 拍照 压缩图片

    4. **图片压缩**:为了减少上传的大小和提高上传速度,通常需要对图片进行压缩。可以使用Canvas API的`toDataURL()`方法将图片绘制到Canvas上,然后调整Canvas的宽度和高度来实现等比例缩放,再导出为新的DataURL,...

    前端图片上传压缩

    标题中的“前端图片上传压缩”指的就是在客户端(用户浏览器)对图片进行压缩处理,减少图片的大小,然后将其上传到服务器。这种技术通常用于优化用户体验,提高上传效率,并减轻服务器的压力。 描述中虽然没有提供...

    图片上传及压缩类

    在Android开发中,图片处理是一项常见的任务,包括图片的上传和压缩...总之,图片上传和压缩是Android应用开发中的基础功能,涉及到图片处理、网络通信等多个方面,需要结合具体业务需求和用户体验进行合理设计和实现。

    微信小程序中上传图片并进行压缩的实现代码

    我们还可以通过调整`***pressImage`方法中的参数对图片进行压缩处理,例如设置图片的目标宽度、高度以及压缩质量等。 通过上述方法,我们可以在微信小程序中实现上传图片并进行压缩的功能。需要注意的是,由于微信...

    kindeditor上传图片自动压缩过大的图片

    它提供了丰富的API和自定义选项,包括图片上传功能。在某些场景下,为了优化网站性能和减少服务器存储空间,我们可能需要限制用户上传的图片大小,或者在上传过程中自动对过大的图片进行压缩。标题和描述提到的问题...

    ios图片上传服务器前的压缩处理

    因此,在图片上传至服务器之前进行压缩处理是必要的。 **图片压缩的基本原理** 图片压缩主要分为有损压缩和无损压缩两种。有损压缩如JPEG,会丢失部分图像信息,但能大幅度减小文件大小;无损压缩如PNG,保留所有...

    图片上传组件(自带图片压缩)

    总结来说,这个“图片上传组件(自带图片压缩)”是一个集成了前端交互、后端处理和数据库操作的完整解决方案,它利用了jQuery的便捷性、Spring的灵活性、Struts2的控制能力以及iBatis的数据持久化功能,实现了高效、...

    移动端H5图片压缩上传

    在上述代码中,我们创建了一个FormData对象,并将压缩后的Blob添加到其中,然后通过fetch API发送POST请求到服务器的图片上传接口。 除了基本的图片压缩上传,"移动端图片上传,支持图片裁切"这一描述可能意味着还...

    图片上传 图片压缩 上传压缩 HTML+JS

    这个项目标题和描述中的"图片上传 图片压缩 上传压缩 HTML+JS"表明我们将探讨如何利用HTML和JavaScript实现这个功能。下面将详细阐述这一过程。 首先,我们从HTML部分开始。在HTML中,我们需要创建一个表单让用户...

    完美php图片上传压缩程序

    本文将详细讨论“完美PHP图片上传压缩程序”的核心知识点,包括PHP图片处理、图片上传和等比缩放。 首先,PHP提供了GD库和Imagick库等内置工具,用于处理和操作图像。GD库是最基础的图像处理库,支持JPEG、PNG、GIF...

    批量图片压缩处理工具

    批量图片压缩处理工具就是专门针对这种情况设计的,它能帮助用户一次性处理大量图片,提高工作效率。下面我们将详细探讨批量图片压缩处理工具的工作原理、常见方法以及其在实际应用中的重要性。 批量图片压缩处理...

    压缩图片上传服务器工具

    2. **本地压缩**:工具先对图片进行压缩处理,减少上传的原始数据量。 3. **断点续传**:支持大文件分块上传,如果网络中断,可以从上次中断的位置继续上传,提高上传稳定性。 4. **进度显示**:提供上传进度条,让...

    java 图片压缩 iphone拍照上传旋转问题处理压缩工具类

    在Java开发中,处理图像尤其是来自...以上就是使用Java处理iPhone拍照上传时的图片旋转和压缩问题的方法。在实际应用中,可能还需要考虑其他因素,如图片尺寸调整、色彩管理等,但这个工具类已经能解决大部分基本需求。

    vue图片上传压缩

    在移动Web蓬勃发展的今天,有太多太多的应用需要让用户在移动Web上传图片文件了,正因如此,我们有些困难必须去攻克: 低网速下上传进度缓慢,用户体验差 高并发下,后台处理较大的上传文件压力大 或许有更多...

Global site tag (gtag.js) - Google Analytics