武装少女在线观看高清完整版免费,丝袜+亚洲区,少妇被cao高潮呻吟声,午夜伦情电午夜伦情电影,日日躁夜夜躁狠狠躁

小程序模板網(wǎng)

微信小程序 關(guān)于【canvas.drawImage 】完全顯示圖片問(wèn)題

發(fā)布時(shí)間:2018-12-03 10:02 所屬欄目:小程序開(kāi)發(fā)教程

問(wèn)題描述

問(wèn)題產(chǎn)生

對(duì)于微信小程序,canvas處理過(guò)程中,dramImage默認(rèn)圖片引用是有殘缺的

導(dǎo)入初始項(xiàng)目

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

目的

通過(guò)對(duì)canvas繪圖過(guò)程的修改,或者其樣式的修改,達(dá)到完全顯示,并自適應(yīng)不同機(jī)型的目的

解決方案

準(zhǔn)備工作

  Page({
   data:{
     imgSrc: '', // 需要處理圖片地址
     imgW: '', // canvas 寬度
     imgH: '', // canvas 高度
     byclear: 1 // 比例,這里將iphon6- 375像素設(shè)置為1標(biāo)準(zhǔn),以便在自適應(yīng)上的轉(zhuǎn)換
   },
   onReady() {
    var that = this
    // 根據(jù)屏幕的寬度計(jì)算標(biāo)準(zhǔn)比例值。這里講375作為標(biāo)準(zhǔn)值
    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) {
    // 處理邏輯
   }
  })

獲取選擇目標(biāo)圖片的寬高度~

默認(rèn)canvas 是無(wú)法獲取圖片的高度的,再者小程序里面沒(méi)有 new Image()這個(gè)方法,只能通過(guò)標(biāo)簽組件image間接獲取,所以我們需要在wxml中插入一個(gè)隱藏的標(biāo)簽image,隱藏方法我們?cè)O(shè)置display:none 或者h(yuǎn)idden就可以了,注意不要wx:if, wx:if 不會(huì)觸發(fā)bindload事件。

  <image src="{{imgSrc}}" bindload='checkwh' mode='widthFix' hidden/>
  <canvas canvas-id="canvasIn" class="canvas"></canvas>
在方法checkwh里面即可獲取到圖片寬高

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

canvas.scale 方案

dramImage 繪圖方法,我們可以通過(guò)對(duì)畫(huà)布的放大縮小scale來(lái)完整繪制,繼續(xù)在checkwh中進(jìn)行處理.scale縮放比例很簡(jiǎn)單,我們只要計(jì)算出屏幕與圖片的實(shí)際比例,對(duì)應(yīng)縮小就可。即:375 * byclear / e.detail.width 這里要帶上自適應(yīng)比例,當(dāng)然對(duì)于圖片寬度小于屏幕的我們不做縮放處理

  checkwh(e){
     // 實(shí)際寬度 e.detail.width 高度 e.detail.height
    let whsrc = e.detail.height / e.detail.width
     // 計(jì)算高寬,需要處理圖片寬度大于屏幕寬度的時(shí)候 對(duì)應(yīng)的canvas比例
    let res = this.data.res 
    let byclear = this.data.byclear
    const ctx = wx.createCanvasContext('canvasIn', this);
    // 對(duì)畫(huà)布進(jìn)行縮放,注意scale兩個(gè)參數(shù)保持一致,即縮放比例都是一樣的。保證寬高比一致
    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()
    // 后續(xù)操作
  }

上面我們已經(jīng)完整的將圖片繪制到canvas中了,還不夠,下面我們將設(shè)置設(shè)置canvas寬高大小,已達(dá)到完全展示

  <canvas canvas-id="canvasIn" class="canvas" style="width:{{imgW}}rpx;height:{{imgH}}rpx;margin:0 auto;">
  </canvas>

微信自適應(yīng)單位是rpx,對(duì)于iphone 6 ,375px = 750rpx => 1px = 2rpx; 其他型號(hào)計(jì)算是帶上比例byclear即可,然后圖片小于屏幕寬度,不做處理,checkwh后續(xù)代碼
因此:

  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方案對(duì)比scale方案,比較好的地方在于,不用計(jì)算canvas的大小,也不用縮放比例,直接將原圖的寬高設(shè)置成canvas的寬高,然后,通過(guò)zoom對(duì)canvas進(jìn)行縮放,直接放代碼額,這里的縮放比例,即為 圖片寬度 / 750,注意這里不需要比例計(jì)算,css樣式會(huì)自動(dòng)進(jìn)行樣式比率計(jì)算
關(guān)鍵wxml代碼

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

關(guān)鍵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
    })
  }


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開(kāi)源 碼云倉(cāng)庫(kù):starfork
本文地址:http://www.kknew.com.cn/wxmini/doc/course/24986.html 復(fù)制鏈接 如需定制請(qǐng)聯(lián)系易優(yōu)客服咨詢(xún):800182392 點(diǎn)擊咨詢(xún)
QQ在線咨詢(xún)
AI智能客服 ×