欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年11月30日 11:50:00   作者:ereror  
這篇文章主要介紹了微信小程序canvas.drawImage完全顯示圖片問題的解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

問題描述

問題產(chǎn)生

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

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

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

目的

通過對(duì)canvas繪圖過程的修改,或者其樣式的修改,達(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 是無法獲取圖片的高度的,再者小程序里面沒有 new Image()這個(gè)方法,只能通過標(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 繪圖方法,我們可以通過對(duì)畫布的放大縮小scale來完整繪制,繼續(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ì)畫布進(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á)到完全展示

復(fù)制代碼 代碼如下:
<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的寬高,然后,通過zoom對(duì)canvas進(jìn)行縮放,直接放代碼額,這里的縮放比例,即為 圖片寬度 / 750,注意這里不需要比例計(jì)算,css樣式會(huì)自動(dòng)進(jìn)行樣式比率計(jì)算

關(guān)鍵wxml代碼

復(fù)制代碼 代碼如下:
<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
 })
 },

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 微信小程序的部署方法步驟

    微信小程序的部署方法步驟

    這篇文章主要介紹了微信小程序的部署方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • Object.keys?詭異特性示例詳解

    Object.keys?詭異特性示例詳解

    這篇文章主要介紹了Object.keys?詭異特性示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 微信小程序?qū)崿F(xiàn)多列選擇器

    微信小程序?qū)崿F(xiàn)多列選擇器

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)多列選擇器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • js繼承的實(shí)現(xiàn)代碼

    js繼承的實(shí)現(xiàn)代碼

    學(xué)著js的繼承,自己也寫了個(gè)。感覺不是很好?,F(xiàn)在很多代碼都封裝成類。
    2010-08-08
  • 運(yùn)用js實(shí)現(xiàn)圖層拖拽的功能

    運(yùn)用js實(shí)現(xiàn)圖層拖拽的功能

    js拖拽是常見的網(wǎng)頁(yè)效果,本文將從零開始實(shí)現(xiàn)一個(gè)簡(jiǎn)單的js插件,下面和小編來一起學(xué)習(xí)一下吧
    2019-05-05
  • JavaScript數(shù)據(jù)類型的存儲(chǔ)方法詳解

    JavaScript數(shù)據(jù)類型的存儲(chǔ)方法詳解

    JavaScript中基本數(shù)據(jù)類型和引用數(shù)據(jù)類型是如何存儲(chǔ)的呢?下面通過本文給大家分享js數(shù)據(jù)類型的存儲(chǔ)方法,需要的朋友參考下吧
    2017-08-08
  • 微信小程序連接服務(wù)器展示MQTT數(shù)據(jù)信息的實(shí)現(xiàn)

    微信小程序連接服務(wù)器展示MQTT數(shù)據(jù)信息的實(shí)現(xiàn)

    這篇文章主要介紹了微信小程序連接服務(wù)器展示MQTT數(shù)據(jù)信息的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 基于JavaScript實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng)

    基于JavaScript實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Javascript中的async awai的用法

    Javascript中的async awai的用法

    本篇文章主要介紹了Javascript中的async/awai的用法,將分享async / await是如何工作的,有興趣的可以了解一下
    2017-05-05
  • 通過隱藏iframe實(shí)現(xiàn)無刷新上傳文件操作

    通過隱藏iframe實(shí)現(xiàn)無刷新上傳文件操作

    本文給大家介紹iframe無刷新上傳文件,通過一個(gè)隱藏的iframe來處理上傳操作我采用的是ReactJS,amazeui,nodejs1.html target指向iframe的name,就是把上傳后的操作交給iframe來處理
    2016-03-03

最新評(píng)論