`
肖秀梅
  • 浏览: 4740 次
  • 性别: Icon_minigender_2
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

上传图片(等比缩放的效果)

阅读更多
package com.sanqing.upload;

/**
* @author zhanjianwen
* @time 2011-5-30
* @version 1.0
*/
/** 
*  缩略图实现,将图片(jpg、bmp、png、gif等等)真实的变成想要的大小 
*/

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 CompressPic {
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 CompressPic() { // 初始化变量
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); //4516毫秒 效果好
//tag.getGraphics().drawImage(img.getScaledInstance(newWidth, newHeight,Image.SCALE_FAST), 0, 0, null);//2718毫秒 效果很差
//tag.getGraphics().drawImage(img.getScaledInstance(newWidth, newHeight,Image.SCALE_AREA_AVERAGING), 0, 0, null); //4515毫秒 效果好
//tag.getGraphics().drawImage(img.getScaledInstance(newWidth, newHeight,Image.SCALE_DEFAULT), 0, 0, null); //2719毫秒 效果差
//tag.getGraphics().drawImage(img.getScaledInstance(newWidth, newHeight,Image.SCALE_REPLICATE), 0, 0, null); // 2750毫秒 效果差
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) {
CompressPic mypic = new CompressPic();
System.out.println("输入的图片大小:" + mypic.getPicSize("d:\\4.bmp") / 1024 + "KB");
int count = 0; // 记录全部图片压缩所用时间
for (int i = 0; i < 100; i++) {
int start = (int) System.currentTimeMillis(); // 开始时间
mypic.compressPic("d:\\", "d:\\test\\", "4.bmp", "r1" + i + ".JPG",160, 100, true);
int end = (int) System.currentTimeMillis(); // 结束时间
int re = end - start; // 但图片生成处理时间
count += re;
System.out.println("第" + (i + 1) + "张图片压缩处理使用了: " + re + "毫秒");
System.out.println("输出的图片大小:" + mypic.getPicSize("d:\\test\\r1" + i + ".JPG") / 1024 + "KB");
}
System.out.println("总共用了:" + count + "毫秒");
}
}
分享到:
评论

相关推荐

    JavaScript等比例缩放图片控制超出范围的图片

    特别是在用户上传图片或者动态加载内容时,图片大小不受控制,可能会导致页面布局混乱。这时,JavaScript 的图片等比例缩放功能就显得尤为重要。本文将详细解析如何使用 JavaScript 实现等比例缩放图片,以控制其...

    免费图片批量等比缩小压缩处理工具 图片批量压缩 SEO老司机

    这款工具的主要功能是进行图片的批量等比缩小和压缩,以提高图片上传速度,减少存储空间占用,并优化网站的SEO性能。 等比缩小是指在调整图片尺寸时,保持原图的宽高比例,避免因为非等比例缩放导致图片变形。这...

    jQuery图片割选择

    该插件支持非等比例缩放、拖动选择、实时预览等功能,非常适合用户自定义上传图片的需求。 **图片割选程序实现步骤** 1. **引入资源**: 首先,你需要在HTML文件(如index.htm)中引入jQuery库和imgareaselect插件...

    c#图片等比例缩放.

    ### C# 图片等比例缩放技术解析 在现代Web应用开发中,图像处理是一项非常重要的功能,尤其是在处理大量图片的场景下。合理的图片处理不仅可以优化用户体验,还能显著提升网站性能。本文将深入探讨如何使用C#实现...

    PHP实现图片的等比例缩放1

    5. **执行等比缩放**:创建一个新的图像源 `$nim` 用 `imagecreatetruecolor()` 函数,然后使用 `imagecopyresampled()` 进行等比例缩放。例如: ```php $nim = imagecreatetruecolor($nw, $nh); ...

    上传图片时按比例压缩

    版本6.3.9-0虽然较旧,但仍能完成许多基本和高级的图像操作,包括缩放、裁剪、旋转、合成、颜色调整以及我们关注的图片压缩。 图片压缩的目标是在不影响视觉效果的情况下减小文件大小。ImageMagick通过几种不同的...

    压缩调整图片尺寸的PHP类.zip

    3. 等比缩放:类的核心功能可能是实现等比缩放。在调整图片尺寸时,保持长宽比是非常重要的,以免破坏图片的视觉效果。这通常涉及到计算新的宽度和高度,使得缩放后的图片保持原有的宽高比。 4. 图片质量调整:除了...

    网页图片处理代码全集整理

    这些代码主要涵盖以下几个方面:图片尺寸调整、等比缩放、图片加载优化、IE6下的图片处理问题解决、去除图片工具栏、防止图片链接被盗用以及图片大小验证等方面。 ### 一、图片尺寸调整与等比缩放 #### 代码示例:...

    WP Smush Pro v3.7 WordPress 图片上传压缩插件

    WP Smush插件,我想很多wp站长应该知道的吧,这款插件可以一键压缩站点上所有的图片,可以上传图片时压缩图片,能够无损压缩并且压缩率很高,也可以设置最大宽高,超过时等比缩放图片 WP Smush Pro插件也有免费版本...

    php生成缩略图填充白边(等比缩略图方案)

    通常,直接按照固定尺寸缩放图片会导致长宽比例失衡,从而影响显示效果。为了解决这个问题,我们可以采用“等比缩略图”方案,即在缩放后为图片添加填充色(如白色)来确保图片的原始比例。以下是对这一方法的详细...

    PHP图片处理类 phpThumb参数用法介绍

    当只设置其中一个时,phpThumb会按照指定的尺寸等比缩放图片。如果同时指定了w和h,图片将被拉伸或压缩到设定的尺寸,可能会导致图片比例失真。 q参数:此参数用于设置JPEG格式图片的输出质量。取值范围通常为0到...

Global site tag (gtag.js) - Google Analytics