小程序分享图片(JAVA+小程序端)

第一次做小程序海报分享,感觉canvas还是有点难度的。

所以用了JAVA后端生成,JAVA用了 ImageCombiner 组件去开发,整体来说感觉还是便捷很多的。

复制代码
<dependency>
    <groupId>com.freewayso</groupId>
    <artifactId>image-combiner</artifactId>
    <version>2.6.5</version>
</dependency>

具体使用的话看连接:https://gitee.com/dromara/image-combiner/#12-imagecombiner%E8%83%BD%E5%A4%9F%E5%81%9A%E4%BB%80%E4%B9%88

下面我把关键代码加一下:

复制代码
//文件的话,放在static静态目录即可。 
BufferedImage bf= ImageIO.read(ImageUtil.class.getResource("/static/share.jpg"));
//linux环境的话,是没有中文字体的,需要将字体也一起打包进入jar包里面
        String path="/Alibaba-PuHuiTi-Regular.ttf";
        ImageCombiner combiner = new ImageCombiner(bf, OutputFormat.JPG);
        combiner.addTextElement("xxxxx",path, 60, 180, 100);
        //组合图片
        combiner.combine();
        //生成bufferImage,返回
        BufferedImage combinedImage = combiner.getCombinedImage();
        return combinedImage;

在controller端的话

复制代码
@GetMapping("/getOrderShareImg")
    public void loadShare(Long id, HttpServletResponse response) throws Exception {
        //业务查询逻辑
        OrderVo ncOrderVo = orderService.queryById(id);
        //拿到outputStream,
      
        ServletOutputStream os = response.getOutputStream();
        BufferedImage bufferedImage = ImageUtil.genImage(ncOrderVo);

         //write即可

        ImageIO.write(bufferedImage,"jpg",os);
        os.close();
    }

小程序端的话

javascript 复制代码
wx.downloadFile({
    url: request.BASE_URL+'api/wxapp/getOrderShareImg?id='+this.data.order.id, // 下载url
    success (res) {
      // 下载完成后转发
      wx.showShareImageMenu({
        path: res.tempFilePath,
        success() {},
        fail: console.error,
      })
    },
    fail: console.error,
  })
相关推荐
win x40 分钟前
Redis 使用~如何在Java中连接使用redis
java·数据库·redis
星晨雪海1 小时前
基于 @Resource 的支付 Service 多实现类完整示例
java·开发语言
阿维的博客日记1 小时前
什么是逃逸分析
java·juc
河北清兮网络科技1 小时前
短剧 APP 产品说明
小程序·uni-app·短剧
Ricky_Theseus1 小时前
C++右值引用
java·开发语言·c++
Rick19932 小时前
Java内存参数解析
java·开发语言·jvm
我是大猴子2 小时前
Spring代理类为何依赖注入失效?
java·后端·spring
勿忘,瞬间2 小时前
多线程之进阶修炼
java·开发语言
014-code2 小时前
线程池参数怎么配才不翻车
java
吴梓穆2 小时前
UE5 c++ 常用方法
java·c++·ue5