当前位置:   article > 正文

可视化大屏设计尺寸_Vue 大屏可视化-屏幕自适应(保持设计尺寸比例)

可视化屏幕尺寸

最近在用VUE写大屏页面,遇到屏幕自适应问题,根据设计的尺寸,在各种屏幕尺寸下自适应,保持显示比例不变,经过几天摸索,终于达到了效果,希望为还在这问题困扰的提供点帮助

铺满全屏效果见Vue 大屏可视化 铺满全屏

1. 在配置文件设置大屏设计的尺寸1920*1080

//appConfig.js

export default{

screen:{

width:1920,

height:1080,

scale:20

}//大屏设计宽高

}

2. 定义resetScreenSize.js

import appConfig from '../config/base'

export function pageResize(callback) {

let init = () => {

console.log(window.innerHeight + "," + window.innerWidth);

let _el = document.getElementById('app');

let hScale = window.innerHeight / appConfig.screen.height;

let wScale = window.innerWidth / appConfig.screen.width;

let pageH = window.innerHeight;

let pageW = window.innerWidth;

let isWider = (window.innerWidth / window.innerHeight) >= (appConfig.screen.width / appConfig.screen.height);

console.log(isWider);

if (isWider) {

_el.style.height = window.innerHeight+'px';// '100%';

_el.style.width = pageH * appConfig.screen.width / appConfig.screen.height + 'px';

_el.style.top='0px';

_el.style.left=(window.innerWidth -pageH * appConfig.screen.width / appConfig.screen.height)*0.5+'px';

console.log(_el.style.width + "," + _el.style.height)

}

else {

_el.style.width = window.innerWidth+'px';// '100%';

_el.style.height = pageW * appConfig.screen.height / appConfig.screen.width + 'px';

_el.style.top= 0.5*(window.innerHeight-pageW * appConfig.screen.height / appConfig.screen.width)+'px';

_el.style.left='0px';

console.log(_el.style.height);

console.log(_el.style.top);

}

document.documentElement.style.fontSize = (_el.clientWidth / appConfig.screen.scale) + 'px';

}

var resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';

window.addEventListener(resizeEvt, init, false);

document.documentElement.addEventListener('DOMContentLoaded', init, false);

init()

}

3 使用方式

main.js 引入

import appConfig from './config/base.js';

Vue.prototype.appConfig=appConfig;

app.Vue  在mounted函数引入

import {pageResize} from './utils/resetScreenSize'

export default {

name: 'App',

data(){

return{

}

},

mounted(){

pageResize();

console.log('pageResize');

}

}

组件中样式 lang="stylus"

.mc{

display :flex;

flex-direction :column;

align-content :center;

justify-content :center;

display: flex;

flex: 1 1 auto;

flex-direction: column;

padding:(15/96)rem;

}

.leftC{

width :(410/96)rem;

}

.centerC{

width :(1060/96)rem;

}

.rightC{

width :(450/96)rem;

}

其中 96为 配置文件中1920/20得来,这样不用在进行各种换算了

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号