过去做的项目都是针对企业级应用,第一次开发新闻版块图片上传的功能,需要解决用户上传图片后,按照用户规定的尺寸大小或者按照图片比例,对图片进行压缩。
自己试写的工具类,写的时候考虑了几个关键点:
1、图片格式
JAVA的API很好,com.sun.image.codec.jpeg.JPEGCodec和com.sun.image.codec.jpeg.JPEGImageEncoder 这两个类基本上自动解决了类型转换的问题,可以正常实现bmp转jpg、png转jpg、gif转jpg,但是暂时还没有解决gif转gif的功能。
2、画面质量的问题
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);
3、压缩速度
测试36MB的bmp图片(8192*6144)压缩成(160*120)的jpg的5KB图片,只需要2-3秒的时间。批量处理100张(1027*768)的bmp图像,转换成(120*80)的jpg图片总共只需要17秒。
4、根据用户喜好选择压缩模式
按比例或者按规定尺寸
//compressPic(大图片路径,生成小图片路径,大图片文件名,生成小图片文名,生成小图片宽度,生成小图片高度,是否等比缩放(默认为true))
以下是源码,如觉得可以更加完善的话,希望大家可以提供点意见!!
/**
* 缩略图实现,将图片(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 + "毫秒");
}
}
分享到:
- 2008-11-13 14:24
- 浏览 2969
- 评论(1)
- 论坛回复 / 浏览 (0 / 49995)
- 查看更多
相关推荐
根据给定文件的信息,本文将深入探讨“图片上传压缩处理”的相关知识点,包括该功能的重要性、实现原理以及具体的代码分析。 ### 图片上传压缩处理的重要性 在互联网应用中,图片是用户界面的重要组成部分之一。...
该功能主要针对移动端用户,提供了便捷的图片上传、压缩及旋转处理。以下是一些相关知识点: 1. Vue.js框架:Vue是一套用于构建用户界面的渐进式JavaScript框架,主要用于开发单页面应用程序(SPA)。它允许开发者...
本文将深入探讨“单张图片上传压缩”的相关知识点。 1. **图片格式与压缩原理** - 常见的图片格式有JPEG、PNG、GIF等,其中JPEG适用于照片类图像,因为它支持有损压缩,能显著减小文件大小。PNG则适合图标、设计稿...
这样,在图片上传之前,会先进行压缩处理,确保图片尺寸和质量符合我们的设定。 以下是一个简化的示例代码: ```javascript ref="upload" :action="uploadUrl" :before-upload="beforeUpload" :on-success=...
本文将深入探讨移动端图片上传压缩的相关知识点,包括压缩技术的选择、压缩策略、性能优化以及兼容性问题。 首先,我们需要了解图片的格式,常见的有JPEG、PNG、WebP等。JPEG适用于照片类图片,支持有损压缩,能...
通过以上技术手段,可以在ASP环境中构建一个功能完善的图片上传系统,既支持用户从本地选择图片,也能直接拍照上传,并对图片进行压缩处理,提高网站效率。同时,确保系统安全性和用户体验是设计过程中不可忽视的...
4. **图片压缩**:为了减少上传的大小和提高上传速度,通常需要对图片进行压缩。可以使用Canvas API的`toDataURL()`方法将图片绘制到Canvas上,然后调整Canvas的宽度和高度来实现等比例缩放,再导出为新的DataURL,...
标题中的“前端图片上传压缩”指的就是在客户端(用户浏览器)对图片进行压缩处理,减少图片的大小,然后将其上传到服务器。这种技术通常用于优化用户体验,提高上传效率,并减轻服务器的压力。 描述中虽然没有提供...
在Android开发中,图片处理是一项常见的任务,包括图片的上传和压缩...总之,图片上传和压缩是Android应用开发中的基础功能,涉及到图片处理、网络通信等多个方面,需要结合具体业务需求和用户体验进行合理设计和实现。
我们还可以通过调整`***pressImage`方法中的参数对图片进行压缩处理,例如设置图片的目标宽度、高度以及压缩质量等。 通过上述方法,我们可以在微信小程序中实现上传图片并进行压缩的功能。需要注意的是,由于微信...
它提供了丰富的API和自定义选项,包括图片上传功能。在某些场景下,为了优化网站性能和减少服务器存储空间,我们可能需要限制用户上传的图片大小,或者在上传过程中自动对过大的图片进行压缩。标题和描述提到的问题...
因此,在图片上传至服务器之前进行压缩处理是必要的。 **图片压缩的基本原理** 图片压缩主要分为有损压缩和无损压缩两种。有损压缩如JPEG,会丢失部分图像信息,但能大幅度减小文件大小;无损压缩如PNG,保留所有...
总结来说,这个“图片上传组件(自带图片压缩)”是一个集成了前端交互、后端处理和数据库操作的完整解决方案,它利用了jQuery的便捷性、Spring的灵活性、Struts2的控制能力以及iBatis的数据持久化功能,实现了高效、...
在上述代码中,我们创建了一个FormData对象,并将压缩后的Blob添加到其中,然后通过fetch API发送POST请求到服务器的图片上传接口。 除了基本的图片压缩上传,"移动端图片上传,支持图片裁切"这一描述可能意味着还...
这个项目标题和描述中的"图片上传 图片压缩 上传压缩 HTML+JS"表明我们将探讨如何利用HTML和JavaScript实现这个功能。下面将详细阐述这一过程。 首先,我们从HTML部分开始。在HTML中,我们需要创建一个表单让用户...
本文将详细讨论“完美PHP图片上传压缩程序”的核心知识点,包括PHP图片处理、图片上传和等比缩放。 首先,PHP提供了GD库和Imagick库等内置工具,用于处理和操作图像。GD库是最基础的图像处理库,支持JPEG、PNG、GIF...
批量图片压缩处理工具就是专门针对这种情况设计的,它能帮助用户一次性处理大量图片,提高工作效率。下面我们将详细探讨批量图片压缩处理工具的工作原理、常见方法以及其在实际应用中的重要性。 批量图片压缩处理...
2. **本地压缩**:工具先对图片进行压缩处理,减少上传的原始数据量。 3. **断点续传**:支持大文件分块上传,如果网络中断,可以从上次中断的位置继续上传,提高上传稳定性。 4. **进度显示**:提供上传进度条,让...
在Java开发中,处理图像尤其是来自...以上就是使用Java处理iPhone拍照上传时的图片旋转和压缩问题的方法。在实际应用中,可能还需要考虑其他因素,如图片尺寸调整、色彩管理等,但这个工具类已经能解决大部分基本需求。
在移动Web蓬勃发展的今天,有太多太多的应用需要让用户在移动Web上传图片文件了,正因如此,我们有些困难必须去攻克: 低网速下上传进度缓慢,用户体验差 高并发下,后台处理较大的上传文件压力大 或许有更多...