Java程序对图片的各种处理2009-06-22 14:02package 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图像处理类库 Java Image Filters
java图像处理程序,可以实现简单的灰度转换、图像均衡的功能。值得学习学习
这是一个Java图片处理程序。 Java 开源代码,高手学习 java 图片处理源码
一个处理图片的简单的例子,初学者可以从分析实例开始快速掌握java的一些基础知识
java编写的图像处理程序+源代码+文档 支持灰度图处理、对比度处理、亮度处理、直方图均衡化、灰度直方图、直方图匹配、锐化处理、平滑化处理
前端图片插件不支持HEIC格式展示,需要在后端对HEIC格式图片进行转换为常用图片格式PNG,JPEG处理。通过网上资料查询及检验。在wiondows操作系统java开发环境中可通过ImageMagick安装包和im4java.jar把其他格式图片...
场景运用:在前端图片格式上传中,需要在后端对pdf格式图片进行转换为常用图片格式PNG,JPEG处理。通过网上资料查询及检验。在wiondows操作系统java开发环境中可通过ImageMagick安装包和im4java.jar把其他格式图片如...
java 程序设计 飞行棋游戏 还不是很完善 图片不处理等还没完成
java 水印 图像处理 图片分割 裁剪 缩放 功能 且带整个程序的整合, 和单元测试对单独功能的处理 操作,并可以通过打印 发送传真,全部
代码中可以将大图片通过设定的分辨率生成小规格的图片,方便web程序页面浏览。
* 压缩图片文件 * 先保存原文件,再压缩、上传 * @param oldFile 要进行压缩的文件全路径 * @param width 宽度 * @param height 高度 * @param quality 质量 * @param smallIcon 小图片的后缀 * @return ...
javajava图片特效处理程序,有几十种特效,包括水波纹、高斯模糊、浮雕效果等等,里面有html说明和一个测试程序,自己可以根据需要更改调试。
示例代码展示了如何使用Java的图像处理库来对图像进行灰度化处理。在代码中,我们使用javax.imageio.ImageIO类加载输入图像文件,并创建一个与输入图像具有相同尺寸和类型的输出图像。然后,我们遍历输入图像的每个...
不用多说,程序写得很清楚了,自己能看得懂的
Java图片旋转,使用Java语言编写程序,旋转图像文件,期间用到了滑动条jSlider事件处理技术,得到旋转角度(弧
应用此程序可以对图片实现缩放,使其大小任意改变。在网上报名考试中,很多时候要用到个人免冠正面照,并要求有标准尺寸,已经安装java的朋友就不需要使用photoshop这么复杂的工具了,直接使用此程序处理图片即可!
将程序中文字生成为图片,根据文字行数、每行文字个数自动设置生成图片的大小。生成图片后如需水印可查看我上传的其他资源进行处理。
不用Ps就能不照片合在一起,两张图片在一起你也能办到,既能操作程序练习代码,又能处理图片
使用non-local means方法编写java程序实现对图片的降噪处理,读入噪点图片,输出降噪图片,降噪效果很好。
基于图像处理的车牌识别研究与实现_程序 识别国内车牌 基于java语言,快速识别,参考用java实现车牌号码识别