一种简单粗暴的大屏自适应方案,原理及案例

现状

现在最流行的大屏自适应手法: scale缩放
为了解决2d/3d的点击交互问题,通常设计成了2个层容器。图表层和2d/3d层。图表层负责缩放,2d/3d层保持100%显示,避免缩放引起的交互事件event问题。

下图是一个1920*1080的大屏示意图

使用常规的缩放方法,让大屏在窗口内最大化显示。大屏在不同的窗口中出现了空白区域,并没有充满整个屏幕。

新的方法

在缩放的基础上,对指定的要素进行贴边处理。还是这张设计图,我们希望上下吸附到窗口最上面和最下面。左右图表吸附到窗口的最左边和最右边。

这里面需要简单的计算,其中a是图表层 scale属性

js 复制代码
var halftop = (window.innerHeight- (1080*a.scaleY))/2/a.scaleY;
var halfleft = (window.innerWidth- (1920*a.scaleX))/2/a.scaleX; 

对指定id的容器,在resize事件中设置上下左右浮动。如下图

实战项目效果

注,下面图片中的数据指标、城市名、姓名、图像均为虚拟数据。

在实际应用中,一般1920*1080设计稿已宽屏为主,如果是竖屏大屏(下图5),需要设计竖屏UI。

你也可以下载该项目demo, 对窗口进行缩放查看效果 pan.baidu.com/s/1hE_C9x9i...

相关推荐
前端布鲁伊9 小时前
再来聊聊,Vue3 项目中 Pinia 的替代方案
前端·面试
柒昀10 小时前
Vue.js
前端·javascript·vue.js
2201_7578308710 小时前
Stream的终结方法
java·服务器·前端
进阶的鱼10 小时前
React+ts+vite脚手架搭建(五)【登录篇】
前端·javascript
safestar201210 小时前
React深度实战:从组件抽象到性能优化的思考历程
前端·javascript·react.js
洗澡水加冰10 小时前
VSCode插件: 自动临时分配Theme以区分不同窗口
前端·typescript·visual studio code
我叫张小白。10 小时前
TypeScript类型断言与类型守卫:处理类型的不确定性
前端·javascript·typescript
阿笑带你学前端10 小时前
Flutter 实战:为开源记账 App 实现优雅的暗黑模式(Design Token + 动态主题)
前端
天渺工作室10 小时前
Chrome浏览器自带翻译的诡异Bug:ID翻译后竟然变化了
前端·chrome
daols8811 小时前
vxe-table 如何实现跟 excel 一样的筛选框,支持字符串、数值、日期类型筛选
前端·javascript·excel·vxe-table