Graphics2D绘制多图片水印方法

/***@paramsrcPath需要添加水印的完整地址*@paramids需要添加的水印的id集合,结果以”,”分隔*@return返回包含水印图片的输入流*@throwsException*/publicInputStreamaddWatermark(StringsrcPath,Str…

大家好,又见面了,我是你们的朋友全栈君。

还有一篇文章添加多种水印(文字水印(带背景颜色) +图片水印)大家可以看一下、
https://blog.csdn.net/whiteGu/article/details/97653571

/**
     * @param srcPath 需要添加水印的完整地址
     * @param ids     需要添加的水印的id集合 ,结果以 ","分隔
     * @return 返回包含水印图片的输入流
     * @throws Exception
     */
    public InputStream addWatermark(String srcPath, String ids) throws Exception {
        File waterFile1 = null;
        File waterFile2 = null;
        Image watermarkImage1 = null;
        Image watermarkImage2 = null;
        String fileSuffix = srcPath.substring(srcPath.lastIndexOf(".") + 1);
        if (StringUtils.isBlank(ids)) throw new BaseAppException("必传水印id");
        List<SysWatermark> sysWatermarks = Arrays.stream(ids.split(",")).map(x -> sysWatermarkService.getByPrimaryKey(x)
        ).collect(Collectors.toList());
        if (CollectionUtils.isEmpty(sysWatermarks)) throw new BaseAppException("没有对应的水印模板");

        //获取图片路径
        String waterImagePath1 = imgPrefix + sysWatermarks.get(0).getWatermarkUrl();
        File srcFile = new File(srcPath);
        waterFile1 = new File(waterImagePath1);
        if (sysWatermarks.size() > 1) {
            String waterImagePath2 = imgPrefix + sysWatermarks.get(1).getWatermarkUrl();
            waterFile2 = new File(waterImagePath2);
        }
        //读取原图片
        try {
            Image srcImage = ImageIO.read(srcFile);
            int height = srcImage.getHeight(null);
            int width = srcImage.getWidth(null);
            if (width > 1000 || height > 1000) {
                throw new BaseAppException("图片大小最大不能大于1000*1000");
            }
            //准备画板
            BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
            //创建画笔
            Graphics2D graphics = bufferedImage.createGraphics();
            graphics.drawImage(srcImage, width, height, null);
            //读取水印
            Image temp1 = ImageIO.read(waterFile1);
            ImageIcon imageIcon1 = new ImageIcon(temp1);
            watermarkImage1 = imageIcon1.getImage();
            //读取第二张水印
            if (null != waterFile2) {
                Image temp2 = ImageIO.read(waterFile2);
                ImageIcon imageIcon2 = new ImageIcon(temp2);
                watermarkImage2 = imageIcon2.getImage();
            }
            //第一张水印图片的透明度
            watermarkCoordinate(graphics, sysWatermarks.get(0), watermarkImage1, width, height);
            //处理第二张水印(如果是多水印可以采用循环方式,由于我这里只会有2张水印所以写死了)
            if (null != watermarkImage2) {
                watermarkCoordinate(graphics, sysWatermarks.get(1), watermarkImage2, width, height);
            }
            graphics.dispose();
             //本地测试
            OutputStream outputStream = new FileOutputStream("D:/test.jpg");
            ImageIO.write(bufferedImage, "JPG", outputStream);
            //本地测试结束(如果是本地测试下面不需要)
            ByteArrayOutputStream os = new ByteArrayOutputStream();
            ImageIO.write(bufferedImage, fileSuffix, os);
            return new ByteArrayInputStream(os.toByteArray());
        } catch (IOException e) {
            e.printStackTrace();
            throw new BaseAppException("读取图片失败");
        }
    }

    /**
     * 添加水印管理
     *
     * @param graphics     画笔
     * @param sysWatermark 水印
     * @param image        水印图片
     * @param width        需要添加水印图的宽度
     * @param height       需要添加水印图的高度
     */
    private void watermarkCoordinate(Graphics2D graphics, SysWatermark sysWatermark, Image image, int width, int height) {
        float transparency = sysWatermark.getWatermarkTransparency() / 100;
        graphics.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_ATOP, transparency));
        //放上水印图
        String coordinate = sysWatermark.getWatermarkCoordinate();
        JSONObject parseObject = JSONObject.parseObject(coordinate);
        int watermarkWidth = (int) parseObject.get("width");
        int watermarkHeight = (int) parseObject.get("height");
        graphics.drawImage(image, width * watermarkWidth / 100, height * watermarkHeight / 100, null);
    }

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/129084.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月13日 上午6:40
下一篇 2022年4月13日 上午6:40


相关推荐

  • 哈希查找算法

    哈希查找算法哈希查找算法哈希查找算法又称散列查找算法 是一种借助哈希表 散列表 查找目标元素的方法 查找效率最高时对应的时间复杂度为 O 1 哈希查找算法适用于大多数场景 既支持在有序序列中查找目标元素 也支持在无序序列中查找目标元素 讲解哈希查找算法之前 我们首先要搞清楚什么是哈希表 哈希表是什么哈希表 Hashtable 又称散列表 是一种存储结构 通常用来存储多个元素 和其它存储结构 线性表 树等 相比 哈希表查找目标元素的效率非常高 每个存储到哈希表中的元素 都配有一个唯一的标识 又称 索引 或者

    2026年3月18日
    3
  • 字符串常量池_字符串常量池溢出

    字符串常量池_字符串常量池溢出我们知道字符串的分配和其他对象分配一样,是需要消耗高昂的时间和空间的,而且字符串我们使用的非常多。JVM为了提高性能和减少内存的开销,在实例化字符串的时候进行了一些优化:使用字符串常量池。每当我们创建字符串常量时,JVM会首先检查字符串常量池,如果该字符串已经存在常量池中,那么就直接返回常量池中的实例引用。如果字符串不存在常量池中,就会实例化该字符串并且将其放到常量池中。由于String字符串…

    2022年7月28日
    12
  • ORA-12560: TNS: 协议适配器错误 解决方法[通俗易懂]

    ORA-12560: TNS: 协议适配器错误 解决方法[通俗易懂]前言&nbsp;&nbsp;&nbsp;&nbsp;我在控制台重启oracle服务端监听lsnrctlstart的时候&nbsp;&nbsp;&nbsp;&nbsp;报错:ORA-12560:TNS:协议适配器错误解决方法&nbsp;&nbsp;&nbsp;&nbsp;一:检查监听口是否开启。在开始-运行,输入services.msc或者在控制面板-管理工具,进入服务。找…

    2022年6月17日
    106
  • pycharm安装pygame库遇到问题怎么办?

    pycharm安装pygame库遇到问题怎么办?新手在 pycharm 安装其他第三方库时非常顺利 安装 pygame 库却遇到问题 安装失败时软件提示原因可能大都与 version 有关 可以试一下下面这个简单有效方法 希望有帮助

    2026年3月19日
    2
  • 排序算法汇总总结

    排序算法汇总总结

    2021年12月2日
    49
  • APP 安全测试(OWASP Mobile Top 10)–后篇之一

    APP 安全测试(OWASP Mobile Top 10)–后篇之一OWASPMobileTop10相对于Web的OWASPTop10来说,个人觉得描述的相对简单多,并且安全测试的时候的可操作性也不是太强。本来打算个人整体捋一遍的,但因为项目时间的问题,前面四个章节安排给了别人去负责,我只负责后面的六章(所以标题写了后篇)。下面我把个人的测试方法简单叙述一下。下面可能有些测试点不全或者有瑕疵,欢迎纠错。。。。OWASPM…

    2022年5月7日
    165

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号