`

java图片文字水印、图片水印、缩放、补白处理

阅读更多
package com.hmw.picMark;      
     
import java.awt.AlphaComposite;      
import java.awt.Color;      
import java.awt.Font;      
import java.awt.Graphics2D;      
import java.awt.Image;      
import java.awt.geom.AffineTransform;      
import java.awt.image.AffineTransformOp;      
import java.awt.image.BufferedImage;      
import java.io.File;      
import java.io.IOException;      
     
import javax.imageio.ImageIO;      
     
     
public final class ImageUtils {      
    /**    
     * 图片水印    
     *     
     * @param pressImg    
     *            水印图片    
     * @param targetImg    
     *            目标图片    
     * @param x    
     *            修正值 默认在中间    
     * @param y    
     *            修正值 默认在中间    
     * @param alpha    
     *            透明度    
     */     
    public final static void pressImage(String pressImg, String targetImg, int x, int y, float alpha) {      
        try {      
            File img = new File(targetImg);      
            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, "jpg", img);      
        } catch (Exception e) {      
            e.printStackTrace();      
        }      
    }      
     
    /**    
     * 文字水印    
     *     
     * @param pressText    
     *            水印文字    
     * @param targetImg    
     *            目标图片    
     * @param fontName    
     *            字体名称    
     * @param fontStyle    
     *            字体样式    
     * @param color    
     *            字体颜色    
     * @param fontSize    
     *            字体大小    
     * @param x    
     *            修正值    
     * @param y    
     *            修正值    
     * @param alpha    
     *            透明度    
     */     
    public static void pressText(String pressText, String targetImg, String fontName, int fontStyle, Color color, int fontSize, int x, int y, float alpha) {      
        try {      
            File img = new File(targetImg);      
            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, "jpg", img);      
        } catch (Exception e) {      
            e.printStackTrace();      
        }      
    }      
     
    /**    
     * 缩放    
     *     
     * @param filePath    
     *            图片路径    
     * @param height    
     *            高度    
     * @param width    
     *            宽度    
     * @param bb    
     *            比例不对时是否需要补白    
     */     
    public static void resize(String filePath, int height, int width, boolean bb) {      
        try {      
            double ratio = 0; // 缩放比例      
            File f = new File(filePath);      
            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, "jpg", f);      
        } catch (IOException e) {      
            e.printStackTrace();      
        }      
    }      
     
    public static void main(String[] args) throws IOException {      
        pressImage("G:\\imgtest\\sy.jpg", "G:\\imgtest\\testjpg", 0, 0, 5f);      
        pressText("我是文字水印", "G:\\imgtest\\testjpg", "黑体", 36, Color.white, 80,      
                0, 0, 3f);      
        resize("G:\\imgtest\\testjpg", 500, 500, true);      
    }      
     
    public static int getLength(String text) {      
        int length = 0;      
        for (int i = 0; i < text.length(); i++) {      
            if (new String(text.charAt(i) + "").getBytes().length > 1) {      
                length += 2;      
            } else {      
                length += 1;      
            }      
        }      
        return length / 2;      
    }      
}     
  
分享到:
评论

相关推荐

    java图片处理 文字水印 图片水印 缩放 补白

    第二种是添加图片水印和文字水印两种方法,水印图片可以是GIF,PNG透明的文件,我一般采用的是PNG的,因为它的质量和GIF相比要高一些; 适用人群:Java开发者 使用场景:版权信息标注 目标:可以直接拿来用

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

    在这个实例中,我们将探讨如何在Java中实现文字水印、图片水印、图像缩放以及补白功能。以下是一些关键知识点: 1. **Java AWT 和 Swing 图形库**: Java中的`java.awt`和`javax.swing`包提供了丰富的图形用户界面...

    Java图片处理技术

    在Java编程语言中,处理...综上所述,这段代码展示了Java如何利用AWT库进行图片处理,包括添加图片和文字水印,以及处理透明度和定位。这些都是Java图形处理的基本技术,对于开发涉及图像编辑和处理的应用非常有用。

    scratch少儿编程逻辑思维游戏源码-Pyorovania.zip

    scratch少儿编程逻辑思维游戏源码-Pyorovania.zip

    scratch少儿编程逻辑思维游戏源码-弹力猫.zip

    scratch少儿编程逻辑思维游戏源码-弹力猫.zip

    scratch少儿编程逻辑思维游戏源码-地心引力.zip

    scratch少儿编程逻辑思维游戏源码-地心引力.zip

    基于金枪鱼群优化算法的SVM在多变量时间序列预测中的MATLAB实现及优化

    内容概要:本文介绍了一种基于金枪鱼群优化算法(TSO)和支持向量机(SVM)的混合算法模型——TSO-SVM,在多变量时间序列预测中的应用。文中详细解释了TSO-SVM的工作原理,即通过模拟金枪鱼群觅食行为来优化SVM的参数,从而提升预测性能。同时提供了具体的Matlab代码实现步骤,包括参数初始化、模型训练和预测。实验结果显示,TSO-SVM相较于传统SVM方法,显著提升了预测的准确性和稳定性,并展示了良好的泛化能力。 适合人群:对机器学习尤其是时间序列预测感兴趣的科研人员和技术开发者。 使用场景及目标:①需要进行多变量时间序列预测的研究项目;②希望利用自然启发式优化算法改善现有SVM模型效果的技术团队。 其他说明:推荐使用Libsvm工具箱配合Matlab 2018B及以上版本,仅限于Windows 64位操作系统。

    机器视觉技术:OpenCV与Qt在工业相机采集及图像处理中的应用

    内容概要:本文深入探讨了机器视觉技术,重点介绍了OpenCV和Qt在工业相机采集及图像处理中的应用。文中详细讲述了卡尺工具、找线、找圆、颜色检测、模板匹配及形状匹配等关键技术的具体实现方法,并特别强调了海康工业相机采集与基于形状的模板匹配界面的开发。此外,形状匹配算法已被封装成DLL,方便直接调用。通过实际案例和技术解析,帮助读者全面掌握机器视觉系统的构建。 适合人群:对机器视觉感兴趣的初学者、有一定编程基础的研发人员、从事工业自动化领域的工程师。 使用场景及目标:适用于希望深入了解机器视觉技术及其应用场景的专业人士,旨在提升图像处理能力,优化工业自动化流程,提高生产效率。 其他说明:文章不仅提供理论知识,还附有示例代码,便于读者动手实践并加深理解。

    scratch少儿编程逻辑思维游戏源码-Billy奇妙之旅.zip

    scratch少儿编程逻辑思维游戏源码-Billy奇妙之旅.zip

    电动汽车BMS电池管理系统应用层软件模型:MBD方法、通信协议及AUTOSAR构建

    内容概要:本文详细介绍了基于模型开发(MBD)的BMS电池管理系统应用层软件模型。首先概述了BMS的核心任务,即确保电池的安全与高效运行,涉及充电、放电控制、实时监测和电池均衡管理。接着重点讨论了SUMlink电池管理系统策略模型,该模型通过收集和处理电池的数据(如电压、电流、温度),并运用多种算法(如SOC估算、SOH评估)来优化电池性能。文中还阐述了BMC CVS内部通讯协议DBC的作用,确保各模块间数据传输的准确性与效率。最后,介绍了AUTOSAR标准在BMS系统中的应用,特别是针对MPC5644A芯片的底层Build工程,提高了系统的可维护性、可扩展性和可靠性。此外,提到了INCA A2L标定文件的应用,用于配置和调整系统参数,以满足不同需求。 适合人群:从事电动汽车电池管理系统研究与开发的技术人员,尤其是对MBD方法、通信协议和AUTOSAR标准感兴趣的工程师。 使用场景及目标:适用于希望深入了解BMS系统的设计原理和技术细节的专业人士,旨在提高他们对该领域的理解和实际操作能力。 其他说明:通过对代码的具体分析,读者能够更加直观地理解BMS的工作流程及其各个组件间的协作关系。

    少儿编程scratch项目源代码文件案例素材-深海困境.zip

    少儿编程scratch项目源代码文件案例素材-深海困境.zip

    少儿编程scratch项目源代码文件案例素材-去吧泡泡糖.zip

    少儿编程scratch项目源代码文件案例素材-去吧泡泡糖.zip

    KEPServerEX6-6.17.269.0

    KEPServerEX6-6.17.269.0,最新版

    scratch少儿编程逻辑思维游戏源码-第二个循环.zip

    scratch少儿编程逻辑思维游戏源码-第二个循环.zip

    少儿编程scratch项目源代码文件案例素材-手里剑.zip

    少儿编程scratch项目源代码文件案例素材-手里剑.zip

    少儿编程scratch项目源代码文件案例素材-山地跳跃.zip

    少儿编程scratch项目源代码文件案例素材-山地跳跃.zip

    机器人路径规划中Informed RRT*算法详解与代码实现

    内容概要:本文详细介绍了Informed RRT*算法及其在机器人路径规划领域的应用。文章首先解释了该算法相较于传统RRT*算法的优势,即通过将采样范围限制在由起点和终点构成的椭圆区域内来提高搜索效率。接着,文中提供了具体的代码实现,包括椭圆采样的核心公式、路径优化的rewire步骤以及动态调整邻居半径的方法。此外,还讨论了路径队列管理和椭圆区域随路径优化动态更新的重要性。通过这些技术手段,Informed RRT*能够在找到初始路径后显著加快优化速度。 适合人群:对机器人路径规划感兴趣的科研人员、工程师及学生。 使用场景及目标:适用于需要高效路径规划的实际应用场景,如自动驾驶汽车、无人机飞行路径规划等。目标是在复杂环境中快速找到从起点到终点的最佳路径。 其他说明:建议读者在理解理论的基础上,结合提供的代码进行实验,以便更好地掌握算法的工作机制。同时,在不同环境条件下测试算法性能,观察其自适应能力。

    基于COMSOL有限元仿真的变压器辐射传热数值分析:从入门到进阶

    内容概要:本文详细介绍了基于COMSOL有限元软件的变压器辐射传热数值分析方法。首先,解释了变压器内外辐射传热的基本机理,包括热量通过传导、对流和辐射的方式传递,重点在于辐射传热的作用及其数学描述。接着,逐步引导读者从零开始构建有限元仿真模型,涵盖模型参数确定、网格划分、材料属性定义、边界条件设置、传热方程设定、仿真运行及结果分析等多个步骤。最后,探讨了进一步研究的方向,如不同因素(温度、材料属性、几何形状)对辐射传热的影响,以及该模型在电力电子设备和热管理系统的潜在应用。 适合人群:电气工程专业学生、初学者和技术爱好者,尤其是对有限元仿真和变压器辐射传热感兴趣的群体。 使用场景及目标:适用于希望通过实际操作掌握有限元仿真技能的人群,旨在帮助他们理解变压器辐射传热机制并能独立完成相关仿真项目。 其他说明:本文不仅提供了理论知识,还附带了详细的视频教程和仿真模型,使学习过程更加直观易懂。

    scratch少儿编程逻辑思维游戏源码-Scratch 奔跑.zip

    scratch少儿编程逻辑思维游戏源码-Scratch 奔跑.zip

    scratch少儿编程逻辑思维游戏源码-超级马里奥兄 回放引擎.zip

    scratch少儿编程逻辑思维游戏源码-超级马里奥兄 回放引擎.zip

Global site tag (gtag.js) - Google Analytics