Java图片裁剪

java

public static void main(String[] args) throws IOException {

String path = "C:/Users/yang/Desktop/source.jpg";

BufferedImage bufferedImage = ImageIO.read(new File(path));

int width = bufferedImage.getWidth();

int height = bufferedImage.getHeight();

System.out.println(width+"---"+height);

String targetpath = "C:/Users/yang/Desktop/";

int i = 0,cutwidth = 2000;

while(height>0 && height%cutwidth!=0){

System.out.println("第"+(i+1)+"次");

cut(path, targetpath+i+".jpg", 0, i*cutwidth, width, cutwidth);

height -= cutwidth;

i++;

}

}

public static void cut(String srcpath,String subpath,int x,int y,int width,int height) throws IOException{ 

FileInputStream is = null ;

ImageInputStream iis =null ;

try{

//读取图片文件

is = new FileInputStream(srcpath);

/**//*

* 返回包含所有当前已注册 ImageReader 的 Iterator,这些 ImageReader

* 声称能够解码指定格式。参数:formatName - 包含非正式格式名称 .

*(例如 "jpeg" 或 "tiff")等。

*/

String suffix = srcpath.substring(srcpath.lastIndexOf(".")+1);

Iterator<ImageReader> it = ImageIO.getImageReadersByFormatName(suffix);

ImageReader reader = it.next();

//获取图片流

iis = ImageIO.createImageInputStream(is);

/**//*

* <p>iis:读取源.true:只向前搜索 </p>.将它标记为‘只向前搜索’。

* 此设置意味着包含在输入源中的图像将只按顺序读取,可能允许 reader

* 避免缓存包含与以前已经读取的图像关联的数据的那些输入部分。

*/

reader.setInput(iis,true) ;

/**//*

* <p>描述如何对流进行解码的类<p>.用于指定如何在输入时从 Java Image I/O

* 框架的上下文中的流转换一幅图像或一组图像。用于特定图像格式的插件

* 将从其 ImageReader 实现的 getDefaultReadParam 方法中返回

* ImageReadParam 的实例。

*/

ImageReadParam param = reader.getDefaultReadParam();

/**//*

* 图片裁剪区域。Rectangle 指定了坐标空间中的一个区域,通过 Rectangle 对象

* 的左上顶点的坐标(x,y)、宽度和高度可以定义这个区域。

*/

Rectangle rect = new Rectangle(x, y, width, height);

//提供一个 BufferedImage,将其用作解码像素数据的目标。

param.setSourceRegion(rect);

/**//*

* 使用所提供的 ImageReadParam 读取通过索引 imageIndex 指定的对象,并将

* 它作为一个完整的 BufferedImage 返回。

*/

BufferedImage bi = reader.read(0,param);

//保存新图片

ImageIO.write(bi, "jpg", new File(subpath));

}

finally{

if(is!=null)

is.close() ;

if(iis!=null)

iis.close();

}

}

 

以上是 Java图片裁剪 的全部内容, 来源链接: utcz.com/z/393517.html

回到顶部