uniapp定制小程序码+海报

需求

1.生成微信小程序自定义参数二维码
2.将二维码拼接背景图生成活动海报保存至相册


效果图

文末已发布代码,有需要请自行获取,如若有问题欢迎交流

开发环境

服务端:php
客户端:uniapp
应用场景:微信小程序

问题

1.怎么生成微信小程序二维码?
2.怎么生成活动海报?

生成小程序二维码-服务端

第一步 获取微信小程序 access_token

https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=?&secret=?

请求方式:POST
请求参数:
appid 微信小程序id
secret 微信小程序密钥
请求返回:
buffer 小程序二维码二维数组
微信官方文档.小程序-获取AccessToken

第二步 获取二维码 Buffer

https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=ACCESS_TOKEN

请求方式:POST
请求参数:
scene 二维码参数
page 二维码打开路径
请求返回:
buffer 小程序二维码二维数组
微信官方文档.小程序-获取二维码

第三步 将buffer转换为base64字节码

微信小程序无法直接将buffer保存到图片,所以最好将其转换为base64字节码,通过转换为base64字节码写入到画布,通过保存画布到相册,即可实现保存海报

客户端

创建活动海报

UI代码

<template>
    <view class="container">
        <view class="contents">
            <canvas class="page-content" canvas-id="shareCanvas" style="width:100%;" :style="{ height: height + 'px' }"></canvas>
        </view>
        <view class="page-bottom flex text-center">
            <button class="cu-btn block bg-orange" @tap="selectImage">选择图片</button>
            <button class="cu-btn block bg-orange" @tap="saveImage">保存图库</button>
        </view>
    </view>
</template>
获取二维码
            const url ="服务器接口地址";
            //加载页面参数
            let  scene = 'id=' + this.id + '&token=' + this.token + '&type=1';
            let params={
              page: 'pages/index/index',
              scene: scene
            }
            uni.request({
                url: url, 
                data: params,
                method: "POST",
                header: {
                    "Content-Type": "application/x-www-form-urlencoded"
                },
                dataType: 'arraybuffer',//请求字节
                success: (res) => {
                    //获取base64 字符串
                    var data=res.data;
                    //拼装base64图片
                    var img='data:image/png;base64,'+data;
                    //调起绘制器
                    this.initImage(img);
                }
            });

*注意事项:
1.由于从微信官方请求下来的图片字节码不带base64数据头,需要自行拼接,如:

var img='data:image/png;base64,'+data;

2.由于全部为字节码建议dataType设置为arraybuffer,这样可以避免请求乱码

绘制画布
uni.getSystemInfo({
                    success: function(e) {
                        console.log(e);
                        //获取屏幕宽高设置画布宽高
                        let width = e.windowWidth;
                        let height= e.screenHeight;
                        that.height=height;
                        let topheight = 320;//图片距离上边距离
                        const ctx = uni.createCanvasContext('shareCanvas');
                        // 底图
                        ctx.drawImage(res[0].path, 0, 0, width, height);
                        //绘制序列从上到下, 通过距离上边高度来排列显示
                        // 文字内容
                        ctx.setTextAlign('center'); // 文字居中
                        ctx.setFillStyle('#F0AD4E'); // 文字颜色:黑色
                        ctx.setFontSize(22); // 文字字号:22px
                        ctx.fillText('双十一活动', width / 2, topheight-30);
                        ctx.setFillStyle('#FFFFFF'); 
                            ctx.setFontSize(20); 
                        ctx.fillText('扫码领取更多奖', width / 2, topheight);
                        // 小程序码
                        const qrImgSize = 140;
                        ctx.drawImage(res[1], (width - qrImgSize) / 2, topheight+15 , qrImgSize, qrImgSize);
                        ctx.stroke();
                        ctx.draw();
                    }
                });

*注意事项:
1.画布组件显示内容为图层,所以为了铺垫元素,需要注意从上到下元素的间距。

保存到相册

const wxCanvasToTempFilePath = tools.promisify(uni.canvasToTempFilePath);
            const wxSaveImageToPhotosAlbum = tools.promisify(uni.saveImageToPhotosAlbum);
            wxCanvasToTempFilePath(
                {
                    canvasId: 'shareCanvas'
                },
                this
            ).then(res => {
                    return wxSaveImageToPhotosAlbum({
                        filePath: res.tempFilePath
                    });
                })
                .then(res => {
                    wx.showToast({
                        title: '已保存到相册'
                    });
                });

项目源码

https://github.com/sunql0827/createposter.git

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343