微信小程序 canvas 生成图片保存本地 并分享至朋友圈

上代码

                                  第一步 页面引入  canvas    添加 ID

     css

核心部分 js   

canvasView: function (object) {

   // console.log(object)

    let _seif = this;

    wx.getSystemInfo({

      success: function (res) {

        var v = 750 / res.windowWidth;//设计稿尺寸除以  当前手机屏幕宽度

        function shiftSize(w) {

          return w / v;

        };

        // 画图适配

        const ctx = wx.createCanvasContext('Canvas', _seif);


        //内容部分

         ctx.save();

         ctx.drawImage('../../images/bj.png', 0, 0, 500,3000); //绘制图片

        /****

         * 

         * 

         * 头像

         * 

        */

        ctx.save();

        ctx.beginPath() //开始创建一个路径

        ctx.arc(shiftSize(250), 50, 30, 0, 2 * Math.PI); //画一个圆形裁剪区域

        ctx.setStrokeStyle('#ef5756');

        ctx.stroke('#ef5756');

        ctx.clip();//裁剪 

        ctx.drawImage(object.avatarUrl, shiftSize(190), 20, 60, 60); //绘制图片

        ctx.restore(); //恢复之前保存的绘图上下文

        //姓名

        ctx.save();

        ctx.setFillStyle("#ffffff");

        ctx.setFontSize(12);

        ctx.setTextAlign('center');

        ctx.fillText(object.nickName, shiftSize(250), 100);

        ctx.save();

        ctx.setFillStyle("#ffffff");

        ctx.setFontSize(10)

        ctx.fillText('分享想买清单', shiftSize(250), 116);

        //内容部分

        ctx.save();

        ctx.setFillStyle('#fff');

        ctx.fillRect(shiftSize(10), 130, shiftSize(480), object.goodsVos.length * 28.5 + object.goodsVos.length);

        //主播

        ctx.save();

        ctx.setFillStyle("#333");

        ctx.setFontSize(10)

        ctx.setTextAlign('left');

        ctx.fillText(object.title, 10, 146);

        ctx.save();

        ctx.setFillStyle("#a4a4a4");

        ctx.setFontSize(10);

        console.log(object)


        ctx.fillText(object.types=='00' ? '主播口述' :object.types=='01' ? '官方正式' : '', 10, 164);

        ctx.setFillStyle("#a4a4a4");

        ctx.setFontSize(10);

        ctx.fillText('更新时间' + object.syncTime + '' + object.times, shiftSize(250), 164);

        //商品列表

        let index = 28;

        ctx.save();

        for (let i = 0; i < object.goodsVos.length; i++) {

          ctx.save();

          ctx.setFillStyle("#333");

          ctx.setFontSize(10)

          ctx.fillText(i+1+'、', shiftSize(16) , 186 + (i * index));

          ctx.save();

          ctx.setFillStyle("#333");

          ctx.setFontSize(10);

          if(object.goodsVos[i].name.length>17){

            ctx.fillText(object.goodsVos[i].name.substring(0,17)+'...', shiftSize(50), 186 + (i * index));

          }else{

            ctx.fillText(object.goodsVos[i].name.substring(0,17), shiftSize(50), 186 + (i * index));

          }


          ctx.stroke();

          //线  

          ctx.save();

          ctx.moveTo(shiftSize(10), 194 + (i * index));

          ctx.lineTo(shiftSize(488), 194 + (i * index));

          ctx.setLineWidth(1);

          ctx.setStrokeStyle('#f4f4f4');

          ctx.stroke();

          //想买 按钮

          if (object.goodsVos[i].isFollow == "E") {

            ctx.save();

            ctx.drawImage('../../images/icon/love.png', shiftSize(410), 176 + (i * index), 14, 14); //绘制图片

            ctx.setFillStyle("#fa475e");

            ctx.setFontSize(10);

            ctx.fillText('想买', shiftSize(444), 186 + (i * index));

          }

        }

        // 二维码

        ctx.save();

        // ctx.beginPath() //开始创建一个路径

        // ctx.arc(shiftSize(264), (_seif.data.view.goodsVos.length * 31.52) + _seif.data.view.goodsVos.length, 50, 0, 2 * Math.PI) //画一个圆形裁剪区域

        // ctx.setStrokeStyle('#000')

        // ctx.stroke();

        // ctx.clip();//裁剪

        ctx.drawImage('../../images/code.png', shiftSize(160), (object.goodsVos.length * 30) +140, 100, 100); //绘制图片

        ctx.restore(); //恢复之前保存的绘图上下文'

        ctx.save();

        ctx.setFillStyle("#ffffff")

        ctx.fillText('长按图片识别小程序码', shiftSize(160), (object.goodsVos.length * 30) + 260)

        ctx.draw(true, function () {

          setTimeout(() => {

            wx.canvasToTempFilePath({ //写在 draw的回调里面才能生成图片

              canvasId: 'Canvas',

              success: function (res) {

                _seif.setData({

                  imgs: res.tempFilePath

                });

               }

            })

          }, 1000) 

        })

        // 画图适配完

      }

    });

  },

注意  object的数据 格式   可根据需求更改

最后一步  保存到相册

先把微信头像 转化为临时路径  


点击保存到相册


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