upx2px.js 1.3 KB
Newer Older
fxy060608's avatar
fxy060608 已提交
1 2 3 4 5 6
const EPS = 1e-4
const BASE_DEVICE_WIDTH = 750
let isIOS = false
let deviceWidth = 0
let deviceDPR = 0

fxy060608's avatar
fxy060608 已提交
7
function checkDeviceWidth () {
fxy060608's avatar
fxy060608 已提交
8 9 10 11 12 13 14 15 16 17 18
  const {
    platform,
    pixelRatio,
    windowWidth
  } = uni.getSystemInfoSync()

  deviceWidth = windowWidth
  deviceDPR = pixelRatio
  isIOS = platform === 'ios'
}

19 20 21 22 23
function checkValue (value, defaultValue) {
  value = Number(value)
  return isNaN(value) ? defaultValue : value
}

24
export function upx2px (number, newDeviceWidth) {
fxy060608's avatar
fxy060608 已提交
25 26 27 28 29 30 31 32
  if (deviceWidth === 0) {
    checkDeviceWidth()
  }

  number = Number(number)
  if (number === 0) {
    return 0
  }
33 34 35 36 37 38 39
  const config = __uniConfig.globalStyle || __uniConfig.window || {}
  const maxWidth = checkValue(config.rpxCalcMaxDeviceWidth, 960)
  const baseWidth = checkValue(config.rpxCalcBaseDeviceWidth, 375)
  const includeWidth = checkValue(config.rpxCalcIncludeWidth, 750)
  let width = newDeviceWidth || deviceWidth
  width = number === includeWidth || width <= maxWidth ? width : baseWidth
  let result = (number / BASE_DEVICE_WIDTH) * width
40 41 42 43 44
  if (result < 0) {
    result = -result
  }
  result = Math.floor(result + EPS)
  if (result === 0) {
fxy060608's avatar
fxy060608 已提交
45
    if (deviceDPR === 1 || !isIOS) {
雪洛's avatar
雪洛 已提交
46
      result = 1
fxy060608's avatar
fxy060608 已提交
47
    } else {
雪洛's avatar
雪洛 已提交
48
      result = 0.5
fxy060608's avatar
fxy060608 已提交
49 50
    }
  }
51
  return number < 0 ? -result : result
雪洛's avatar
雪洛 已提交
52
}