图片处理

本文介绍了一种使用Java进行图片大小调整及切割的方法。通过具体的代码示例展示了如何加载图片、改变图片尺寸,并将图片按指定宽度和高度进行切割。适用于需要批量处理图片的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

改变大小

File picFile = new File("C:/pic/yui2.jpg");
FileOutputStream fos = new FileOutputStream(picFile);
BufferedOutputStream bos = new BufferedOutputStream(fos);

File picFileInput = new File("C:/pic/yui.jpg");
FileInputStream fis = new FileInputStream(picFileInput);
BufferedInputStream bis = new BufferedInputStream(fis);

BufferedImage bi = ImageIO.read(bis);
BufferedImage bo = new BufferedImage(512, 384,
BufferedImage.TYPE_INT_RGB);

Image image = bi.getScaledInstance(512, 384, Image.SCALE_REPLICATE);

bo.getGraphics().drawImage(image, 0, 0, null);
ImageIO.write(bo, "jpg", bos);
bos.close();
fos.close();


切割

/** *//**
* 图像切割
* @param srcImageFile 源图像地址
* @param descDir 切片目标文件夹
* @param destWidth 目标切片宽度
* @param destHeight 目标切片高度
*/
public static void cut(String srcImageFile, String descDir, int destWidth, int destHeight)
...{
try
...{
Image img;
ImageFilter cropFilter;
// 读取源图像
BufferedImage bi = ImageIO.read(new File(srcImageFile));
int srcWidth = bi.getHeight(); // 源图宽度
int srcHeight = bi.getWidth(); // 源图高度
if (srcWidth > destWidth && srcHeight > destHeight)
...{
Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);
destWidth = 200; // 切片宽度
destHeight = 150; // 切片高度
int cols = 0; // 切片横向数量
int rows = 0; // 切片纵向数量
// 计算切片的横向和纵向数量
if (srcWidth % destWidth == 0)
...{
cols = srcWidth / destWidth;
}
else
...{
cols = (int) Math.floor(srcWidth / destWidth) + 1;
}
if (srcHeight % destHeight == 0)
...{
rows = srcHeight / destHeight;
}
else
...{
rows = (int) Math.floor(srcHeight / destHeight) + 1;
}
// 循环建立切片
// 改进的想法:是否可用多线程加快切割速度
for (int i = 0; i < rows; i++)
...{
for (int j = 0; j < cols; j++)
...{
// 四个参数分别为图像起点坐标和宽高
// 即: CropImageFilter(int x,int y,int width,int height)
cropFilter = new CropImageFilter(j * 200, i * 150, destWidth, destHeight);
img = Toolkit.getDefaultToolkit().createImage(
new FilteredImageSource(image.getSource(), cropFilter));
BufferedImage tag = new BufferedImage(destWidth, destHeight, BufferedImage.TYPE_INT_RGB);
Graphics g = tag.getGraphics();
g.drawImage(img, 0, 0, null); // 绘制缩小后的图
g.dispose();
// 输出为文件
ImageIO.write(tag, "JPEG", new File(descDir + "pre_map_" + i + "_" + j + ".jpg"));
}
}
}
}
catch (Exception e)
...{
e.printStackTrace();
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值