- 浏览: 304551 次
- 性别:
- 来自: 南京
最新评论
-
memorymyann:
不好意思我看错了
Java计算时间差 -
memorymyann:
好吧,网上很多方法一的,我不知道大家有验证过没有。我测试了下。 ...
Java计算时间差 -
ndzj981479673:
TonyLian 写道下这个包到WEB-INF/libs sp ...
org.springframework.web.servlet.DispatcherServlet -
Heart-wu:
com.jacob.com.ComFailException: ...
Jacob使用小结 -
wo4562658:
没有附件?getAnyCellStyle 这个方法,getHd ...
POI使用小结
关键字: 缩放图像、图像切割、图像类型转换、彩色转为黑白
Java代码
package img;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.Toolkit;
import java.awt.color.ColorSpace;
import java.awt.image.BufferedImage;
import java.awt.image.ColorConvertOp;
import java.awt.image.CropImageFilter;
import java.awt.image.FilteredImageSource;
import java.awt.image.ImageFilter;
import java.awt.image.ImageProducer;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
public class TestSplit {
/**
* 缩放图像
*
* @param srcImageFile
* 源图像文件地址
* @param result
* 缩放后的图像地址
* @param scale
* 缩放比例
* @param flag
* 缩放选择:true 放大; false 缩小;
*/
public static void scale(String srcImageFile, String result, int scale,
boolean flag) {
try {
BufferedImage src = ImageIO.read(new File(srcImageFile)); // 读入文件
int width = src.getWidth(); // 得到源图宽
int height = src.getHeight(); // 得到源图长
if (flag) {
// 放大
width = width * scale;
height = height * scale;
} else {
// 缩小
width = width / scale;
height = height / scale;
}
Image image = src.getScaledInstance(width, height,
Image.SCALE_DEFAULT);
BufferedImage tag = new BufferedImage(width, height,
BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(image, 0, 0, null); // 绘制缩小后的图
g.dispose();
ImageIO.write(tag, "JPEG", new File(result));// 输出到文件流
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* 图像切割
*
* @param srcImageFile
* 源图像地址
* @param descDir
* 切片目标文件夹
* @param destWidth
* 目标切片宽度
* @param destHeight
* 目标切片高度
*/
public static void cut(String srcImageFile, final String descDir, final int destWidth,
final int destHeight) {
try {
// 读取源图像
BufferedImage bi = ImageIO.read(new File(srcImageFile));
final int srcWidth = bi.getHeight(); // 源图宽度
final int srcHeight = bi.getWidth(); // 源图高度
//如果源图片的宽度和长度都小于目标图片,不用处理。
if (srcWidth <= destWidth && srcHeight <= destHeight) return;
// 计算切片的横向和纵向数量
int temp = srcWidth / destWidth;
int cols = srcWidth % destWidth == 0 ? temp : temp+1; // 切片横向数量
temp = srcHeight / destHeight;
int rows = srcHeight % destHeight == 0 ? temp : temp+1 ; //切片纵向数量
// 循环建立切片
// 改进的想法:是否可用多线程加快切割速度
final Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
long bg = System.currentTimeMillis();
// 四个参数分别为图像起点坐标和宽高
// 即: CropImageFilter(int x,int y,int width,int height)
ImageFilter cropFilter = new CropImageFilter(j * destWidth, i * destHeight, Math.min(destWidth,srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight));
ImageProducer imgProducer = image.getSource();
Image img = Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(imgProducer, cropFilter));
BufferedImage tag = new BufferedImage(Math.min(destWidth, srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight), BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(img, 0, 0, null); // 绘制小图
g.dispose();
// 输出为文件
String small_pic_name_path = descDir+"map_" + i + "_" + j + ".jpg";
ImageIO.write(tag, "JPEG", new File(small_pic_name_path));
System.out.println("Thread"+Thread.currentThread().getId()+"\t切割第\t"+i+"_"+j+"\t张图片,耗时:\t"+(System.currentTimeMillis()-bg)+" 毫秒");
}
}
}catch (Exception e) {
e.printStackTrace();
}
}
/**
* 图像类型转换
* GIF->JPG GIF->PNG PNG->JPG PNG->GIF(X)
*/
public static void convert(String source, String result) {
try {
File f = new File(source);
f.canRead();
f.canWrite();
BufferedImage src = ImageIO.read(f);
ImageIO.write(src, "JPG", new File(result));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
* 彩色转为黑白
*
* @param source
* @param result
*/
public static void gray(String source, String result) {
try {
BufferedImage src = ImageIO.read(new File(source));
ColorSpace cs = ColorSpace.getInstance(ColorSpace.CS_GRAY);
ColorConvertOp op = new ColorConvertOp(cs, null);
src = op.filter(src, null);
ImageIO.write(src, "JPEG", new File(result));
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* @param args
* 3X2 4X3 4X4 5X4
*/
public static void main(String[] args) {
// if(1==1){
// return;
// }
//cut("ss.jpg", "./ss/", 256, 256);
PictureCutter.cut("54.jpg", "./ss/", 256, 256);
// Properties p= System.getProperties();
// System.out.println(p);
}
public static void cut1(String srcImageFile, final String descDir, final int destWidth,
final int destHeight) {
try {
// 读取源图像
BufferedImage bi = ImageIO.read(new File(srcImageFile));
final int srcWidth = bi.getHeight(); // 源图宽度
final int srcHeight = bi.getWidth(); // 源图高度
//如果源图片的宽度和长度都小于目标图片,不用处理。
if (srcWidth <= destWidth && srcHeight <= destHeight) return;
// 计算切片的横向和纵向数量
int temp = srcWidth / destWidth;
int cols = srcWidth % destWidth == 0 ? temp : temp+1; // 切片横向数量
temp = srcHeight / destHeight;
int rows = srcHeight % destHeight == 0 ? temp : temp+1 ; //切片纵向数量
// 循环建立切片
// 改进的想法:是否可用多线程加快切割速度
final Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
long bg = System.currentTimeMillis();
// 四个参数分别为图像起点坐标和宽高
// 即: CropImageFilter(int x,int y,int width,int height)
ImageFilter cropFilter = new CropImageFilter(j * destWidth, i * destHeight, Math.min(destWidth,srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight));
ImageProducer imgProducer = image.getSource();
Image img = Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(imgProducer, cropFilter));
BufferedImage tag = new BufferedImage(Math.min(destWidth, srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight), BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(img, 0, 0, null); // 绘制小图
g.dispose();
// 输出为文件
String small_pic_name_path = descDir+"map_" + i + "_" + j + ".jpg";
ImageIO.write(tag, "JPEG", new File(small_pic_name_path));
System.out.println("Thread"+Thread.currentThread().getId()+"\t切割第\t"+i+"_"+j+"\t张图片,耗时:\t"+(System.currentTimeMillis()-bg)+" 毫秒");
}
}
}catch (Exception e) {
e.printStackTrace();
}
}
public static void perform(){
PictureCutter.cut("ss.jpg", "./ss/", 256, 256);
long begin = System.currentTimeMillis();
cut("1.jpg", "./s2/", 128, 128);
long mid = System.currentTimeMillis();
PictureCutter.cut("1.jpg", "./s1/", 128, 128);
long end = System.currentTimeMillis();
System.out.println(mid-begin);
System.out.println(end-mid);
}
}
Java代码
package img;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.Toolkit;
import java.awt.color.ColorSpace;
import java.awt.image.BufferedImage;
import java.awt.image.ColorConvertOp;
import java.awt.image.CropImageFilter;
import java.awt.image.FilteredImageSource;
import java.awt.image.ImageFilter;
import java.awt.image.ImageProducer;
import java.io.File;
import java.io.IOException;
import javax.imageio.ImageIO;
public class TestSplit {
/**
* 缩放图像
*
* @param srcImageFile
* 源图像文件地址
* @param result
* 缩放后的图像地址
* @param scale
* 缩放比例
* @param flag
* 缩放选择:true 放大; false 缩小;
*/
public static void scale(String srcImageFile, String result, int scale,
boolean flag) {
try {
BufferedImage src = ImageIO.read(new File(srcImageFile)); // 读入文件
int width = src.getWidth(); // 得到源图宽
int height = src.getHeight(); // 得到源图长
if (flag) {
// 放大
width = width * scale;
height = height * scale;
} else {
// 缩小
width = width / scale;
height = height / scale;
}
Image image = src.getScaledInstance(width, height,
Image.SCALE_DEFAULT);
BufferedImage tag = new BufferedImage(width, height,
BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(image, 0, 0, null); // 绘制缩小后的图
g.dispose();
ImageIO.write(tag, "JPEG", new File(result));// 输出到文件流
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* 图像切割
*
* @param srcImageFile
* 源图像地址
* @param descDir
* 切片目标文件夹
* @param destWidth
* 目标切片宽度
* @param destHeight
* 目标切片高度
*/
public static void cut(String srcImageFile, final String descDir, final int destWidth,
final int destHeight) {
try {
// 读取源图像
BufferedImage bi = ImageIO.read(new File(srcImageFile));
final int srcWidth = bi.getHeight(); // 源图宽度
final int srcHeight = bi.getWidth(); // 源图高度
//如果源图片的宽度和长度都小于目标图片,不用处理。
if (srcWidth <= destWidth && srcHeight <= destHeight) return;
// 计算切片的横向和纵向数量
int temp = srcWidth / destWidth;
int cols = srcWidth % destWidth == 0 ? temp : temp+1; // 切片横向数量
temp = srcHeight / destHeight;
int rows = srcHeight % destHeight == 0 ? temp : temp+1 ; //切片纵向数量
// 循环建立切片
// 改进的想法:是否可用多线程加快切割速度
final Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
long bg = System.currentTimeMillis();
// 四个参数分别为图像起点坐标和宽高
// 即: CropImageFilter(int x,int y,int width,int height)
ImageFilter cropFilter = new CropImageFilter(j * destWidth, i * destHeight, Math.min(destWidth,srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight));
ImageProducer imgProducer = image.getSource();
Image img = Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(imgProducer, cropFilter));
BufferedImage tag = new BufferedImage(Math.min(destWidth, srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight), BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(img, 0, 0, null); // 绘制小图
g.dispose();
// 输出为文件
String small_pic_name_path = descDir+"map_" + i + "_" + j + ".jpg";
ImageIO.write(tag, "JPEG", new File(small_pic_name_path));
System.out.println("Thread"+Thread.currentThread().getId()+"\t切割第\t"+i+"_"+j+"\t张图片,耗时:\t"+(System.currentTimeMillis()-bg)+" 毫秒");
}
}
}catch (Exception e) {
e.printStackTrace();
}
}
/**
* 图像类型转换
* GIF->JPG GIF->PNG PNG->JPG PNG->GIF(X)
*/
public static void convert(String source, String result) {
try {
File f = new File(source);
f.canRead();
f.canWrite();
BufferedImage src = ImageIO.read(f);
ImageIO.write(src, "JPG", new File(result));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
/**
* 彩色转为黑白
*
* @param source
* @param result
*/
public static void gray(String source, String result) {
try {
BufferedImage src = ImageIO.read(new File(source));
ColorSpace cs = ColorSpace.getInstance(ColorSpace.CS_GRAY);
ColorConvertOp op = new ColorConvertOp(cs, null);
src = op.filter(src, null);
ImageIO.write(src, "JPEG", new File(result));
} catch (IOException e) {
e.printStackTrace();
}
}
/**
* @param args
* 3X2 4X3 4X4 5X4
*/
public static void main(String[] args) {
// if(1==1){
// return;
// }
//cut("ss.jpg", "./ss/", 256, 256);
PictureCutter.cut("54.jpg", "./ss/", 256, 256);
// Properties p= System.getProperties();
// System.out.println(p);
}
public static void cut1(String srcImageFile, final String descDir, final int destWidth,
final int destHeight) {
try {
// 读取源图像
BufferedImage bi = ImageIO.read(new File(srcImageFile));
final int srcWidth = bi.getHeight(); // 源图宽度
final int srcHeight = bi.getWidth(); // 源图高度
//如果源图片的宽度和长度都小于目标图片,不用处理。
if (srcWidth <= destWidth && srcHeight <= destHeight) return;
// 计算切片的横向和纵向数量
int temp = srcWidth / destWidth;
int cols = srcWidth % destWidth == 0 ? temp : temp+1; // 切片横向数量
temp = srcHeight / destHeight;
int rows = srcHeight % destHeight == 0 ? temp : temp+1 ; //切片纵向数量
// 循环建立切片
// 改进的想法:是否可用多线程加快切割速度
final Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);
for (int i = 0; i < rows; i++) {
for (int j = 0; j < cols; j++) {
long bg = System.currentTimeMillis();
// 四个参数分别为图像起点坐标和宽高
// 即: CropImageFilter(int x,int y,int width,int height)
ImageFilter cropFilter = new CropImageFilter(j * destWidth, i * destHeight, Math.min(destWidth,srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight));
ImageProducer imgProducer = image.getSource();
Image img = Toolkit.getDefaultToolkit().createImage(new FilteredImageSource(imgProducer, cropFilter));
BufferedImage tag = new BufferedImage(Math.min(destWidth, srcWidth - j * destWidth), Math.min(srcHeight - i * destHeight, destHeight), BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(img, 0, 0, null); // 绘制小图
g.dispose();
// 输出为文件
String small_pic_name_path = descDir+"map_" + i + "_" + j + ".jpg";
ImageIO.write(tag, "JPEG", new File(small_pic_name_path));
System.out.println("Thread"+Thread.currentThread().getId()+"\t切割第\t"+i+"_"+j+"\t张图片,耗时:\t"+(System.currentTimeMillis()-bg)+" 毫秒");
}
}
}catch (Exception e) {
e.printStackTrace();
}
}
public static void perform(){
PictureCutter.cut("ss.jpg", "./ss/", 256, 256);
long begin = System.currentTimeMillis();
cut("1.jpg", "./s2/", 128, 128);
long mid = System.currentTimeMillis();
PictureCutter.cut("1.jpg", "./s1/", 128, 128);
long end = System.currentTimeMillis();
System.out.println(mid-begin);
System.out.println(end-mid);
}
}
发表评论
-
synchronized(this)的一些理解
2011-12-06 18:58 1013对synchronized(this)的 ... -
Comparator和Comparable在排序中的应用
2011-07-30 11:21 899当需要排序的集合或数组不是单纯的数字型时,通常可以使用Co ... -
如何将文件中Base64进制数据生成X509证书
2010-12-16 19:50 2765byte[] ciphertext1 = new BASE64 ... -
Java相关数字签名技术纪要
2010-12-16 18:59 1210一:需要包含的包 ... -
jdom通过string生产xml文档
2010-12-09 10:50 1079生产xml文档: XMLOutputter outpu ... -
Tomcat支持Https访问
2010-11-10 20:01 3191用Tomcat来配置SSL主要有下面这么两大步骤: 一、生成证 ... -
一个tomcat配置多个端口
2010-10-19 18:43 3076第一步、修改server.xml[..\Tomcat 6.0\ ... -
Servlet上传文件及发送HTTP请求至Servet上传文件。
2010-08-12 18:30 1658Servlet接受HTTP消息,解析内容并输出至文件中 // ... -
如何在工程指定目录下保存文件。
2010-08-11 18:59 12041:Servlet中 String fileDir ... -
各进制基本概念。
2010-07-30 12:26 1153二进制: 二进制是逢2进位的进位制,0、 ... -
Junit小结
2010-07-20 08:58 656一 几个常用注释 @Before 被它注释的方法, ... -
JMockit_UT小结
2010-07-15 16:11 11551:模拟方法抛出异常 fin ... -
如何将当前时间延迟至指定的年、月、日后日期。
2010-06-23 19:27 1030Calendar cale = Calenda ... -
tomcat添加gzip功能
2010-03-04 15:24 2018在文件tomcat/conf/server.xml 中添加红 ... -
HttpClient笔记
2010-01-16 20:03 3325背景:因为想写一个测试tomcat连接的程序,就试试自已去构造 ... -
ThreadLocal知识
2009-11-14 21:57 2703首先,ThreadLocal 不是用来解决共享对象的多线程访问 ... -
一个不错的JDBC连接池教程(带具体例子)
2009-06-11 21:17 1255关键字: jdbc 1.前言 数据库应用,在许多软件系统中 ... -
Java计算时间差
2009-06-11 21:10 5839比如:现在是2004-03-26 13:31:40 ... -
Unable to instantiate Action(关于struts2.0异常)
2009-05-17 20:39 7795[ERROR] - [2009-03-12 14:27:59] ... -
怎么实现jdk6运行,而使用jdk5编译
2009-05-12 22:05 1329步骤: 1:eclipse->window->pr ...
相关推荐
在实际项目开发中,图片处理是一项常见的需求,包括但不限于图片的压缩、尺寸调整以及添加水印等操作。传统的Java库虽然能够实现这些功能,但往往在图片质量方面不尽如人意,尤其是当图片尺寸被大幅度压缩时,画质...
Java图像处理类库,如Java Image Filters,是Java平台上的一个重要工具,用于对数字图像进行各种操作和修改。这些类库通常包含了一系列的类和方法,可以实现图像的过滤、调整、裁剪、旋转、合成等多种功能,为开发者...
本项目"用Java实现的图片加密程序"正是关注这一主题,它利用Java的IO流处理技术,实现了对图片文件的加密和解密功能。以下是关于这个项目的一些详细知识点: 1. **Java IO流**:Java的IO流是处理输入输出的基础,它...
在部分内容中,作者提供了一个 Java 程序,展示了如何使用 Java 来处理图片的背景颜色。该程序使用了 BufferedImage 类来读取图片,并使用 getRGB 方法来获取图片的像素信息,然后使用 setRGB 方法来设置图片的背景...
在Windows系统中,批处理文件通常用来自动化执行一系列命令,如编译和运行Java程序。它可能会包含类似`javac`(Java编译器)和`java`(Java虚拟机)的命令,用于将源代码编译成字节码并执行。 其次,`...
标题中的“用java写的图片浏览程序”表明这是一个使用Java编程语言开发的应用程序,主要用于查看和管理图片。在Java中,可以使用Swing或JavaFX库来构建这样的图形用户界面(GUI),这两个库提供了丰富的组件来创建...
在这个“微信小程序java上传图片_servlet”项目中,我们将探讨如何在微信小程序中实现图片上传功能,并通过Java Servlet进行后端处理。 首先,微信小程序提供了wx.chooseImage接口,用户可以通过这个接口选择本地...
【标题】"多图片广告展示java小程序"是一个基于Java编程语言...总之,"多图片广告展示java小程序"是一个综合性的项目,涉及了Java GUI编程、图像处理、数据管理等多个方面,对于学习和实践Java应用开发具有很高的价值。
在IT领域,特别是编程语言的学习与应用中,Java作为一门广泛应用的高级编程语言,其功能强大,能够处理各种复杂的计算任务,包括图像处理。本文将深入解析如何在Java程序中加载并显示一张图片,以此为基础,拓展至更...
在Java编程语言中,将多张图片合成一张图片是一项常见的图像处理任务,广泛应用于各种应用场景,如社交媒体拼图、报告生成、数据可视化等。要实现这个功能,我们需要使用到Java的图像处理库,如Java AWT(Abstract ...
这可能意味着程序使用了Java标准库中的AWT或Swing组件来构建GUI,同时实现了基本的图片处理和播放功能。 7. **IMAGES 文件夹**:这可能是存放待播放图片的目录,包含一系列的图像文件,格式可能是常见的JPEG、PNG或...
在Java编程语言中,对图片进行高级处理包括各种图像操作,如渐变、锐化和边缘检测等。这些技术在图像处理和计算机视觉领域中至关重要,可以用于改善图像质量、识别图像特征或创建视觉效果。以下是对这些概念的详细...
java图像处理程序,可以实现简单的灰度转换、图像均衡的功能。值得学习学习
"图片_java"则意味着程序处理和显示图片的功能是用Java实现的。 在压缩包的文件名称列表中,我们可以看到几个重要的文件: 1. ImageChanger.class:这可能是程序的主要类,负责处理图片的更改或转换。在Java中,....
本资源包包含了使用Java编写的图像处理程序,以及相关的源代码和文档,旨在帮助学习者或开发者深入理解和实践图像处理技术。 首先,我们来探讨一下Java在图像处理中的基础概念。Java提供了`java.awt.image`和`javax...
Java图片处理工具ImageMagick是一个强大的跨平台图形处理库,它允许开发人员在Java应用程序中进行复杂的图像操作,包括但不限于转换、编辑、合成图像以及处理大量格式的图像文件。ImageMagick是由C语言编写的,但...
在Java程序中调用摄像头,JMF是基础框架。然而,由于JMF的更新较慢,不支持现代摄像头,因此在实际项目中可能需要寻找替代方案。 3. **Java Advanced Imaging (JAI)** 和 **JavaFX**: Java Advanced Imaging提供...
通过分析和使用这个“zimg 的JAVA提交图片的演示程序”,开发者可以学习到如何在自己的Java项目中集成Zimg,实现高效、灵活的图片处理功能,提升用户体验,同时降低服务器端的计算压力。这对于构建高性能的图片服务...
综上所述,"java编写的简单图片处理"项目涵盖了基础的Java图像处理技术,包括图像的移动、缩放、2D到3D的转换,以及可能的地图数据处理。这些技能对于开发任何涉及图像显示和编辑的Java应用程序都是必不可少的。通过...
这是一个Java图片处理程序。 Java 开源代码,高手学习 java 图片处理源码