当前位置: 首页 > news >正文

react 大屏根据屏幕分辨率缩放

记录,以防忘记

const DataLargeScreen = () => {
    const layoutRef = useRef<any>();
    // ui稿宽度
    const width = useRef(1920).current;
    // ui稿高度
    const height = useRef(1080).current;
    const [scaleValue, setScaleValue] = useState(1);
    const useWhichScaleValue = () => {
        const innerWidth = window.innerWidth;
        const innerHeight = window.innerHeight;
        const scaleW = innerWidth / width;
        const scaleH = innerHeight / height;
        setScaleValue(Math.min(scaleW, scaleH));
    };
    useEffect(() => {
        useWhichScaleValue();
        // 节流 lodashjs
        window.addEventListener('resize', _.throttle(useWhichScaleValue, 300));
        // window.addEventListener('resize', useWhichScaleValue)
        return () => {
            window.removeEventListener('resize', useWhichScaleValue);
        };
    }, []);
    useEffect(() => {
        const layoutBox = layoutRef.current;
        if (layoutBox) {
            layoutBox.style.setProperty('--scale', scaleValue);
        }
    }, [scaleValue]);

    return (
        <div className="bg-layout" style={{ display: 'flex', justifyContent: 'center', alignItems: 'center', width: '100vw', height: '100vh' }}>
            <div className="layout" ref={layoutRef}>
                <ScreenContent />
            </div>
        </div>
    );
};

export default DataLargeScreen;

scss

// 缩放时的背景
.bg-layout {
    background-image: url('~@@/assets/img/dataLargeScreen/largeScreenBg.png');
    background-size: 100% 100%;
    overflow: hidden;
}
.layout {
    // overflow: hidden;
    font-size: 12px;
    color: #fff;
    // font-size: 14px;
    // background-color: aqua;
    width: 1920px;
    height: 1080px;
    background-image: url('~@@/assets/img/dataLargeScreen/largeScreenBorder.png');
    // background-repeat:repeat-x;
    background-size: 100% 100%;
    background-position: center;
    transform: scale(var(--scale));
}

相关文章:

  • Qt 重入和线程安全
  • 【线程安全问题的原因和方法】【java形式】【图片详解】
  • 深入理解 tree 命令行工具:目录结构可视化的利器
  • LeetCode hot 100 每日一题(15)——48.旋转图像
  • python --face_recognition(人脸识别,检测,特征提取,绘制鼻子,眼睛,嘴巴,眉毛)/活体检测
  • vue数据重置
  • RFID测温技术:提升电缆安全监测的理想选择
  • docker pull时报错:https://registry-1.docker.io/v2/
  • 开源链动2+1模式与AI智能名片赋能的S2B2C共享经济新生态
  • 批量配置Linux ~/.bash_profile
  • 医学图像分割数据集肺分割数据labelme格式6299张2类别
  • 数据库基础知识点(系列二)
  • Atlas 800I A2 双机直连部署DeepSeek-R1-w8a8
  • SAP Activate Methodology in a Nutshell Phases of SAP Activate Methodology
  • 位运算题目:最大单词长度乘积
  • Netty源码—客户端接入流程
  • Linux应用:select、poll
  • 算法每日一练 (18)
  • 23种设计模式-创建型模式-原型
  • 4、操作系统结构和发展史
  • 民生访谈|规范放生活动、提升供水品质……上海将有这些举措
  • 十四届全国人大常委会第十五次会议继续审议民营经济促进法草案
  • 王文涛会见德国汽车工业协会主席穆勒
  • 上海超万套保租房供应高校毕业生,各项目免押、打折等优惠频出
  • 第二部以“法典”命名的法律!生态环境法典编纂迈出“关键步”
  • 同款瑞幸咖啡竟差了6元,开了会员仍比别人贵!客服回应