`
qingqinguo
  • 浏览: 3819 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

图片缩放功能

    博客分类:
  • j2se
阅读更多
   
    别人上传过来一个图片,要求显示的时候进行处理,都以规定大小显示。而且文件大小也要跟着改变。下面是我在网上找的一个例子:

/**
 *  缩略图实现,将图片(jpg、bmp、png、gif等等)真实的变成想要的大小 
 * 
 *  2010-11-16
 */
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 < 10; i++) {
			int start = (int) System.currentTimeMillis(); // 开始时间   
			mypic.compressPic("e:\\", "e:\\test\\", "1.jpg", "r1" + i + ".jpg", 800, 600, 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 + "毫秒");
	}
}



分享到:
评论

相关推荐

    js仿QQ实现图片缩放功能

    在JavaScript编程领域,实现类似QQ的图片缩放功能是一项常见的需求,这主要涉及到网页的交互体验和图片处理技术。本文将详细讲解如何使用JavaScript来创建一个具有双击放大、滚轮缩放功能的图片查看器。 首先,我们...

    Android实现图片缩放功能

    总的来说,实现Android的图片缩放功能涉及到对Bitmap对象的操作、手势识别以及性能优化等多个方面。通过理解这些知识点,开发者可以构建出具有流畅手势交互的图片查看应用。在实际开发中,还需要根据具体需求进行...

    图片缩放功能的一个Demo

    本示例,"图片缩放功能的一个Demo",旨在提供一个简单的图片缩放解决方案。这个Demo可能是一个基于UIScrollView的实现,因为文件名列表中提到了"UIScrollviewShuoFang",这通常意味着在iOS开发中,我们利用...

    js图片缩放功能

    在JavaScript中实现图片缩放功能是一项常见的需求,特别是在网页开发中。这主要涉及到HTML5的Canvas元素、CSS3的transform属性以及JavaScript的DOM操作。以下将详细解释如何使用这些技术来实现图片缩放。 首先,...

    servlet文件上传(含图片缩放功能)

    "servlet文件上传(含图片缩放功能)"的示例是利用Servlet实现用户上传图片,并且具备根据用户需求对上传图片进行缩放的功能。这个功能在很多网站如社交媒体、博客平台等非常常见,以便用户能够优化他们的图片大小,...

    兼容IE,firefox,chrome图片缩放功能

    总的来说,实现跨浏览器的图片缩放功能,我们需要结合CSS的`max-width`、`max-height`、`object-fit`属性,以及JavaScript/jQuery的动态调整,甚至使用特定的图片处理工具。通过这些方法,我们可以确保图片在IE、...

    C# 图片缩放功能

    在C#编程环境中,WPF...通过这种方式,你可以在WPF应用中实现基于滚轮的图片缩放功能,提供用户友好的图像查看体验。这种功能在各种图像处理、设计工具或数据分析应用中都十分常见,是提升用户体验的重要一环。

    图片处理类,包括图片缩放功能,验证码生成功能。

    **图片缩放功能** 图片缩放是图片处理中的基本操作,它允许我们根据需求调整图像的大小。在编程中,这通常通过使用特定的算法来实现,如最近邻插值、双线性插值或更高级的插值方法如三次卷积插值。这些方法会根据...

    帖内图片缩放功能 for phpwind.rar

    《phpwind论坛帖内图片缩放功能详解及应用》 在互联网社区中,phpWind(简称PHPWIND)是一款广泛使用的开源社区建站系统,它以其高效、稳定、易用的特点深受众多网站管理员的喜爱。然而,在用户交互的过程中,论坛...

    flex图片浏览(带图片缩放功能)

    对于"flex图片浏览(带图片缩放功能)"这个应用,我们需要使用Flex中的Image组件来显示图片。Image组件能够加载和显示各种图像格式,包括JPEG、PNG、GIF等。以下是一个简单的例子: ```mxml ('path/to/your/image.jpg...

    Silverlight 源码 图片缩放实例

    图片缩放功能在用户体验设计中至关重要,因为它允许用户以更直观的方式查看和操作图像。 首先,我们要理解Silverlight中的基本元素,如UIElement和Visual,它们是构建界面的基础。UIElement提供了事件处理和布局...

    Android ImageView图片缩放功能

    现在app中,图片预览功能肯定是少不了的,用户基本已经形成条件反射,看到小图,点击看大图,看到大图两个手指开始进行放大,放大后,开始移动到指定部位想要做到图片支持多点触控,自由的进行缩放、平移 以及事件...

    图片缩放JS插件

    在网页开发中,图片缩放功能常常被用于增强用户体验,特别是在展示细节丰富的图像或产品图片时。"图片缩放JS插件"就是一种专门解决这个问题的工具,它允许用户通过手势来放大和缩小图片,提供了更为直观和互动的查看...

    android imageview 图片缩放

    本文将深入探讨如何在Android中实现ImageView的图片缩放功能,同时结合异步加载和Activity的半透明效果,提升用户体验。 首先,我们要理解Android中ImageView的基本用法。ImageView可以设置为固定大小或根据图片...

    图片缩放旋转 图片缩放 图片旋转 完整程序 源代码 cb c++

    在C++中,可以使用OpenCV库等图像处理库来实现图片缩放功能,它们提供了相应的API接口供开发者调用。 其次,“图片旋转”是指将图像绕某个点进行旋转,这个点通常为图像的中心。旋转操作同样需要考虑图像质量的保持...

    实现Jpeg图片转化为BMP图片,以及BMP图片缩放功能(C++代码)

    本文将详细介绍如何使用C++语言实现JPEG图片向BMP图片的转换,以及BMP图片的缩放功能。 首先,让我们理解JPEG和BMP这两种图片格式。JPEG(Joint Photographic Experts Group)是一种有损压缩格式,主要用于照片或...

    MFC_图片缩放

    总的来说,"MFC_图片缩放"项目展示了如何在MFC环境中利用CImage类加载和处理图片,以及如何通过双缓冲技术和滚轮事件实现平滑的图片缩放功能。这不仅对理解MFC框架有帮助,也为开发类似的应用程序提供了实践参考。

    关于图片缩放的若干问题的解决

    此外,选择合适的库和算法也是优化的关键,例如OpenCV、PIL(Python Imaging Library)等图像处理库提供了高效的图片缩放功能。 6. **适应不同设备和平台**:在网页设计或移动应用开发中,图片通常需要根据不同的...

    图片缩放的View

    通过以上步骤,我们可以利用`ScaleGestureDetector`实现一个基本的图片缩放功能。在`ImageScaleDemo`这个示例项目中,开发者可能已经给出了完整的代码实现,供我们参考和学习。分析这个项目的源代码,我们可以深入...

    图片浏览、缩放 uo_image for PB_pb_pb图片缩放_

    在描述中提到“pb图片缩放 功能一般 没什么用出pb图片缩放”,这可能意味着开发者或者用户认为该组件或库提供的图片缩放功能在实际应用中表现平平,没有特别突出的优点或特色,可能无法满足某些高级或特定需求。...

Global site tag (gtag.js) - Google Analytics