麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 課堂 > 小程序 > 正文

微信小程序canvas.drawImage完全顯示圖片問題的解決

2020-03-21 16:05:48
字體:
來源:轉載
供稿:網友

問題描述

問題產生

對于微信小程序,canvas處理過程中,dramImage默認圖片引用是有殘缺的

導入初始項目

打開鏈接(原官網例子),瀏覽器喚醒微信開發這工具,打開連接之前需要下載好微信開發者工具,如已安裝則直接喚起,沒有則會提示下載

目的

通過對canvas繪圖過程的修改,或者其樣式的修改,達到完全顯示,并自適應不同機型的目的

解決方案

準備工作

 Page({ data:{  imgSrc: '', // 需要處理圖片地址  imgW: '', // canvas 寬度  imgH: '', // canvas 高度  byclear: 1 // 比例,這里將iphon6- 375像素設置為1標準,以便在自適應上的轉換 }, onReady() { var that = this // 根據屏幕的寬度計算標準比例值。這里講375作為標準值 wx.getSystemInfo({  success: function(res) {  let byclear = res.screenWidth / 375  that.setData({   byclear  })  }, }) }, openAndDraw() { // 選擇圖片 var that = this wx.chooseImage({  success: (res) => {  that.setData({   imgSrc: res.tempFilePaths[0],   res  })  } }) }, checkwh(e) { // 處理邏輯 } })

獲取選擇目標圖片的寬高度~

默認canvas 是無法獲取圖片的高度的,再者小程序里面沒有 new Image()這個方法,只能通過標簽組件image間接獲取,所以我們需要在wxml中插入一個隱藏的標簽image,隱藏方法我們設置display:none 或者hidden就可以了,注意不要wx:if, wx:if 不會觸發bindload事件。

<image src="{{imgSrc}}" bindload='checkwh' mode='widthFix' hidden/><canvas canvas-id="canvasIn" class="canvas"></canvas>

在方法checkwh里面即可獲取到圖片寬高

 checkwh(e){  // 實際寬度 e.detail.width 高度 e.detail.height  let whsrc = e.detail.height / e.detail.width  // 計算高寬,需要處理圖片寬度小于屏幕寬度的時候 對應的canvas比例   }

canvas.scale 方案

dramImage 繪圖方法,我們可以通過對畫布的放大縮小scale來完整繪制,繼續在checkwh中進行處理.scale縮放比例很簡單,我們只要計算出屏幕與圖片的實際比例,對應縮小就可。即:375 * byclear / e.detail.width 這里要帶上自適應比例,當然對于圖片寬度小于屏幕的我們不做縮放處理

 checkwh(e){  // 實際寬度 e.detail.width 高度 e.detail.height let whsrc = e.detail.height / e.detail.width  // 計算高寬,需要處理圖片寬度大于屏幕寬度的時候 對應的canvas比例 let res = this.data.res  let byclear = this.data.byclear const ctx = wx.createCanvasContext('canvasIn', this); // 對畫布進行縮放,注意scale兩個參數保持一致,即縮放比例都是一樣的。保證寬高比一致 if (e.detail.width > 375 * byclear) ctx.scale(375 * byclear / e.detail.width, 375 * byclear / e.detail.width); ctx.drawImage(res.tempFilePaths[0], 0, 0, e.detail.width, e.detail.height) ctx.draw() // 后續操作 }

上面我們已經完整的將圖片繪制到canvas中了,還不夠,下面我們將設置設置canvas寬高大小,已達到完全展示

 

復制代碼代碼如下:
<canvas canvas-id="canvasIn" class="canvas" style="width:{{imgW}}rpx;height:{{imgH}}rpx;margin:0 auto;"></canvas>

 

微信自適應單位是rpx,對于iphone 6 ,375px = 750rpx => 1px = 2rpx; 其他型號計算是帶上比例byclear即可,然后圖片小于屏幕寬度,不做處理,checkwh后續代碼

因此:

 checkwh(e){ // 前面代碼...  this.setData({  imgW: e.detail.width > 375 ? 750 : e.detail.width * 2 / byclear,  imgH: e.detail.width > 375 ? 750 * whsrc : e.detail.height * 2 / byclear  }) }

canvas 縮放 zoom 方案

zoom方案對比scale方案,比較好的地方在于,不用計算canvas的大小,也不用縮放比例,直接將原圖的寬高設置成canvas的寬高,然后,通過zoom對canvas進行縮放,直接放代碼額,這里的縮放比例,即為 圖片寬度 / 750,注意這里不需要比例計算,css樣式會自動進行樣式比率計算

關鍵wxml代碼

 

復制代碼代碼如下:
<canvas canvas-id="canvasIn" class="canvas" style="width:{{imgW}}rpx;height:{{imgH}}rpx;margin:0 auto;zoom:{{imgW > 750 ? 750 / imgW : 1}}"></canvas>

 

關鍵js代碼

 checkwh(e){ var vhsrc = e.detail.height / e.detail.width let res = this.data.res let byclear = this.data.byclear const ctx = wx.createCanvasContext('canvasIn', this); ctx.drawImage(res.tempFilePaths[0], 0, 0, e.detail.width, e.detail.height) ctx.draw() this.setData({  imgW: e.detail.width * 2 / byclear,  imgH: e.detail.height * 2 / byclear }) },

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 午夜视频你懂的 | 369看片你懂的小视频在线观看 | 狠狠干五月| www.99av| 激情视频在线播放 | 日美av在线| 久久成人精品视频 | 久久精品日产高清版的功能介绍 | 无遮挡一级毛片视频 | 成人毛片av在线 | 精品在线免费播放 | 国产亚洲精彩视频 | 国产午夜亚洲精品午夜鲁丝片 | 国产免费黄色 | 啪啪激情 | 免费一级毛片在线播放视频 | 午夜精品福利视频 | 欧美另类视频在线 | 国产午夜免费不卡精品理论片 | 久久久久久久久久久久久久av | 中文字幕在线观看免费 | 亚洲αv| 久久亚洲精选 | 成人偷拍片视频在线观看 | 欧美日韩免费一区 | 国产毛片视频 | 久久精品成人影院 | 国产污污视频 | 亚洲综合网站 | 久久免费观看一级毛片 | 禁漫天堂久久久久久久久久 | 国产jjizz一区二区三区视频 | 热re91久久精品国产99热 | 久久狠狠高潮亚洲精品 | 午夜久久久精品一区二区三区 | 欧美视频一区二区 | 毛片免费观看视频 | 久久久久久片 | 久久第四色 | 特片网久久 | 国产精品久久久久久影院8一贰佰 |