一级片大奶子_色又黄又爽18禁免费视频_热久久久久久久_久久久精品一区二区_日韩av不卡在线播放_精品国内自产拍在线观看视频

商城系統 注冊

微信小程序canvas圖片及文本適配

2020-09-27|HiShop
導讀:小程序中的繪圖一般是需要canvas來制作完成,那么如何合理利用小程序canvas進行繪圖,并且圖片及文本適配呢。下面一一來解答。...

小程序中的繪圖一般是需要canvas來制作完成,那么如何合理利用小程序canvas進行繪圖,并且圖片及文本適配呢。下面一一來解答。

 

場景需求

小程序目前不支持直接分享到朋友圈,所以對于有分享到朋友圈的需求,一般是生成一張圖片,例如,生成一張帶有小程序碼的圖片,用戶可以將這張圖片保存到手機本地,然后將這張圖片分享到朋友圈。這張圖片需要使用canvas畫出來。

今天我們不講怎么生成碼,這個一般是后端封裝一個API,前端通過調用API得到一個小程序碼的url,通過image去畫到canvas上,跟在canvas上畫一個image是一樣的邏輯。這篇文章主要是講怎么在canvas上適配圖片和文字,也就是怎么將圖片和文本畫到canvas上的正確的位置,能在不同的手機上都能正確的展示。

效果圖展示(以下圖片是在微信開發者工具中顯示的) 
這里演示的Demo是: 
“選擇圖片”button選擇一張圖片,可以居中顯示在以下圖中的黃色區域,即canvas中,并在canvas的頂部居中展示文本“你若盛開,蝴蝶自來”。

微信小程序canvas圖片及文本適配

代碼說明

wxml

 

  1. <button bindtap="chooseImg">選擇圖片</button>
  2. <view class="canvas-box">
  3. <canvas class="canvas" canvas-id="shareCanvas" bindlongtap="saveShareImage"></canvas>
  4. </view>

$3. scss(wxss)  這里我用的是scss去寫樣式代碼,在webStorm中可以通過配置,將scss解析成wxss,至于具體怎么配置,可以自行百度。  PS1:這里定義了一個scss rpx function,是因為在webStrom中格式化代碼的時候會將數字和單位rpx中間添加一個空格,導致編譯報錯,所以用一個function去處理  PS2:樣式說明(設計稿是基于iphone6視覺稿標準):  button寬高:700rpx * 92rpx (350px * 46px)  包裹canvas的容器的view(.canvas-box)position:fixed,占據除頂部button的高度之外,填滿剩余全部空間,canvas居中顯示,寬高:700rpx, 100%

 

  1. @function rpx($value) {
  2. @return $value*1rpx;
  3. }
  4.  
  5. page {
  6. background-color: #fff6f6;
  7. button {
  8. width: rpx(700);
  9. height: rpx(92);
  10. background-color: #ffddab !important;
  11. }
  12. .canvas-box {
  13. position: fixed;
  14. top: rpx(92);
  15. left: 0;
  16. right: 0;
  17. bottom: 0;
  18. canvas {
  19. position: absolute;
  20. width: rpx(700);
  21. height: 100%;
  22. top: 50%;
  23. left: 50%;
  24. transform: translate(-50%, -50%);
  25. }
  26. }
  27. }

$4. js  1、在data中定義三個變量

 

  1. data: {
  2. windowWidth: 0, // 可使用窗口寬度
  3. windowHeight: 0, // 可使用窗口高度
  4. ratio: 0 // 根據尺寸動態計算 1px換算成多少rpx
  5. }

2、通過wx.getSystemInfo獲得系統信息,并且計算ratio

 

  1. onReady: function (e) {
  2. // 獲取系統信息
  3. wx.getSystemInfo({
  4. success: res => {
  5. console.log(res);
  6. this.setData({
  7. windowWidth: res.windowWidth,
  8. windowHeight: res.windowHeight,
  9. });
  10. this.setData({
  11. // 屏幕寬度 375px = 750rpx,1px=2rpx
  12. // 1px = (750 / 屏幕寬度)rpx;
  13. // 1rpx = (屏幕寬度 / 750)px;
  14. ratio: 750 / this.data.windowWidth
  15. });
  16. }
  17. });
  18. },

3、button的觸發事件chooseImg,通過wx.chooseImage選擇圖片,通過wx.getImageInfo獲取選擇的圖片的大小

 

  1. chooseImg: function () {
  2. wx.chooseImage({
  3. count: 1,
  4. success: res => {
  5. let imgUrl = res.tempFilePaths[0];
  6. // 獲取圖片大小
  7. wx.getImageInfo({
  8. src: imgUrl,
  9. success: data => {
  10. let imgWidth = data.width;
  11. let imgHeight = data.height;
  12.  
  13. // 創建canvas,根據選擇的圖片大小,在canvas上繪制圖片和文字
  14. this.createCanvasShareImage(imgUrl, imgWidth, imgHeight);
  15. }
  16. });
  17. }
  18. });
  19. }

4、創建canvas并在canvas上添加圖片和文本

 

  1. createCanvasShareImage: function (imgUrl, imgW, imgH) {
  2. // 使用wx.createCanvasContext獲取繪圖上下文 context
  3. let context = wx.createCanvasContext('shareCanvas');
  4. console.log('context: ', context);
  5.  
  6. // 獲取canvas的寬度:
  7. // 750的設計稿基于iphone6的尺寸(屏幕寬度: 375px)在小程序中的比例是: 1px = 2rpx ==> 375px = 750rpx ==> 屏幕寬度(px) = 750rpx
  8. // 所以 1rpx = 屏幕寬度 / 750
  9. // 我們這里css中設置的 canvas 的width:700rpx, 所以 canvas的寬度計算是: [(屏幕寬度 / 750)* 700]rpx, 這樣就可以做到在不同手機上都可以適配
  10. let canvasWidthPx = 700 / this.data.ratio;
  11.  
  12. // 設置 canvas 的背景并填充canvas
  13. context.fillStyle = '#ffdc22';
  14. context.fillRect(0, 0, canvasWidthPx, this.data.windowHeight);
  15.  
  16. // 繪制圖片:圖片居中顯示在 canvas 中
  17. let imgX = (700 - imgW) / 2;
  18. let imgY = (this.data.windowHeight * this.data.ratio - 46 * this.data.ratio - imgH) / 2;
  19. let clipWidth = imgW * this.data.ratio;
  20. let clipHeight = imgH * this.data.ratio;
  21. context.drawImage(imgUrl, -imgX, -imgY, clipWidth, clipHeight, 0, 0, imgW, imgH);
  22.  
  23. // 設置字體大小、文本顏色
  24. context.setFontSize(20);
  25. context.fillStyle = "#000";
  26.  
  27. // 計算文本的寬度:measureText() 取到文本的 width
  28. let txtWidth = context.measureText('你若盛開,蝴蝶自來').width;
  29.  
  30. // 繪制居中文本:這個地方的 (x, y)的坐標是在文本的左下角位置
  31. context.fillText("你若盛開,蝴蝶自來", (canvasWidthPx - txtWidth) / 2, 20 * this.data.ratio);
  32.  
  33. context.draw();
  34. }

5、長按bindlongtapcanva保存圖片或者直接預覽圖片,先通過wx.canvasToTempFilePath將當前畫布指定區域的內容導出生成指定大小的的圖片,再通過wx.saveImageToPhotosAlbum將圖片保存到本地,或者通過wx.previewImage直接預覽圖片。

 

  1. saveShareImage() {
  2. wx.canvasToTempFilePath({
  3. canvasId: 'shareCanvas',
  4. success: (res) => {
  5. console.log('canvasToTempFilePath: ', res);
  6. // 將圖片保存到相冊
  7. wx.saveImageToPhotosAlbum({
  8. filePath: res.tempFilePath,
  9. success: (data) => {
  10. console.log(data);
  11. }
  12. });
  13.  
  14. // 直接預覽圖片
  15. wx.previewImage({
  16. urls: [res.tempFilePath]
  17. })
  18. }
  19. })
  20. }

 

電話咨詢 預約演示 0元開店
主站蜘蛛池模板: 黄网免费看|成人毛片观看|人妻精品久久无码专区涩涩|一个人在线观看www高清视频|草裙社区精品视频三区|亚洲精品乱码久久久久久金桔影视 | 免费色综合|极品的亚洲|C=aOPROM国产在线视频|色伊人网站|国产精品=a一|97午夜影院 | 偷看农村女人做爰毛片色|亚洲成人=av在线播放|国内视频一区|国产三级黄色|久久色亚洲|91精选国产 | 五月婷婷开心中文字幕|亚洲专区一区二区三区|日韩三级黄色|超碰人人c=ao|久久97超碰色中文字幕|久在草影院 | 激情小说亚洲色图|我要干成人网|久久国产免费看|最新国产成人|久久免费影视|黄瓜视频网址 | 六月婷婷缴清综合在线|国内精品亚洲|无码成人=a=a=a=a=a毛片专区调教|成年人快播|西西人体44WWW高清大胆|久久久高潮 | 美女裸乳裸体无遮挡的网站|在线观看不卡视频|免费午夜看片|亚洲精品日韩一|一级中国黄色片|国产亚洲精久久久久久叶玉卿 | 日韩三级在线免费观看|久久艹艹|色爱综合另类图片=av|国内久久精品视频|xx69在线观看|亚洲国产一区二区精品 | 国产www成人|干干操操|国产久一一精品|日韩综合在线播放|二区视频|九九国产视频 | 8050午夜一级毛片|欧洲熟妇精品视频|亚洲在线视频网站|天天久久精品视频|亚洲综合在线网址|麻豆极品JK丝袜自慰喷水久久 | 国产成人精品高清在线观看99|亚州综合网|亚洲视频观看|新国产美女遭强高潮免费|奇米777在线观看|蜜臀=avwww国产天堂 | 中文乱码人妻一区二区三区视频|亚洲高清专区|中文毛片无遮挡高潮免费|黄人成=a动漫片免费网站|99re在线免费|女乱淫免费看视频大黄 | 最近中文字幕在线mv视频在线|#NAME?|色惰网站|草逼一区|免费精品国产的网站免费观看|播放日韩一级黄色片 | 一区二区三区精液|成人二区三区|99精品国产99久久久久久97|久久久久久高清毛片|亚洲啊啊啊啊啊|亚洲人成亚洲精品 | 国产视频资源|日日摸久久久精品|男人午夜视频|山外人精品影院|一区二区三区=av夏目彩春|久久网精品三级片 | 日本真人边吃奶边做爽免费视频|麻豆中文字幕|九色porny丨首页入口在线|亚洲黄色片一级|2024韩国三级午夜理论|尤物一区二区 | 蜜臀91精品一区二区三区|亚洲中出视频|啪啪玩小处雏女|精品日韩一区二区|久久婷婷综合色丁香五月|亚洲视频在线观看网站 | 天天操人人插|欧日韩在线|色一区二区三区四区|国产一在线观看|亚洲精品福利片|#NAME? | 浓毛欧美老妇乱子伦视频|中文字幕丰满伦子无码|黄色片视频在线观看|亚洲视频综合|久草手机视频在线观看|91日韩国产 | 色综合久久蜜芽国产精品|中国国产精品|国产黄色的视频|风间由美无打码在线观看|欧美日韩国产精品久久久久|最新中文字幕免费视频 | 亚洲一级毛片免费观看|欧美韩日一区|WWW内射国产在线观看|奇米精品一区二区三区在线观看|99久久亚洲|国产成人精品亚洲线观看 | 日本=a一级|国产亚洲精品精|中国女人特级毛片|蜜乳=av一区二区三区|欧美群妇大交群的观看方式|日一区二区三区 | 日日爽天天操|亚洲=aV永久无码精品一区二区|免费精品视频在线观看|日本高清色视频www·com|国产成人麻豆免费观看|色一情一区二 | 国产精品第一页在线播放|久久精品人人人人人人|亚洲精品一区久久久久一品=aV|欧美7777|美女全身赤裸裸免费网站|在线视频三区 | 97久久精品人人澡人人爽|亚洲人成图片小说网站|99久久精品毛片免费播放高潮|夜夜操网站|三区在线|69看片 | 成本人片在线观看免费网站|成年人视频网站在线|夜趣福利视频|免费观看的=av在线播放|亚洲欧美偷国产日韩|四虎.com | CONDOM色孩交VIDEOS精品|#NAME?|四虎永久在线精品8848=a|三级在线观看国产|日韩久久成人|大学生一级一片第一次野外 | 日本一区二区影视|久久人人97超碰超国产|ssswww免费|久久爱在线播放视频|国产三级视屏|国产精品久久久久久久久久久免费看 | 精选久久久|#NAME?|亚洲日本香蕉视频观看视频|钻石午夜影院|中文字幕第23页在线|成人午夜免费看 | 中文字幕在线视频2019|欧美第一页草草影院|天天操天天射日本人|国产高清在线露脸一区|自拍性旺盛老熟女|九九视频大全 | 天海翼一区二区|黄色片高清视频|午夜激情一区二区|chinese激烈高潮hd|色精品国产|中文字幕视频网 | 欧美一区二区三区视频在线观看|日韩不卡高清|成人午夜视频无码免费视频|一道本道加勒比天天看|欧美成年人视频在线观看|日本中文字幕乱码免费 51久久夜色精品国产水果派解说|国产欧美日韩视频免费|国产96在线亚洲|人妻无码中文字幕免费视频蜜桃|成人=a片产无码免费视频奶头鸭度|亚洲已满18点击进入在线看片 | 一区二区三区日韩视频在线观看|日韩欧美在线观看一区|91精品一区二区三区久久|FREEZEFR=aME丰满人妻|亚洲=aV无码一区二区二三区|欧美综合区自拍亚洲综合绿色 | 久久精品九九热无码免贵|日本=aⅴ精品一区二区三区|亚洲国产精品一区二区成人片|国产精品91久久|久草=av在线播放|亚洲在线www | 亚洲人成77777在线播放网站|逼逼久久|亚洲最大成人网4388xx|国产=a级黄色录像|日韩高清国产一区在线|无码综合天天久久综合网色吧影院 | #NAME?|久久精品一二三影院|91看剧|欧美性色欧美=a在线视频|五月婷婷激情六月|成人免费一级=a久久 | 亚洲久久综合|久久伊甸园|青草国产超碰人人添人人碱|91资源在线播放|九九九免费观看视频|又黄又爽的免费视频 | 肉体裸体xxxxx免费观看|国产乱妇乱子在线播放视频|日本免费无遮挡毛片的意义|国产无套乱子伦精彩无码视频|国产一区二区h|亚洲色图网址 | 黄网免费看|成人毛片观看|人妻精品久久无码专区涩涩|一个人在线观看www高清视频|草裙社区精品视频三区|亚洲精品乱码久久久久久金桔影视 | 大内密探零性|国产美女自拍小视频|久久久久久久综合狠狠综合|九九热免费精品|性=a毛片|午夜免费啪啪 | 免费无码黄网站在线看|九九在线精品视频|h黄动漫免费网站|成人小说亚洲一区二区三区|极品老师腿张开粉嫩小泬|婷婷开心中文字幕 |