大屏可视化 适配方案 scale方案详解

常见的几种可视化适配方案如下

  • vw,vh:主要是将设计稿px通过计算换算成vw,vh, 可以进行同比缩放但是同时又不会出现白边的情况【唯一的缺陷是比较麻烦:要为每一个图表单独设置 字体、间距、位移 的适配

  • scale: 根据屏幕大小对图表进行等比缩放,通过设计稿宽高比 与 窗口宽高比 大小 决定使用 宽宽比还是高高比,通过比值来控制图表大小 简单代码量小【因为是使用比值, 所以会出现屏幕白边的情况, 当屏幕过大时字体会有一点模糊, 当缩放比过大时 事件热区会发生偏移

  • rem + vh,vw:算是上面两个方案的结合,会有白边,且要单个设置

在项目中我使用的是 scale属性 方案【因为在GitHub上有现成插件可以直接使用,方便开发】 具体原理代码如下

敲定 缩放比例,并渲染

js 复制代码
function handleScreenAuto(){
    // scale 比例计算
    const designDraftWidth = 1920; //设计稿的宽度
    const designDraftHeight = 960; //设计稿的高度
    
    // 窗口和设计稿的宽高比
    const windowRatio = document.documentElement.clientWidth / document.documentElement.clientHeight
    const designRatio = designDraftWidth / designDraftHeight
    
    // 高高比
    const widths = document.documentElement.clientWidth / designDraftWidth
    // 宽宽比
    const heights = document.documentElement.clientHeight / designDraftHeight
    
    // 根据 窗口比值大小 和 设计稿比值大小 判断使用哪一个比值【高高比,宽宽比】
    const scale = windowRatio < designRatio ? widths : heights; 
    
    // 定位元素 添加 style 样式 transform; 
    document.querySelector().style.transfrom = `scale(${scale}) translate(-50%, -50%)`
}

钩子函数:

为了在窗口改变大小时触发, 将封装好的方法绑定在window 的onresize上面, 保证 窗口改变大小的时候进行触发, 代码运行时机在 mounted钩子函数中执行

js 复制代码
onMounted() {
  // 初始化自适应  ----在刚显示的时候就开始适配一次
  handleScreenAuto();
  // 绑定自适应函数   ---防止浏览器栏变化后不再适配
  window.onresize = () => handleScreenAuto();
},

最后在 组件销毁后 将方法释放掉

js 复制代码
onUnmounted(){
  window.onresize = null
}

居中属性作用展示

css样式表:

css 复制代码
/*
  除了设计稿的宽高是根据您自己的设计稿决定以外,其他复制粘贴就完事
*/  
.screen-root {
    height: 100%;
    width: 100%;
    .screen {
        display: inline-block;
        width: 1920px;  <!--设计稿的宽度-->
        height: 960px;  <!--设计稿的高度-->
        transform-origin: 0 0; 
        position: absolute;
        left: 50%;
        top: 50%;
    }
}
  • transfrom:translate(-50%, -50%)
  • transform-origin: 0 0;
  • position: absolute; left: 50%; top: 50%;

引用文档:juejin.cn/post/716393...

相关推荐
IT研究室5 小时前
大数据毕业设计选题推荐-基于大数据的国内旅游景点游客数据分析系统-Spark-Hadoop-Bigdata
大数据·hadoop·spark·毕业设计·源码·数据可视化·bigdata
程序员白话9 小时前
使用kube-prometheus在K8s集群快速部署Prometheus+Grafana
后端·数据可视化
alsmile1 天前
什么是组态?不会代码也能搭出工业大屏和数字可视化
低代码·数据可视化
IT研究室1 天前
大数据毕业设计选题推荐-基于大数据的国家药品采集药品数据可视化分析系统-Spark-Hadoop-Bigdata
大数据·hadoop·信息可视化·spark·毕业设计·数据可视化·bigdata
IT研究室2 天前
大数据毕业设计选题推荐-基于大数据的贵州茅台股票数据分析系统-Spark-Hadoop-Bigdata
大数据·hadoop·spark·毕业设计·源码·数据可视化·bigdata
IT毕设梦工厂2 天前
大数据毕业设计选题推荐-基于大数据的国家基站整点数据分析系统-Hadoop-Spark-数据可视化-BigData
大数据·hadoop·spark·毕业设计·源码·数据可视化
@HNUSTer3 天前
Python数据可视化科技图表绘制系列教程(六)
python·数据可视化·科技论文·专业制图·科研图表
界面开发小八哥3 天前
数据可视化图表库LightningChart JS v8.0上线:全新图例系统 + 数据集重构
javascript·信息可视化·数据可视化·lightningchart
Yvonne爱编码3 天前
零基础学习数据采集与监视控制系统SCADA
学习·信息可视化·信息与通信·数据可视化
IT研究室3 天前
大数据毕业设计选题推荐-基于大数据的宫颈癌风险因素分析与可视化系统-Spark-Hadoop-Bigdata
大数据·hadoop·spark·毕业设计·源码·数据可视化·bigdata