近期有使用到图片的压缩处理,由于在之前用Java 处理时,在低像素的情况下,Java 处理的效果确实很差,然后尝试了用网上推荐的免费开源的第三方软件,利用Java 的jni 调用dll 文件进行处理,效果还可以。在此记录下,方便以后继续积累。
1、纯Java 类处理图片代码
/**
* 转换图片大小,不变形
*
* @param img
* 图片文件
* @param width
* 图片宽
* @param height
* 图片高
*/
public static void changeImge(File img, int width, int height) {
try {
Image image = ImageIO.read(img);
//图片尺寸的大小处理,如果长宽都小于规定大小,则返回,如果有一个大于规定大小,则等比例缩放
int srcH = image.getHeight(null);
int srcW = image.getWidth(null);
if (srcH <= height && srcW <= width) {
return;
}
int tmpH = width;
int tmpW = height;
//在长度和宽度都做了限制,不能超过设定值
while (srcH > height || srcW > width) {
if(srcW > width) {
tmpH = srcH * width / srcW;
srcH = tmpH;
srcW=width;
}
if(srcH > height) {
tmpW = srcW * height / srcH;
srcW = tmpW;
srcH=height;
}
}
BufferedImage bufferedImage = new BufferedImage(srcW, srcH,
BufferedImage.TYPE_3BYTE_BGR);
bufferedImage.getGraphics().drawImage(
image.getScaledInstance(srcW, srcH, Image.SCALE_SMOOTH), 0,
0, srcW, srcH, null);
FileOutputStream fos = new FileOutputStream(img);
JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(fos);
encoder.encode(bufferedImage);
fos.close();
// System.out.println("转换成功...");
} catch (IOException e) {
e.printStackTrace();
throw new IllegalStateException("图片转换出错!", e);
}
}
2、使用Jmagick 辅助
(参考了以下网站:http://www.i5a6.com/?p=142)
(1)使用的windows下的jmagick-win-6.3.9-q16.zip 地址是:http://downloads.jmagick.org/6.3.9/
(2)doc对应的api地址:http://downloads.jmagick.org/jmagick-doc/
(3)安装imagemagick,官方网站:http://www.imagemagick.org/
我使用的是:imagemagick-6.4.6-4-q16-windows-dll.exe :点击下载
(4) 安装imagemagick-6.4.6-4-q16-windows-dll.exe,将 安装目录下(按自己所安装的目录找) 下的所有dll文件 copy 到系统盘下的 “c:\windows\system32\”文件夹里
(5) 配置环境变量
再环境变量path里添加新的值 “c:\program files\imagemagick-6.4.6-4-q16“使用ide可以不用配置
(6)解压jmagick-win-6.3.9-q16.zip
将 jmagick.dll 复制到系统盘下的 “c:\windows\system32\”文件夹里 和 复制到jdk的bin(例“d:\jdk6\bin”)文件里各一份
将 jmagick.jar 复制到tomcat下的lib文件夹里 和 所使用项目的web-inf下lib文件里 各一份
(7)web应用如果部署到tomcat下,那么最好在catalina.bat文件中改变如下设置
set java_opts=%java_opts% -xms256m -xmx768m -xx:maxpermsize=128m – djava.util.logging.manager=org.apache.juli.classloaderlogmanager – djava.util.logging.config.file=”${catalina.base}\conf\logging.properties”
避免heap溢出的问题,参数看你自己的机器而定。( -xms256m -xmx768m -xx:maxpermsize=128m )
(8)还要注意如果部署到web应用,你在使用的class里面需要
system.setproperty(“jmagick.systemclassloader”,”no”);
要不然会报出unsatisfiedlinkerror: no jmagick in java.library.path.
工具类:
import java.awt.Dimension;
import java.awt.Rectangle;
import java.text.SimpleDateFormat;
import java.util.Date;
import magick.CompositeOperator;
import magick.CompressionType;
import magick.DrawInfo;
import magick.ImageInfo;
import magick.MagickException;
import magick.MagickImage;
import magick.PixelPacket;
import magick.PreviewType;
public class ImageUtils {
static{
//不能漏掉这个,不然jmagick.jar的路径找不到
System.setProperty("jmagick.systemclassloader","no");
}
/**
* 压缩图片,不变形
* @param filePath 源文件路径
* @param toPath 缩略图路径
* @param width 设定宽
* @param height 设定长
*/
public static void changeSize(String filePath, String toPath,int width,int height) throws MagickException{
ImageInfo info = null;
MagickImage image = null;
Dimension imageDim = null;
MagickImage scaled = null;
try{
info = new ImageInfo(filePath);
image = new MagickImage(info);
imageDim = image.getDimension();
//图片尺寸的大小处理,如果长宽都小于规定大小,则返回,如果有一个大于规定大小,则等比例缩放
int srcH = imageDim.width;
int srcW = imageDim.height;
if (srcH <= height && srcW <= width) {
return;
}
int tmpH = width;
int tmpW = height;
//在长度和宽度都做了限制,不能超过设定值
while (srcH > height || srcW > width) {
if(srcW > width) {
tmpH = srcH * width / srcW;
srcH = tmpH;
srcW=width;
}
if(srcH > height) {
tmpW = srcW * height / srcH;
srcW = tmpW;
srcH=height;
}
}
scaled = image.scaleImage(srcW, srcH);//小图片文件的大小.
scaled.setFileName(toPath);
scaled.writeImage(info);
}finally{
if(scaled != null){
scaled.destroyImages();
}
}
}
/**
* 水印(图片logo)
* @param filePath 源文件路径
* @param toImg 修改图路径
* @param logoPath logo图路径
* @throws MagickException
*/
public static void initLogoImg(String filePath, String toImg, String logoPath) throws MagickException {
ImageInfo info = new ImageInfo();
MagickImage fImage = null;
MagickImage sImage = null;
MagickImage fLogo = null;
MagickImage sLogo = null;
Dimension imageDim = null;
Dimension logoDim = null;
try {
fImage = new MagickImage(new ImageInfo(filePath));
imageDim = fImage.getDimension();
int width = imageDim.width;
int height = imageDim.height;
if (width > 660) {
height = 660 * height / width;
width = 660;
}
sImage = fImage.scaleImage(width, height);
fLogo = new MagickImage(new ImageInfo(logoPath));
logoDim = fLogo.getDimension();
int lw = width / 8;
int lh = logoDim.height * lw / logoDim.width;
sLogo = fLogo.scaleImage(lw, lh);
sImage.compositeImage(CompositeOperator.AtopCompositeOp, sLogo, width-(lw + lh/10), height-(lh + lh/10));
sImage.setFileName(toImg);
sImage.writeImage(info);
} finally {
if(sImage != null){
sImage.destroyImages();
}
}
}
/**
* 水印(文字)
* @param filePath 源文件路径
* @param toImg 修改图路径
* @param text 名字(文字内容自己随意)
* @throws MagickException
*/
public static void initTextToImg(String filePath, String toImg, String text) throws MagickException{
ImageInfo info = new ImageInfo(filePath);
if (filePath.toUpperCase().endsWith("JPG") || filePath.toUpperCase().endsWith("JPEG")) {
info.setCompression(CompressionType.JPEGCompression); //压缩类别为JPEG格式
info.setPreviewType(PreviewType.JPEGPreview); //预览格式为JPEG格式
info.setQuality(95);
}
MagickImage aImage = new MagickImage(info);
Dimension imageDim = aImage.getDimension();
int wideth = imageDim.width;
int height = imageDim.height;
if (wideth > 660) {
height = 660 * height / wideth;
wideth = 660;
}
int a = 0;
int b = 0;
String[] as = text.split("");
for (String string : as) {
if(string.matches("[\u4E00-\u9FA5]")){
a++;
}
if(string.matches("[a-zA-Z0-9]")){
b++;
}
}
int tl = a*12 + b*6 + 300;
MagickImage scaled = aImage.scaleImage(wideth, height);
if(wideth > tl && height > 5){
DrawInfo aInfo = new DrawInfo(info);
aInfo.setFill(PixelPacket.queryColorDatabase("white"));
aInfo.setUnderColor(new PixelPacket(0,0,0,100));
aInfo.setPointsize(12);
//解决中文乱码问题,自己可以去随意定义个自己喜欢字体,对于移植有点问题,所以暂且注释
// String fontPath = "C:/WINDOWS/Fonts/MSYH.TTF";
// aInfo.setFont(fontPath);
aInfo.setTextAntialias(true);
aInfo.setOpacity(0);
aInfo.setText(" " + text + "于 " + new SimpleDateFormat("yyyy-MM-dd").format(new Date()) + " 上传于XXXX网,版权归作者所有!");
aInfo.setGeometry("+" + (wideth-tl) + "+" + (height-5));
scaled.annotateImage(aInfo);
}
scaled.setFileName(toImg);
scaled.writeImage(info);
scaled.destroyImages();
}
/**
* 切图
* @param imgPath 源图路径
* @param toPath 修改图路径
* @param w 宽度
* @param h 高度
* @param x 左上角的 X 坐标
* @param y 左上角的 Y 坐标
* @throws MagickException
*/
public static void cutImg(String imgPath, String toPath, int w, int h, int x, int y) throws MagickException {
ImageInfo infoS = null;
MagickImage image = null;
MagickImage cropped = null;
Rectangle rect = null;
try {
infoS = new ImageInfo(imgPath);
image = new MagickImage(infoS);
rect = new Rectangle(x, y, w, h);
cropped = image.cropImage(rect);
cropped.setFileName(toPath);
cropped.writeImage(infoS);
} finally {
if (cropped != null) {
cropped.destroyImages();
}
}
}
}
分享到:
相关推荐
本文将深入探讨“Jmagick缩图”这一主题,它是一种基于Java的图片处理工具,用于快速有效地生成图片的缩略图。 JMagick是ImageMagick的一个Java接口,ImageMagick是一个强大的跨平台图像处理库。它允许Java开发者...
在实际项目开发中,图片处理是一项常见的需求,包括但不限于图片的压缩、尺寸调整以及添加水印等操作。传统的Java库虽然能够实现这些功能,但往往在图片质量方面不尽如人意,尤其是当图片尺寸被大幅度压缩时,画质...
**JMagick图片处理**是图像操作的重要工具,它是一个Java接口,用于ImageMagick库,使得在Java环境中可以方便地进行图像处理。这个技术涵盖了多个关键知识点,包括创建缩略图、添加水印、切图以及压缩图片,这些都是...
例如,一个Web应用可能使用Jmagick来动态生成缩略图,或者在上传图片时进行预处理,以确保符合规定的尺寸和格式。 总的来说,Jmagick提供了一种灵活且强大的方式,让Java开发者能够充分利用ImageMagick的图像处理...
在实际应用中,JMagick可以用于各种场景,如网站的图像上传处理、图片格式转换、图片质量优化等。例如,一个常见的应用场景是用户上传一张大尺寸的照片,服务器端可以通过JMagick进行自动缩放,减少存储空间并加快...
"rt java图片处理jar包"可能就是这样一个库,它可能包含了一些优化的算法或额外的特性,使得图片处理更加便捷。 5. **性能优化**: 大规模的图片处理可能需要考虑性能问题。例如,为了避免内存占用过多,可以使用...
2. 解压:解压下载的文件到本地目录,通常会包含JMagick的库文件和必要的配置文件。 3. 配置环境变量:将JMagick的库路径添加到系统的PATH环境变量中,以便Java能够找到这个库。 4. 验证安装:编写一个简单的Java...
在Java Web应用中,JMagick可以通过Ajax技术实现实时的客户端图像处理,提升用户体验。Ajax允许页面在不刷新的情况下与服务器进行异步通信,用户可以即时预览图像处理的结果,增强了交互性和响应速度。 标签“ajax...
ImageMagick是一款强大的开源图像处理工具,而JMagick是其与Java平台的桥梁,使得在Java应用程序中能够调用ImageMagick的功能。这个“ImageMagick-6.3.9+jmagick组合”指的是ImageMagick的一个特定版本6.3.9与...
总的来说,Java图片和文件处理涉及到广泛的技术和工具,从基础的Java API到强大的第三方库,都有助于开发者高效地完成相关任务。在实际开发中,根据项目需求选择合适的工具和方法,可以提升代码的可维护性和性能。
要实现在Java中添加水印,我们可以利用开源的图像处理库,如Apache Commons Imaging(原名:Sanselan)、ImageMagick的Java绑定(JMagick)或Java Advanced Imaging (JAI)。这里以Apache Commons Imaging为例,因为...
在Java Web开发中,图片处理是一项常见的需求,无论是用于网站展示、用户上传的头像处理,还是电商系统中的商品图片优化。本项目专注于图片的压缩功能,提供了简单易用的API,可以对图片进行缩放和降质处理,并且...
在Java编程中,图片处理是一项常见的任务,包括图片的压缩和裁剪。在这个场景中,我们关注的是如何实现“图片等比压缩后裁剪”。等比压缩是指保持原图宽高比例进行压缩,以避免图像失真,而裁剪则是根据特定需求去除...
这个配置文档主要涵盖了如何在Java环境中配置和使用相关工具来处理图片上传的过程。首先,我们来深入理解涉及的关键知识点。 1. **Servlet与Multipart解析器**: 图片上传通常通过HTTP POST请求完成,其中包含...
Java的`java.awt.image.BufferedImage`类提供了丰富的图像处理功能,包括调整尺寸和压缩。通过创建一个目标尺寸的BufferedImage对象,然后使用`Graphics2D`的`drawImage()`方法将原图绘制到新尺寸的BufferedImage上...
Java提供了多种库,如Apache Commons Imaging (前身是Apache Commons Sanselan) 或 ImageMagick的Java绑定(JMagick),可以用来处理图像。 对于存储,除了本地文件系统外,还可以考虑云存储服务,如Amazon S3、...
3. **JMagick**:是ImageMagick的Java接口,提供了丰富的图片处理功能,包括压缩。ImageMagick是一个强大的命令行工具集,JMagick则将这些功能封装为Java API。 4. **FreeImage**:是一个开源库,支持多种图像格式...
### Jmagick 图片处理知识点 #### 一、概述 Jmagick 是一个 Java 接口,用于 ImageMagick 图形库,它提供了一系列强大的功能,包括图片缩放、翻转、添加水印等复杂的图形处理操作。这些功能在很多应用中都非常有用...
JMagick是ImageMagick库的一个Java绑定,它允许Java应用程序直接处理图像操作,包括读取、写入和转换各种图像格式。在处理图片时,Dimension类可能会与JMagick结合使用,以控制显示或输出的图像尺寸。 综上所述,这...
ImageMagick 是一个功能很强的图片处理程序。可应用在多种操作系统平台上。 安装ImageMagick和JMagick 如果安装了老版本ImageMagick的rpm包,请先删除 安装环境要求: 确认已经安装了zlib、freetype、libpng和jpeg-...