微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

简单的java图片处理类(图片水印 图片缩放)

图片处理类功能非常之强大可以实现几乎所有WEB开发中对图像的处理功能都集成了,包括缩放图像、切割图像、图像类型转换、彩色转黑白、文字水印、图片水印等功能

复制代码 代码如下:

import java.awt.AlphaComposite;

import java.awt.Color;

import java.awt.Font;

import java.awt.Graphics;

import java.awt.Graphics2D;

import java.awt.Image;

import java.awt.Toolkit;

import java.awt.color.ColorSpace;

import java.awt.geom.AffineTransform;

import java.awt.image.AffineTransformOp;

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.io.File;

import java.io.IOException;import javax.imageio.ImageIO;

/**

 * 图片处理工具类:

 * 功能缩放图像、切割图像、图像类型转换、彩色转黑白、文字水印、图片水印等

 * @author Administrator

 */

public class ImageUtils {

    /**

     * 几种常见的图片格式

     */

    public static String IMAGE_TYPE_GIF = "gif";// 图形交换格式

    public static String IMAGE_TYPE_JPG = "jpg";// 联合照片专家组

    public static String IMAGE_TYPE_JPEG = "jpeg";// 联合照片专家组

    public static String IMAGE_TYPE_BMP = "bmp";// 英文Bitmap(位图)的简写,它是Windows操作系统中的标准图像文件格式

    public static String IMAGE_TYPE_PNG = "png";// 可移植网络图形

    public static String IMAGE_TYPE_PSD = "psd";// Photoshop的专用格式Photoshop

    /**

     * 程序入口:用于测试

     * @param args

     */

    public static void main(String[] args) {

        // 1-缩放图像

        // 方法一:按比例缩放

        ImageUtils.scale("e:/abc.jpg", "e:/abc_scale.jpg", 2, true);//测试OK

        // 方法二:按高度和宽度缩放

        ImageUtils.scale2("e:/abc.jpg", "e:/abc_scale2.jpg", 500, 300, true);//测试OK

        // 2-切割图像:

        // 方法一:按指定起点坐标和宽高切割

        ImageUtils.cut("e:/abc.jpg", "e:/abc_cut.jpg", 0, 0, 400, 400 );//测试OK

        // 方法二:指定切片的行数和列数

        ImageUtils.cut2("e:/abc.jpg", "e:/", 2, 2 );//测试OK

        // 方法三:指定切片的宽度和高度

        ImageUtils.cut3("e:/abc.jpg", "e:/", 300, 300 );//测试OK

        // 3-图像类型转换:

        ImageUtils.convert("e:/abc.jpg", "GIF", "e:/abc_convert.gif");//测试OK

        // 4-彩色转黑白:

        ImageUtils.gray("e:/abc.jpg", "e:/abc_gray.jpg");//测试OK

        // 5-给图片添加文字水印:

        // 方法一:

        ImageUtils.presstext("我是水印文字","e:/abc.jpg","e:/abc_presstext.jpg","宋体",Font.BOLD,Color.white,80, 0, 0, 0.5f);//测试OK

        // 方法二:

        ImageUtils.presstext2("我也是水印文字", "e:/abc.jpg","e:/abc_presstext2.jpg", "黑体", 36, Color.white, 80, 0, 0, 0.5f);//测试OK

        // 6-给图片添加图片水印:

        ImageUtils.pressImage("e:/abc2.jpg", "e:/abc.jpg","e:/abc_pressImage.jpg", 0, 0, 0.5f);//测试OK

    }

    /**

     * 缩放图像按比例缩放)

     * @param srcImageFile 源图像文件地址

     * @param result 缩放后的图像地址

     * @param scale 缩放比例

     * @param flag 缩放选择:true 放大; false 缩小;

     */

    public final 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 result 缩放后的图像地址

     * @param height 缩放后的高度

     * @param width 缩放后的宽度

     * @param bb 比例不对时是否需要补白:true为补白; false为不补白;

     */

    public final static void scale2(String srcImageFile, String result, int height, int width, boolean bb) {

        try {

            double ratio = 0.0; // 缩放比例

            File f = new File(srcImageFile);

            BufferedImage bi = ImageIO.read(f);

            Image itemp = bi.getScaledInstance(width, height, bi.SCALE_SMOOTH);

            // 计算比例

            if ((bi.getHeight() > height) || (bi.getWidth() > width)) {

                if (bi.getHeight() > bi.getWidth()) {

                    ratio = (new Integer(height)).doubleValue()

                            / bi.getHeight();

                } else {

                    ratio = (new Integer(width)).doubleValue() / bi.getWidth();

                }

                AffineTransformOp op = new AffineTransformOp(AffineTransform

                        .getScaleInstance(ratio, ratio), null);

                itemp = op.filter(bi, null);

            }

            if (bb) {//补白

                BufferedImage image = new BufferedImage(width, height,

                        BufferedImage.TYPE_INT_RGB);

                Graphics2D g = image.createGraphics();

                g.setColor(Color.white);

                g.fillRect(0, 0, width, height);

                if (width == itemp.getWidth(null))

                    g.drawImage(itemp, 0, (height - itemp.getHeight(null)) / 2,

                            itemp.getWidth(null), itemp.getHeight(null),

                            Color.white, null);

                else

                    g.drawImage(itemp, (width - itemp.getWidth(null)) / 2, 0,

                            itemp.getWidth(null), itemp.getHeight(null),

                            Color.white, null);

                g.dispose();

                itemp = image;

            }

            ImageIO.write((BufferedImage) itemp, "JPEG", new File(result));

        } catch (IOException e) {

            e.printstacktrace();

        }

    }

    /**

     * 图像切割(按指定起点坐标和宽高切割)

     * @param srcImageFile 源图像地址

     * @param result 切片后的图像地址

     * @param x 目标切片起点坐标X

     * @param y 目标切片起点坐标Y

     * @param width 目标切片宽度

     * @param height 目标切片高度

     */

    public final static void cut(String srcImageFile, String result,

            int x, int y, int width, int height) {

        try {

            // 读取源图像

            BufferedImage bi = ImageIO.read(new File(srcImageFile));

            int srcWidth = bi.getHeight(); // 源图宽度

            int srcHeight = bi.getWidth(); // 源图高度

            if (srcWidth > 0 && srcHeight > 0) {

                Image image = bi.getScaledInstance(srcWidth, srcHeight,

                        Image.SCALE_DEFAULT);

                // 四个参数分别为图像起点坐标和宽高

                // 即: CropImageFilter(int x,int y,int width,int height)

                ImageFilter cropFilter = new CropImageFilter(x, y, width, height);

                Image img = Toolkit.getDefaultToolkit().createImage(

                        new FilteredImageSource(image.getSource(),

                                cropFilter));

                BufferedImage tag = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);

                Graphics g = tag.getGraphics();

                g.drawImage(img, 0, 0, width, height, null); // 绘制切割后的图

                g.dispose();

                // 输出文件

                ImageIO.write(tag, "JPEG", new File(result));

            }

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 图像切割(指定切片的行数和列数)

     * @param srcImageFile 源图像地址

     * @param descDir 切片目标文件

     * @param rows 目标切片行数。认2,必须是范围 [1, 20] 之内

     * @param cols 目标切片列数。认2,必须是范围 [1, 20] 之内

     */

    public final static void cut2(String srcImageFile, String descDir,

            int rows, int cols) {

        try {

            if(rows20) rows = 2; // 切片行数

            if(cols20) cols = 2; // 切片列数

            // 读取源图像

            BufferedImage bi = ImageIO.read(new File(srcImageFile));

            int srcWidth = bi.getHeight(); // 源图宽度

            int srcHeight = bi.getWidth(); // 源图高度

            if (srcWidth > 0 && srcHeight > 0) {

                Image img;

                ImageFilter cropFilter;

                Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);

                int destWidth = srcWidth; // 每张切片的宽度

                int destHeight = srcHeight; // 每张切片的高度

                // 计算切片的宽度和高度

                if (srcWidth % cols == 0) {

                    destWidth = srcWidth / cols;

                } else {

                    destWidth = (int) Math.floor(srcWidth / cols) + 1;

                }

                if (srcHeight % rows == 0) {

                    destHeight = srcHeight / rows;

                } else {

                    destHeight = (int) Math.floor(srcWidth / rows) + 1;

                }

                // 循环建立切片

                // 改进的想法:是否可用多线程加快切割速度

                for (int i = 0; i                     for (int j = 0; j                         // 四个参数分别为图像起点坐标和宽高

                        // 即: CropImageFilter(int x,int y,int width,int height)

                        cropFilter = new CropImageFilter(j * destWidth, i * destHeight,

                                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

                                + "_r" + i + "_c" + j + ".jpg"));

                    }

                }

            }

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 图像切割(指定切片的宽度和高度)

     * @param srcImageFile 源图像地址

     * @param descDir 切片目标文件

     * @param destWidth 目标切片宽度。认200

     * @param destHeight 目标切片高度。认150

     */

    public final static void cut3(String srcImageFile, String descDir,

            int destWidth, int destHeight) {

        try {

            if(destWidth            if(destHeight            // 读取源图像

            BufferedImage bi = ImageIO.read(new File(srcImageFile));

            int srcWidth = bi.getHeight(); // 源图宽度

            int srcHeight = bi.getWidth(); // 源图高度

            if (srcWidth > destWidth && srcHeight > destHeight) {

                Image img;

                ImageFilter cropFilter;

                Image image = bi.getScaledInstance(srcWidth, srcHeight, Image.SCALE_DEFAULT);

                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                     for (int j = 0; j                         // 四个参数分别为图像起点坐标和宽高

                        // 即: CropImageFilter(int x,int y,int width,int height)

                        cropFilter = new CropImageFilter(j * destWidth, i * destHeight,

                                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

                                + "_r" + i + "_c" + j + ".jpg"));

                    }

                }

            }

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 图像类型转换:GIF->JPG、GIF->PNG、PNG->JPG、PNG->GIF(X)、BMP->PNG

     * @param srcImageFile 源图像地址

     * @param formatName 包含格式非正式名称的 String:如JPG、JPEG、GIF等

     * @param destimageFile 目标图像地址

     */

    public final static void convert(String srcImageFile, String formatName, String destimageFile) {

        try {

            File f = new File(srcImageFile);

            f.canRead();

            f.canWrite();

            BufferedImage src = ImageIO.read(f);

            ImageIO.write(src, formatName, new File(destimageFile));

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 彩色转为黑白

     * @param srcImageFile 源图像地址

     * @param destimageFile 目标图像地址

     */

    public final static void gray(String srcImageFile, String destimageFile) {

        try {

            BufferedImage src = ImageIO.read(new File(srcImageFile));

            ColorSpace cs = ColorSpace.getInstance(ColorSpace.CS_GRAY);

            ColorConvertOp op = new ColorConvertOp(cs, null);

            src = op.filter(src, null);

            ImageIO.write(src, "JPEG", new File(destimageFile));

        } catch (IOException e) {

            e.printstacktrace();

        }

    }

    /**

     * 给图片添加文字水印

     * @param presstext 水印文字

     * @param srcImageFile 源图像地址

     * @param destimageFile 目标图像地址

     * @param fontName 水印的字体名称

     * @param fontStyle 水印的字体样式

     * @param color 水印的字体颜色

     * @param fontSize 水印的字体大小

     * @param x 修正值

     * @param y 修正值

     * @param alpha 透明度:alpha 必须是范围 [0.0, 1.0] 之内(包含边界值)的一个浮点数字

     */

    public final static void presstext(String presstext,

            String srcImageFile, String destimageFile, String fontName,

            int fontStyle, Color color, int fontSize,int x,

            int y, float alpha) {

        try {

            File img = new File(srcImageFile);

            Image src = ImageIO.read(img);

            int width = src.getWidth(null);

            int height = src.getHeight(null);

            BufferedImage image = new BufferedImage(width, height,

                    BufferedImage.TYPE_INT_RGB);

            Graphics2D g = image.createGraphics();

            g.drawImage(src, 0, 0, width, height, null);

            g.setColor(color);

            g.setFont(new Font(fontName, fontStyle, fontSize));

            g.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP,

                    alpha));

            // 在指定坐标绘制水印文字

            g.drawString(presstext, (width - (getLength(presstext) * fontSize))

                    / 2 + x, (height - fontSize) / 2 + y);

            g.dispose();

            ImageIO.write((BufferedImage) image, "JPEG", new File(destimageFile));// 输出文件

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 给图片添加文字水印

     * @param presstext 水印文字

     * @param srcImageFile 源图像地址

     * @param destimageFile 目标图像地址

     * @param fontName 字体名称

     * @param fontStyle 字体样式

     * @param color 字体颜色

     * @param fontSize 字体大小

     * @param x 修正值

     * @param y 修正值

     * @param alpha 透明度:alpha 必须是范围 [0.0, 1.0] 之内(包含边界值)的一个浮点数字

     */

    public final static void presstext2(String presstext, String srcImageFile,String destimageFile,

            String fontName, int fontStyle, Color color, int fontSize, int x,

            int y, float alpha) {

        try {

            File img = new File(srcImageFile);

            Image src = ImageIO.read(img);

            int width = src.getWidth(null);

            int height = src.getHeight(null);

            BufferedImage image = new BufferedImage(width, height,

                    BufferedImage.TYPE_INT_RGB);

            Graphics2D g = image.createGraphics();

            g.drawImage(src, 0, 0, width, height, null);

            g.setColor(color);

            g.setFont(new Font(fontName, fontStyle, fontSize));

            g.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP,

                    alpha));

            // 在指定坐标绘制水印文字

            g.drawString(presstext, (width - (getLength(presstext) * fontSize))

                    / 2 + x, (height - fontSize) / 2 + y);

            g.dispose();

            ImageIO.write((BufferedImage) image, "JPEG", new File(destimageFile));

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 给图片添加图片水印

     * @param pressImg 水印图片

     * @param srcImageFile 源图像地址

     * @param destimageFile 目标图像地址

     * @param x 修正值。 认在中间

     * @param y 修正值。 认在中间

     * @param alpha 透明度:alpha 必须是范围 [0.0, 1.0] 之内(包含边界值)的一个浮点数字

     */

    public final static void pressImage(String pressImg, String srcImageFile,String destimageFile,

            int x, int y, float alpha) {

        try {

            File img = new File(srcImageFile);

            Image src = ImageIO.read(img);

            int wideth = src.getWidth(null);

            int height = src.getHeight(null);

            BufferedImage image = new BufferedImage(wideth, height,

                    BufferedImage.TYPE_INT_RGB);

            Graphics2D g = image.createGraphics();

            g.drawImage(src, 0, 0, wideth, height, null);

            // 水印文件

            Image src_biao = ImageIO.read(new File(pressImg));

            int wideth_biao = src_biao.getWidth(null);

            int height_biao = src_biao.getHeight(null);

            g.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP,

                    alpha));

            g.drawImage(src_biao, (wideth - wideth_biao) / 2,

                    (height - height_biao) / 2, wideth_biao, height_biao, null);

            // 水印文件结束

            g.dispose();

            ImageIO.write((BufferedImage) image,  "JPEG", new File(destimageFile));

        } catch (Exception e) {

            e.printstacktrace();

        }

    }

    /**

     * 计算text的长度(一个中文算两个字符)

     * @param text

     * @return

     */

    public final static int getLength(String text) {

        int length = 0;

        for (int i = 0; i             if (new String(text.charat(i) + "").getBytes().length > 1) {

                length += 2;

            } else {

                length += 1;

            }

        }

        return length / 2;

    }

}

 

上一篇:java图片添加水印实例代码分享下一篇:java 图片加水印实例代码 热门搜索

图片处理类 

缩放图片 

图片缩放 

简单图片 

图片处理 

相关文章

简单的java图片处理类(图片水印 图片缩放)

2021-10-18阅读(6881)评论(0)推荐()

图片处理类功能非常之强大可以实现几乎所有WEB开发中对图像的处理功能都集成了,包括缩放图像、切割图像、图像类型转换、彩色转黑白、文字水印、图片水印等功能

Java图片处理 (文字水印、图片水印、缩放、补白)代码实例

2021-10-10阅读(5348)评论(0)推荐()

这篇文章主要介绍了Java图片处理 (文字水印、图片水印、缩放、补白)代码实例,本文直接给出实现代码,需要的朋友可以参考下

PHP功能图片处理类分享(PHP图片缩放类)

2021-10-04阅读(2426)评论(0)推荐()

本文提供的PHP类用于完成图片缩放,水印添加,当水印图超过目标图片尺寸时,水印图能自动适应目标图片而缩小,当水印图超过目标图片尺寸时,水印图能自动适应目标图片而...

asp.net上传图片并作处理水印与缩略图的实例代码

2021-10-06阅读(3280)评论(0)推荐()

asp.net 上传图片并作处理(生成缩略图 、在图片增加文字水印、在图片生成图片水印)的实例代码,经过测试!

常用的PHP图片处理类(水印、等比缩放、固定高宽)分享

2021-10-16阅读(9917)评论(0)推荐()

这篇文章主要汇总介绍了两个常用的PHP图片处理类(水印、等比缩放、固定高宽),非常的简单实用,有需要的小伙伴可以参考下

功能强大的PHP图片处理类(水印、透明度、旋转)

2021-09-22阅读(7890)评论(0)推荐()

这篇文章主要汇总介绍了PHP图片处理类(水印、透明度、缩放、锐化),非常的简单实用,有需要的小伙伴可以参考下

PHP图片处理之使用imagecopy函数添加图片水印实例

2021-09-14阅读(2280)评论(0)推荐()

这篇文章主要介绍了PHP图片处理之使用imagecopy函数添加图片水印实例,本文给出了一个简单的入门级的自定义函数示例,需要的朋友可以参考下

取消

有人回复邮件通知

提交评论

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐