亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

微信小程序怎么使用canvas自適應屏幕畫海報并保存圖片功能

發布時間:2021-05-20 11:27:42 來源:億速云 閱讀:400 作者:小新 欄目:web開發

這篇文章主要介紹微信小程序怎么使用canvas自適應屏幕畫海報并保存圖片功能,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

我們的在開發中常用的參考屏幕尺寸(iPhone6)為:375*667;

那么想要適應其他尺寸的屏幕時只需按照iPhone6的繪制大小按比例進行換算即可:

獲取系統屏幕尺寸

先利用wx.getSystemInfo (獲取系統信息)的API獲取屏幕寬度,然后除iPhone6的屏幕寬度,即可得到相對單位

// 在onLoad中調用
const that = this
wx.getSystemInfo({
 success: function (res) {
  console.log(res)
  that.setData({
   model: res.model,
   screen_width: res.windowWidth/375,
   screen_height: res.windowHeight
  })
 }
})

在繪制方法中將參數乘以相對單位即可實現自適應

這里的rpx是相對不同屏幕寬度的相對單位,測量出得實際寬度,就是實際測出的px像素值*rpx就可以了;之后無論實在iPhone5,iPhone6,iPhone7...都可以進行自適應。

這里的html也要動態的設置寬和高

<canvas canvas-id="PosterCanvas" ></canvas>
drawPoster(){
  let ctx = wx.createCanvasContext('PosterCanvas'),that=this.data;
  console.log('手機型號' + that.model,'寬'+that.screen_width*375,'高'+ that.screen_height)
  let rpx = that.screen_width
  //這里的rpx是相對不同屏幕寬度的相對單位,實際的寬度測量,就是實際測出的px像素值*rpx就可以了;之后無論實在iPhone5,iPhone6,iPhone7...都可以進行自適應。
  ctx.setFillStyle('#1A1A1A')
  ctx.fillRect(0, 0, rpx * 375, that.screen_height * 1.21)
  ctx.fillStyle = "#E8CDAA";
  ctx.setFontSize(29*rpx)
  ctx.font = 'normal 400 Source Han Sans CN';
  ctx.fillText('Hi 朋友', 133*rpx,66*rpx)
  ctx.fillText('先領禮品再買車', 84*rpx, 119*rpx)
  ctx.drawImage('../../img/sell_index5.png', 26*rpx, 185*rpx, 324*rpx, 314*rpx)
  ctx.drawImage('../../img/post_car2x.png', 66 * rpx, 222 * rpx, 243 * rpx, 145 * rpx)
  ctx.setFontSize(16*rpx)
  ctx.font = 'normal 400 Source Han Sans CN';
  ctx.fillText('長按掃描獲取更多優惠', 108*rpx, 545*rpx)
  ctx.drawImage('../../img/code_icon2x.png', 68 * rpx, 575 * rpx, 79 * rpx, 79 * rpx)
  ctx.drawImage('../../img/code2_icon2x.png', 229 * rpx, 575 * rpx, 79 * rpx, 79 * rpx)
  ctx.setStrokeStyle('#666666')
  ctx.setLineWidth(1*rpx)
  ctx.lineTo(187*rpx,602*rpx)
  ctx.lineTo(187*rpx, 630*rpx)
  ctx.stroke()
  ctx.fillStyle = "#fff"
  ctx.setFontSize(13 * rpx)
  ctx.fillText('xxx科技汽車銷售公司', 119 * rpx, 663 * rpx)
  ctx.fillStyle = "#666666"
  ctx.fillText('朝陽區·望京xxx科技大廈', 109 * rpx, 689 * rpx)
  ctx.setFillStyle('#fff')
  ctx.draw()
 },

保存到相冊

很簡單就是在畫完圖片之后的draw回調函數里調用canvasToTempFilePath()生產一個零時內存里的鏈接,然后在調用saveImageToPhotosAlbum()就可以了;其中牽扯到授權,如果你第一次拒絕了授權,你第二次進入的時候在iphone手機上是不會再次提醒你授權的,這時就需要你手動調用了;以下附上代碼!

ctx.draw(true, ()=>{
    // console.log('畫完了')
    wx.canvasToTempFilePath()({
     x: 0,
     y: 0,
     width: rpx * 375,
     height: that.screen_height * 1.21,
     canvasId: 'PosterCanvas',
     success: function (res) {
      // console.log(res.tempFilePath);
      wx.saveImageToPhotosAlbum({
       filePath: res.tempFilePath,
       success: (res) => {
        console.log(res)
       },
       fail: (err) => { }
      })

     }
    }) 
   })

拒絕授權后再次提醒授權的代碼

mpvue.saveImageToPhotosAlbum({
    filePath: __path,
    success(res) {
     mpvue.showToast({
     title: '保存成功',
     icon: 'success',
     duration: 800,
     mask:true
     });
     },
    fail(res) {
      if (res.errMsg === "saveImageToPhotosAlbum:fail:auth denied" || res.errMsg === "saveImageToPhotosAlbum:fail auth deny" || res.errMsg === "saveImageToPhotosAlbum:fail authorize no response") {

     mpvue.showModal({
        title: '提示',
        content: '需要您授權保存相冊',
        showCancel: false,
        success:modalSuccess=>{
         mpvue.openSetting({
          success(settingdata) {
           // console.log("settingdata", settingdata)
           if (settingdata.authSetting['scope.writePhotosAlbum']) {
            mpvue.showModal({
             title: '提示',
             content: '獲取權限成功,再次點擊圖片即可保存',
             showCancel: false,
            })
           } else {
            mpvue.showModal({
             title: '提示',
             content: '獲取權限失敗,將無法保存到相冊哦~',
             showCancel: false,
            })
           }
          },
          fail(failData) {
           console.log("failData",failData)
          },
          complete(finishData) {
           console.log("finishData", finishData)
          }
         })
        }
       })
     }
     }
   });

以上是“微信小程序怎么使用canvas自適應屏幕畫海報并保存圖片功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

德阳市| 桂平市| 巴彦县| 科尔| 新巴尔虎右旗| 琼结县| 大关县| 阿坝县| 湟源县| 巴东县| 安福县| 喀喇沁旗| 罗平县| 普宁市| 黄骅市| 沧源| 梅州市| 和田市| 巩义市| 景宁| 武邑县| 新化县| 比如县| 嘉峪关市| 新巴尔虎左旗| 丰原市| 当涂县| 大足县| 湾仔区| 淳化县| 基隆市| 沾益县| 信阳市| 龙泉市| 广灵县| 兴仁县| 南川市| 鄂伦春自治旗| 仪征市| 澎湖县| 桂东县|