返回顶部
首页 > 资讯 > 精选 >java后端合成图片如何实现
  • 848
分享到

java后端合成图片如何实现

2023-07-02 09:07:38 848人浏览 薄情痞子
摘要

本篇内容介绍了“java后端合成图片如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!环境jdk1.8Spring Boot搭建引入po

本篇内容介绍了“java后端合成图片如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

环境

搭建

引入pom文件

<dependency>    <groupId>com.freewayso</groupId>    <artifactId>image-combiner</artifactId>    <version>2.2.0</version></dependency>

定义核心接口ImageService

public interface ImageService {        InputStream generateSimpleImage(String text, String bgImageUrl, String todoImage, String localPath, Boolean saveLocal, Boolean saveOss);        InputStream generateComplexImage(String title, String content, String bgImageUrl, String qrCodeUrl, String productImageUrl, String waterMarkImageUrl, String avatarImageUrl, String localPath, Boolean saveLocal, Boolean saveOss);}

定义核心接口实现类ImageServiceImpl

@Servicepublic class ImageServiceImpl implements ImageService {    @Override    public InputStream generateSimpleImage(String text, String bgImageUrl, String todoImage, String localPath, Boolean saveLocal, Boolean saveOss) {        InputStream is = null;        try{            // 合成器(指定背景图和输出格式,整个图片的宽高和相关计算依赖于背景图,所以背景图的大小是个基准)            ImageCombiner combiner = new ImageCombiner(bgImageUrl, OutputFORMat.JPG);            // 加图片元素,第二个参数是左边界距,第三个参数是上边距            combiner.addImageElement(todoImage, 300, 300);            // 加文本元素,第二个参数是字体大小,第三个参数是左边界距,第四个参数是上边距            combiner.addTextElement(text, 60, 100, 960);            // 执行图片合并            combiner.combine();            // 可以获取流(并上传oss等)            is = combiner.getCombinedImageStream();            // 保存到本地            if(saveLocal){                combiner.save(localPath);            }            // 保存到oss            if(saveOss){                // TODO: 2021/12/17 保存到oss            }        }catch (Exception e){            e.printStackTrace();        }        return is;    }    @Override    public InputStream generateComplexImage(String title, String content, String bgImageUrl, String qrCodeUrl, String productImageUrl, String waterMarkImageUrl, String avatarImageUrl, String localPath, Boolean saveLocal, Boolean saveOss) {        InputStream is = null;        try{            BufferedImage waterMark = ImageIO.read(new URL(waterMarkImageUrl)); //水印图            BufferedImage avatar = ImageIO.read(new URL(avatarImageUrl));       //头像            //创建合成器(指定背景图和输出格式,整个图片的宽高和相关计算依赖于背景图,所以背景图的大小是个基准)            ImageCombiner combiner = new ImageCombiner(bgImageUrl, 1500, 0, ZoomMode.Height, OutputFormat.JPG);  //v1.1.4之后可以指定背景图新宽高了(不指定则默认用图片原宽高)            //针对背景和整图的设置            combiner.setBackgroundBlur(30);     //设置背景高斯模糊(毛玻璃效果)            combiner.setcanvasRoundCorner(100); //设置整图圆角(输出格式必须为PNG)            //标题(默认字体为阿里普惠、黑色,也可以自己指定Font对象)            combiner.addTextElement(title, 0, 150, 1400)                    .setCenter(true)        //居中绘制(会忽略x坐标,改为自动计算)                    .setAlpha(.8f)         //透明度(0.0~1.0)                    .setRotate(45)         //旋转(0~360)                    .setColor(Color.red);    //颜色            //内容(设置文本自动换行,需要指定最大宽度(超出则换行)、最大行数(超出则丢弃)、行高)            combiner.addTextElement(content, "微软雅黑", 40, 150, 1480)                    .setStrikeThrough(true)             //删除线                    .setAutoBreakLine(837, 2, 60);      //自动换行            //商品图(设置坐标、宽高和缩放模式,若按宽度缩放,则高度按比例自动计算)            combiner.addImageElement(productImageUrl, 0, 160, 837, 0, ZoomMode.Width)                    .setCenter(true)       //居中绘制(会忽略x坐标,改为自动计算)                    .setRoundCorner(46);     //设置圆角            //头像(圆角设置一定的大小,可以把头像变成圆的)            combiner.addImageElement(avatar, 200, 1200)                    .setRoundCorner(200);   //圆角            //水印(设置透明度,0.0~1.0)            combiner.addImageElement(waterMark, 630, 1200)                    .setAlpha(.8f)         //透明度(0.0~1.0)                    .setRotate(45)         //旋转(0~360)                    .setBlur(20);           //高斯模糊(1~100)            //加入圆角矩形元素(版本>=1.2.0),作为二维码的底衬            combiner.addRectangleElement(138, 1707, 300, 300)                    .setColor(Color.WHITE)                    .setRoundCorner(50)     //该值大于等于宽高时,就是圆形,如设为300                    .setAlpha(.8f);            //二维码(强制按指定宽度、高度缩放)            combiner.addImageElement(qrCodeUrl, 138, 1707, 186, 186, ZoomMode.WidthHeight);            //价格(元素对象也可以直接new,然后手动加入待绘制列表)            TextElement textPrice = new TextElement("¥1290", 60, 230, 1300);            textPrice.setColor(Color.red);          //红色            textPrice.setStrikeThrough(true);       //删除线            combiner.addElement(textPrice);         //加入待绘制集合            //执行图片合并            combiner.combine();            //可以获取流(并上传oss等)            is = combiner.getCombinedImageStream();            //保存到本地            if(saveLocal){                combiner.save(localPath);            }            //保存到oss            if(saveOss){                // TODO: 2021/12/17 保存到oss            }        }catch (Exception e){            e.printStackTrace();        }        return is;    }}

测试ImageController

@RestController@Slf4jpublic class ImageController {    @Resource    httpservletResponse response;    @Autowired    ImageService imageService;        @GetMapping("/createSimpleImage")    public void createSimpleImage(){        OutputStream os = null;        try {            String text = "周末大放送";            String bgImageUrl = "Https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg";            String todoImage = "https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg";            // 图片流            InputStream is = imageService.generateSimpleImage(text, bgImageUrl, todoImage,"",false,false);            BufferedImage image = ImageIO.read(is);            response.setContentType("image/png");            os = response.getOutputStream();            if (image != null) {                ImageIO.write(image, "png", os);            }        } catch (IOException e) {            e.printStackTrace();            log.error("获取图片异常{}",e.getMessage());        } finally {            if (os != null) {                try {                    os.flush();                    os.close();                }catch (Exception e){                    e.printStackTrace();                }            }        }    }        @GetMapping("/createComplexImage")    public void createComplexImage(){        // 背景图        String bgImageUrl = "https://cube.elemecdn.com/6/94/4d3ea53c084bad6931a56d5158a48jpeg.jpeg";        // 二维码        String qrCodeUrl = "https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg";        // 商品图        String productImageUrl = "https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg";        // 水印图        String waterMark = "https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg";        // 头像        String avatar = "https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg";        // 标题文本        String title = "# 最爱的家居";        // 内容文本        String content = "苏格拉底说:“如果没有那个桌子,可能就没有那个水壶”";        OutputStream os = null;        try{            // 图片流            InputStream is = imageService.generateComplexImage(title, content, bgImageUrl, qrCodeUrl, productImageUrl, waterMark, avatar,"",false,false);            BufferedImage image = ImageIO.read(is);            response.setContentType("image/png");            os = response.getOutputStream();            if (image != null) {                ImageIO.write(image, "png", os);            }        }catch (Exception e){            e.printStackTrace();        }finally {            if (os != null) {                try {                    os.flush();                    os.close();                }catch (Exception e){                    e.printStackTrace();                }            }        }    }}

测试效果

java后端合成图片如何实现

“java后端合成图片如何实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: java后端合成图片如何实现

本文链接: https://lsjlt.com/news/341115.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • java后端合成图片如何实现
    本篇内容介绍了“java后端合成图片如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!环境jdk1.8spring boot搭建引入po...
    99+
    2023-07-02
  • java后端合成图片的实现示例
    目录场景环境搭建引入pom文件定义核心接口ImageService定义核心接口实现类ImageServiceImpl测试ImageController测试效果总结场景 前端有一个神器...
    99+
    2024-04-02
  • Java实现图片合成的示例详解
    目录场景环境搭建引入pom文件定义核心接口ImageService定义核心接口实现类ImageServiceImpl测试ImageController测试效果总结场景 前端有一个神器...
    99+
    2024-04-02
  • Python如何实现多张图片合成一张马赛克图片
    这篇文章将为大家详细讲解有关Python如何实现多张图片合成一张马赛克图片,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。图片素材4K高清原图开发环境Python 3.6Pycharm实现代码先导入所需模块...
    99+
    2023-06-22
  • Python实现视频分解成图片+图片合成视频
    目录一、python视频拆分+图片合成(源码一)1.python视频拆分2.python图片合成二、python视频拆分+图片合成(源码二)三、python视频拆分(源码三)一、py...
    99+
    2024-04-02
  • Python如何实现合并多张图片成视频
    本篇内容介绍了“Python如何实现合并多张图片成视频”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!合并多张图片到视频的方法说明除了使用 O...
    99+
    2023-07-05
  • javascript如何实现图片移动端
    这篇文章主要介绍“javascript如何实现图片移动端”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“javascript如何实现图片移动端”文章能帮助大家解决问题。首先,要实现图片的移动,我们需要...
    99+
    2023-07-06
  • Python如何实现多张图片合成文字的效果
    本篇内容主要讲解“Python如何实现多张图片合成文字的效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python如何实现多张图片合成文字的效果”吧!一、图片批量下载首先我们需要从百度下载大...
    99+
    2023-07-02
  • 基于C#实现图片合成功能
    目录实践过程效果代码实践过程 效果 代码 public partial class Form1 : Form { public Form1() { ...
    99+
    2022-12-23
    C#实现图片合成 C#图片合成 C# 图片
  • java如何生成echarts图片
    要在Java中生成ECharts图片,您可以使用ECharts官方提供的Java工具库echarts-java。以下是生成EChar...
    99+
    2023-09-15
    java
  • Python实现多张图片合成一张马赛克图片
    目录前言开发环境实现代码先导入所需模块读取图片文件读取所有源图片并计算对应颜色平均值合法图像列表平均颜色列表遍历主函数模块调用执行完整效果前言 最近有网友私信我,问如何把多张图片合成...
    99+
    2024-04-02
  • Python怎么实现视频分解成图片及图片合成视频
    这篇文章主要介绍了Python怎么实现视频分解成图片及图片合成视频的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python怎么实现视频分解成图片及图片合成视频文章都会有所收获,下面我们一起来看看吧。一、pyt...
    99+
    2023-06-29
  • 如何实现前端图片懒加载
    这篇文章主要介绍了如何实现前端图片懒加载,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。定义图片懒加载又称图片延时加载、惰性加载,即在用户需要...
    99+
    2024-04-02
  • java后端PayPal支付如何实现
    这篇文章给大家分享的是有关java后端PayPal支付如何实现的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。首先引入 PayPal的sdk 这里我引入的是1.0.4版本的<!-- 贝宝支付&nbs...
    99+
    2023-06-22
  • element-ui如何实现上传图片后清空图片显示
    这篇文章主要为大家展示了“element-ui如何实现上传图片后清空图片显示”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“element-ui如何实现上传图片后...
    99+
    2024-04-02
  • Python如何合并多张图片成PDF
    小编给大家分享一下Python如何合并多张图片成PDF,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!过程拿到一个需求最重要的就是将大块任务拆分成一个个小模块,逐个...
    99+
    2023-06-15
  • 基于Python如何实现合并多张图片转成mp4视频
    这篇文章主要介绍“基于Python如何实现合并多张图片转成mp4视频”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于Python如何实现合并多张图片转成mp4视频”文章能帮助大家解决问题。一、需要...
    99+
    2023-07-06
  • Java实现自动生成缩略图片
    本文实例为大家分享了Java实现自动生成缩略图片的具体代码,供大家参考,具体内容如下 一、自动生成缩略图方法: package writeimg;   import java.awt...
    99+
    2024-04-02
  • js前端如何实现图片懒加载
    这篇文章主要介绍js前端如何实现图片懒加载,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!思路:将页面里所有img属性src属性用data-xx代替,当页面滚动直至此图片出现在可视区域...
    99+
    2024-04-02
  • Python实现合成多张图片到PDF格式
    目录1.准备2.合成原理3.多张照片合成PDF在日常生活中,经常会遇到需要提交身份证正反面证明资料的情况,而且这些网站大部分只接受pdf格式,这时候我们就需要把身份证正反面两张图片合...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作