动态等比例缩放微信小程序图片

1,770 阅读2分钟

前言

在小程序布局中,如果图片不是固定高度和高度,但image设置的是固定的高度和宽度,这时候原始图片相对image设置的固定高度和宽度不是等比例大小,那么这张图片就会变形,变的不清晰。这时就可以使用下面的等比例缩放的方式缩放图片,让图片不变形。或者通过image的bindload方法动态的获取图片的高度和宽度,动态的设置图片的高度和宽度,是图片布局的高度和宽度和原始图片的高度和宽度相等。

1. 图片等比例缩放工具zoomImg.js

zoomImg.js放在utils 目录下

//zoomImg.js
class ZoomImg{
  /***
   * 按照显示图片的宽等比例缩放得到显示图片的高
   * @params originalWidth  原始图片的宽
   * @params originalHeight 原始图片的高
   * @params imageWidth     显示图片的宽,如果不传就使用屏幕的宽
   * 返回图片的宽高对象
  ***/
  static imageZoomHeightUtil(originalWidth,originalHeight,imageWidth){
      let imageSize = {};
      if(imageWidth){
          imageSize.imageWidth = imageWidth;
          imageSize.imageHeight = (imageWidth * originalHeight) / originalWidth;
      }else{//如果没有传imageWidth,使用屏幕的宽
          wx.getSystemInfo({  
              success: function (res) {  
                  imageWidth = res.windowWidth;  
                  imageSize.imageWidth = imageWidth;
                  imageSize.imageHeight = (imageWidth * originalHeight) / originalWidth;
              }  
          });
      }
      return imageSize;
  }

  /***
   * 按照显示图片的高等比例缩放得到显示图片的宽
   * @params originalWidth  原始图片的宽
   * @params originalHeight 原始图片的高
   * @params imageHeight    显示图片的高,如果不传就使用屏幕的高
   * 返回图片的宽高对象
  ***/
  static imageZoomWidthUtil(originalWidth,originalHeight,imageHeight){
      let imageSize = {};
      if(imageHeight){
          imageSize.imageWidth = (imageHeight *originalWidth) / originalHeight;
          imageSize.imageHeight = imageHeight;
      }else{//如果没有传imageHeight,使用屏幕的高
          wx.getSystemInfo({  
              success: function (res) {  
                  imageHeight = res.windowHeight;
                  imageSize.imageWidth = (imageHeight *originalWidth) / originalHeight;
                  imageSize.imageHeight = imageHeight;
              }  
          });
      }
      return imageSize;
  }
}
export default ZoomImg;

2. 使用image组件加载图片,通过bindload动态的获取图片的高度和宽度,动态的设置图片的高度和宽度

import ZoomImg from '../utils/zoomImg.js';
 
Page({
  data:{
        imageWidth:0,
        imageHeight:0
  },
  imageLoad: function (e) {  
        //获取图片的原始宽度和高度
        let originalWidth = e.detail.width;
        let originalHeight = e.detail.height;
        //let imageSize = ZoomImg.imageZoomHeightUtil(originalWidth,originalHeight);
 
        //let imageSize = ZoomImg.imageZoomHeightUtil(originalWidth,originalHeight,375);
        let imageSize = ZoomImg.imageZoomWidthUtil(originalWidth,originalHeight,145);
 
        this.setData({imageWidth:imageSize.imageWidth,imageHeight:imageSize.imageHeight});  
  }
})