中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2020-09-03 11:07:36 來源:腳本之家 閱讀:426 作者:ereror 欄目:web開發

問題描述

問題產生

對于微信小程序,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" ></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" ></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
 })
 },

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

友谊县| 昭苏县| 博客| 巨野县| 武宁县| 宁海县| 宁德市| 公主岭市| 伊宁市| 弋阳县| 柯坪县| 阳信县| 互助| 雷波县| 望城县| 乐东| 奉贤区| 东莞市| 蛟河市| 吴堡县| 宁河县| 扬州市| 上高县| 舒城县| 莱西市| 越西县| 彭州市| 阳春市| 河南省| 体育| 镇坪县| 南漳县| 肥东县| 洛浦县| 景德镇市| 海门市| 伊通| 泉州市| 固原市| 福鼎市| 乐山市|