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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 关于0xffffffff 到底是什么意思?

    关于0xffffffff 到底是什么意思?0x16进制一个f代表4个1, 所以就是2进制的32个1.但是运行一下下面这个代码就会发现输出的是-1#includeusingnamespacestd;intmain(){inti=0xffffffff;cout<

    2022年5月17日
    176
  • RTSP协议学习笔记

    RTSP协议学习笔记第一部分:RTSP协议一、       RTSP协议概述RTSP(Real-TimeStreamProtocol)是一种基于文本的应用层协议,在语法及一些消息参数等方面,RTSP协议与HTTP协议类似。RTSP被用于建立的控制媒体流的传输,它为多媒体服务扮演“网络远程控制”的角色。尽管有时可以把RTSP控制信息和媒体数据流交织在一起传送,但一般情况RTSP本身并不用于转送媒体流数据

    2025年8月13日
    2
  • 迷你MVVM框架 avalonjs 学习教程13、模板引用

    迷你MVVM框架 avalonjs 学习教程13、模板引用

    2021年9月1日
    60
  • 知识图谱构建技术综述-2.3知识推理-学习笔记「建议收藏」

    知识图谱构建技术综述-2.3知识推理-学习笔记「建议收藏」文章信息:文章末尾目录2.3节知识推理2.3.1基于规则的推理2.3.2基于分布式特征表示推理(1)基于翻译模型的知识推理(2)基于张量分解的知识推理(3)基于语义匹配模型的知识推理2.3.3基于深度学习的推理2.3节知识推理知识推理:根据已有的实体关系来推断出新的事实结论。知识推理研究分析分为3种:2.3.1基于规则的推理包含:谓词逻辑推理、本体推理和随机推理。【63】等提出一阶归纳学习就是谓词逻辑推理,可以自动提取高质量的事实并去噪

    2022年5月30日
    31
  • docker部署web项目_docker web管理工具

    docker部署web项目_docker web管理工具前言前面我们运行的容器并没有一些什么特别的用处。接下来让我们尝试使用docker构建一个web应用程序。我们将在docker容器中运行一个PythonFlask应用来运行一个web

    2022年7月29日
    7
  • 有什么办法可以实时监控微信_微信被监控有什么特征

    有什么办法可以实时监控微信_微信被监控有什么特征如何同步员工微信聊天记录,员工微信监控管理?这就教你如何操作!企业员工微信怎么更好管理?如何微信监控聊天记录?工作手机管理系统实现员工企业微信聊天全程记录,敏感行为词全程监控,敏感行为监督,私单,飞

    2022年8月6日
    5

发表回复

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

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