在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美

當前位置:雨林木風下載站 > 應用軟件教程 > 詳細頁面

微信小程序通過保存圖片分享到朋友圈的技巧完成

微信小程序通過保存圖片分享到朋友圈的技巧完成

更新時間:2025-09-25 文章作者:未知 信息來源:網絡 閱讀次數:

微信小程序,簡稱小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應用。小程序是一種不用下載就能使用的應用,也是一...
微信小程序,簡稱小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或搜一下即可打開應用。小程序是一種不用下載就能使用的應用,也是一項門檻非常高的創新,經過將近兩年的發展,已經構造了新的小程序開發環境和開發者生態。
這篇文章主要介紹了關于微信小程序通過保存圖片分享到朋友圈的功能實現,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

小程序內是不能直接分享到朋友圈的。所以只能通過生成圖片,攜帶小程序二維碼,保存到手機相冊,讓用戶自己選擇發到朋友圈。然后可以通過在小程序中識別二維碼來進入小程序的指定頁面。下面小編給大家分享實現代碼,需要的朋友參考下吧

說明

首先說明一點,小程序內是不能直接分享到朋友圈的。所以只能通過生成圖片,攜帶小程序二維碼,保存到手機相冊,讓用戶自己選擇發到朋友圈。然后可以通過在小程序中識別二維碼來進入小程序的指定頁面。參考市面上支持分享的應用,基本都是這種實現方式。

準備階段

1.通過服務器獲取小程序碼

這里可以參考下微信的官方文檔,給后臺指定的參數和路徑等信息,讓后臺生成指定的小程序碼。然后調用wx.getImageInfo將后臺生成的小程序碼保存起來。

注意一定要仔細看下微信的文檔,如果生成小程序碼的路徑正式服務器不存在,將會生成失敗。這點也很蛋疼,很不方便調試。

wx.getImageInfo({            
  src:'https://xxx.jpg',//服務器返回的帶參數的小程序碼地址
  success: function (res) {
    //res.path是網絡圖片的本地地址
    qrCodePath = res.path;
  },
  fail: function (res) {
    //失敗回調
  }
});

1.通過canvas繪制所需信息

準備好所有的圖片之后就可以通過canvas繪制了,然后再將canvas導出為圖片。關于繪制這塊,可以參考微信的canvas api,下面的基本都是查著api的方法走的。

其中需要注意的有幾點。

1.是不知道繪出來的文字長度,所以不知道文字到底什么時候該換行,所以針對商品標題,可能多行的數據固定了一行18個字符。

2.是關于繪制圖片的導出,按照官方api的說法應該在draw()完成的回調中執行,但是通過

canvasCtx.draw(false,function(res){
});

這種方式,一直不回調完成。不知道哪里出問題了。所以最后只好加了一個延時去保存圖片。

/**
 * 繪制分享的圖片
 * @param goodsPicPath 商品圖片的本地鏈接
 * @param qrCodePath 二維碼的本地鏈接
 */
drawSharePic: function (goodsPicPath, qrCodePath) {
  wx.showLoading({
    title: '正在生成圖片...',
    mask: true,
  });
  //y方向的偏移量,因為是從上往下繪制的,所以y一直向下偏移,不斷增大。
  let yOffset = 20;
  const goodsTitle = this.data.orderDetail.paltProduct.name1;
  let goodsTitleArray = [];
  //為了防止標題過長,分割字符串,每行18個
  for (let i = 0; i < goodsTitle.length / 18; i++) {
    if (i > 2) {
      break;
    }
    goodsTitleArray.push(goodsTitle.substr(i * 18, 18));
  }
  const price = this.data.orderDetail.price;
  const marketPrice = this.data.orderDetail.marketPrice;
  const title1 = '您的好友邀請您一起分享精品好貨';
  const title2 = '立即打開看看吧';
  const codeText = '長按識別小程序碼查看詳情';
  const imgWidth = 780;
  const imgHeight = 1600;

  const canvasCtx = wx.createCanvasContext('shareCanvas');
  //繪制背景
  canvasCtx.setFillStyle('white');
  canvasCtx.fillRect(0, 0, 390, 800);
  //繪制分享的標題文字
  canvasCtx.setFontSize(24);
  canvasCtx.setFillStyle('#333333');
  canvasCtx.setTextAlign('center');
  canvasCtx.fillText(title1, 195, 40);
  //繪制分享的第二行標題文字
  canvasCtx.fillText(title2, 195, 70);
  //繪制商品圖片
  canvasCtx.drawImage(goodPicPath, 0, 90, 390, 390);
  //繪制商品標題
  yOffset = 490;
  goodsTitleArray.forEach(function (value) {
    canvasCtx.setFontSize(20);
    canvasCtx.setFillStyle('#333333');
    canvasCtx.setTextAlign('left');
    canvasCtx.fillText(value, 20, yOffset);
    yOffset += 25;
  });
  //繪制價格
  yOffset += 8;
  canvasCtx.setFontSize(20);
  canvasCtx.setFillStyle('#f9555c');
  canvasCtx.setTextAlign('left');
  canvasCtx.fillText('¥', 20, yOffset);
  canvasCtx.setFontSize(30);
  canvasCtx.setFillStyle('#f9555c');
  canvasCtx.setTextAlign('left');
  canvasCtx.fillText(price, 40, yOffset);
  //繪制原價
  const xOffset = (price.length / 2 + 1) * 24 + 50;
  canvasCtx.setFontSize(20);
  canvasCtx.setFillStyle('#999999');
  canvasCtx.setTextAlign('left');
  canvasCtx.fillText('原價:¥' + marketPrice, xOffset, yOffset);
  //繪制原價的刪除線
  canvasCtx.setLineWidth(1);
  canvasCtx.moveTo(xOffset, yOffset - 6);
  canvasCtx.lineTo(xOffset + (3 + marketPrice.toString().length / 2) * 20, yOffset - 6);
  canvasCtx.setStrokeStyle('#999999');
  canvasCtx.stroke();
  //繪制最底部文字
  canvasCtx.setFontSize(18);
  canvasCtx.setFillStyle('#333333');
  canvasCtx.setTextAlign('center');
  canvasCtx.fillText(codeText, 195, 780);
  //繪制二維碼
  canvasCtx.drawImage(qrCodePath, 95, 550, 200, 200);
  canvasCtx.draw();
  //繪制之后加一個延時去生成圖片,如果直接生成可能沒有繪制完成,導出圖片會有問題。
  setTimeout(function () {
    wx.canvasToTempFilePath({
      x: 0,
      y: 0,
      width: 390,
      height: 800,
      destWidth: 390,
      destHeight: 800,
      canvasId: 'shareCanvas',
      success: function (res) {
        that.setData({
          shareImage: res.tempFilePath,
          showSharePic: true
        })
        wx.hideLoading();
      },
      fail: function (res) {
        console.log(res)
        wx.hideLoading();
      }
    })
  }, 2000);
},

最后看下繪制出來的效果圖。

微信小程序通過保存圖片分享到朋友圈的功能實現

生成圖片之后就可以提示用戶去保存分享了。

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

關于微信小程序的選擇器(時間,日期,地區)的解析

關于微信小程序收藏功能的實現

微信小程序之點贊和刪除列表以及分享的功能實現

以上就是微信小程序通過保存圖片分享到朋友圈的功能實現的詳細內容,更多請關注php中文網其它相關文章!


小程序是一種不需要下載安裝即可使用的應用,它實現了應用“觸手可及”的夢想,用戶掃一掃或者搜一下即可打開應用。

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美
  • <li id="86scu"><menu id="86scu"></menu></li>
    <li id="86scu"></li>
    <button id="86scu"></button>
  • <s id="86scu"></s><button id="86scu"><menu id="86scu"></menu></button>
  • 国产精品一色哟哟| 欧美 日韩 激情| 日日摸天天爽天天爽视频| 丰满少妇大力进入| 中文字幕人妻熟女人妻洋洋| 4444在线观看| 欧美午夜性视频| 日韩欧美不卡在线| 成熟了的熟妇毛茸茸| 国产极品在线视频| av动漫免费看| 手机av在线免费| 亚洲热在线视频| 国产片侵犯亲女视频播放| 欧美精品在欧美一区二区| 久久www视频| 久久婷婷国产精品| mm131国产精品| 99热一区二区三区| 少妇高潮喷水在线观看| 欧美 日韩 国产 激情| 日韩va在线观看| 人妻激情另类乱人伦人妻| 成人毛片视频网站| 不卡中文字幕在线观看| 国产精品www在线观看| 少妇无码av无码专区在线观看| 国产情侣av自拍| 女同性恋一区二区| 丁香啪啪综合成人亚洲| а 天堂 在线| 免费看国产一级片| 亚洲乱码国产一区三区| 神马午夜伦理影院| 国产视频一区二区视频| 小说区视频区图片区| 免费无码av片在线观看| 日本特级黄色大片| 超碰影院在线观看| 欧美成人精品免费| 成人高清在线观看视频| 国产成人精品视频免费看| 国产又大又长又粗又黄| 天天碰免费视频| 你真棒插曲来救救我在线观看| 九色porny自拍| 精品99在线视频| 日韩av在线播放不卡| 色香蕉在线观看| 蜜臀一区二区三区精品免费视频 | 国产无限制自拍| 欧美 日韩 国产 在线观看| 欧美精品第三页| 欧美精品一区免费| 国产av人人夜夜澡人人爽麻豆| 天天做天天爱天天高潮| 日本黄色的视频| 奇米视频888| 日本 片 成人 在线| 91热这里只有精品| 欧美私人情侣网站| caopor在线视频| 十八禁视频网站在线观看| 一本大道熟女人妻中文字幕在线| 野外做受又硬又粗又大视频√| 妞干网这里只有精品| 国产树林野战在线播放| 黄色片免费在线观看视频| 视色,视色影院,视色影库,视色网 日韩精品福利片午夜免费观看 | 茄子视频成人免费观看| 国产精品亚洲αv天堂无码| av动漫在线看| 久草在在线视频| 亚洲综合婷婷久久| 亚洲精品视频三区| 国产91porn| 拔插拔插海外华人免费| 亚欧无线一线二线三线区别| 北条麻妃av高潮尖叫在线观看| 91看片就是不一样| 男生操女生视频在线观看| 一区二区三区四区久久| 国产美女永久无遮挡| 国产成人亚洲精品无码h在线| 亚洲少妇第一页| 无套内谢丰满少妇中文字幕| 国产黄色激情视频| 日韩中文字幕免费在线| 波多野结衣三级在线| 成人网站免费观看入口| 中文字幕第80页| 法国空姐在线观看免费| 成人在线免费在线观看| 国产传媒免费观看| 日韩中文字幕在线视频观看| 日本中文字幕二区| 波多野结衣综合网| 九九九九九九九九| 成人在线观看你懂的| 在线能看的av网站| 一女被多男玩喷潮视频| 亚洲涩涩在线观看| 日日鲁鲁鲁夜夜爽爽狠狠视频97| 欧美国产日韩另类| 女人扒开屁股爽桶30分钟| 少妇高潮大叫好爽喷水| 日本免费观看网站| 天堂…中文在线最新版在线| 免费黄频在线观看| 中文字幕国产传媒| 波多野结衣之无限发射| 9色视频在线观看| 五月天婷婷影视| 不要播放器的av网站| 男人添女人下面高潮视频| 中文字幕第50页| 在线免费观看av网| 向日葵污视频在线观看| 国内自拍在线观看| 蜜桃传媒一区二区三区| 99视频精品全部免费看| 欧美日韩在线免费观看视频| 欧美日韩一区二区三区69堂| 日本xxxxxxx免费视频| 欧美日韩性生活片| 缅甸午夜性猛交xxxx| 国产精品久久国产| 日韩一二区视频| 国产激情在线看| 国产精品videossex国产高清 | 拔插拔插海外华人免费| a天堂资源在线观看| 毛片av在线播放| 久久久久久人妻一区二区三区| 欧美中日韩在线| 久激情内射婷内射蜜桃| 日韩欧美国产免费| www日韩视频| 蜜臀一区二区三区精品免费视频| 婷婷免费在线观看| 超碰91在线播放| 国产精品va在线观看无码| 久草视频这里只有精品| 日韩精品―中文字幕| 任你操这里只有精品| 久久国产精品国产精品| 天天综合成人网| 免费的av在线| 精品一区二区中文字幕| 亚洲一级免费在线观看| 亚洲热在线视频| 玩弄中年熟妇正在播放| 亚洲色图 在线视频| 青青草原网站在线观看| 久久久久久久久久久视频| 国产aaaaa毛片| 九一免费在线观看| 日韩精品一区二区三区色欲av| 青青草原国产在线视频| 无码av天堂一区二区三区| 999精品网站| 国产一二三四区在线观看| 免费观看日韩毛片| 青娱乐国产精品视频| 日本中文字幕网址| 婷婷中文字幕在线观看| 欧美综合在线播放| 国产免费中文字幕| 国模杨依粉嫩蝴蝶150p| 18视频在线观看娇喘| 国产超碰在线播放| 日韩在线综合网| 777久久精品一区二区三区无码| 日韩视频免费在线播放| 免费网站在线观看视频| 久热精品在线播放| 免费观看日韩毛片| 欧美一区二区激情| 成年人黄色在线观看| 老头吃奶性行交视频| 日本福利视频在线| 人人妻人人澡人人爽欧美一区双| 国内国产精品天干天干| 免费在线激情视频| 黄色国产一级视频| 久久艹国产精品| 欧美性猛交内射兽交老熟妇| 成人免费黄色av| 日韩欧美亚洲另类| 久久久久久蜜桃一区二区| 国产一级特黄a大片免费| 97国产精东麻豆人妻电影| 成年人网站国产| www.国产在线视频| 美女扒开大腿让男人桶| 男女啪啪免费视频网站| av免费看网址| 亚洲自偷自拍熟女另类| 欧美日韩黄色一级片| 欧美极品欧美精品欧美图片|