[大屏适配]根据屏幕尺寸获取伸缩比例

2024-06-20 13:44

本文主要是介绍[大屏适配]根据屏幕尺寸获取伸缩比例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

[大屏适配]根据屏幕尺寸获取伸缩比例

用于检查浏览器窗口的宽度,并根据宽度调整页面的缩放级别,以适应不同的屏幕分辨率。具体来说,代码分为以下几个部分:

  1. getLayoutWidth() 函数用于获取当前浏览器窗口的宽度。该函数首先获取屏幕的宽度和高度,然后根据宽高比计算出适合的宽度,并返回该宽度。

  2. getZoomLevel() 函数用于根据当前浏览器窗口的宽度和起始缩放级别、结束缩放级别计算出当前的缩放级别。该函数首先获取起始宽度和结束宽度以及对应的缩放级别,然后根据线性插值的方法计算出当前的缩放级别,并返回该级别。

  3. notSupportZoom 变量用于判断当前浏览器是否支持缩放。该变量定义了一个自执行函数,该函数通过判断浏览器的 UserAgent、ActiveXObject、CSS、MouseEvent 等属性来判断当前浏览器是否支持缩放。

  4. checkZoom() 函数用于检查当前浏览器窗口的宽度,并根据宽度调整页面的缩放级别。该函数首先调用 getLayoutWidth() 函数获取当前浏览器窗口的宽度,然后根据宽度计算出当前的缩放级别,并将缩放级别应用到页面上。如果当前浏览器不支持缩放,则将缩放级别设置为 1。如果当前浏览器窗口的宽度没有发生变化,则不进行任何操作。最后,该函数使用定时器定时检查浏览器窗口的宽度,并根据宽度调整页面的缩放级别。

  5. 在页面加载完成后,代码通过监听 DOMContentLoaded 事件来调用 checkZoom() 函数,以便在页面加载完成后立即检查浏览器窗口的宽度,并根据宽度调整页面的缩放级别。

总的来说,这段代码主要用于实现页面的自适应缩放功能,以便在不同的屏幕分辨率下都能够正常显示页面内容。

// 获取布局宽度
function getLayoutWidth() {const { width, height } = window.screenif (width > height) {const aspectRatio = width / heightconst regularAspectRatio = 16 / 9if (aspectRatio <= regularAspectRatio) {return width // 返回宽度} else {return height * regularAspectRatio // 返回高度乘以标准宽高比}} else {return width // 返回宽度}
}// 获取缩放级别
function getZoomLevel(width, start, end) {const { width: startWidth, zoom: startZoom } = startconst { width: endWidth, zoom: endZoom } = endreturn startZoom + ((endZoom - startZoom) * (width - startWidth)) / (endWidth - startWidth)
}// 判断是否支持缩放
const notSupportZoom = (function () {let ua = navigator.userAgentreturn (ua.indexOf('Firefox') > -1 ||!!window.ActiveXObject ||'ActiveXObject' in window ||typeof CSS === 'undefined' ||!CSS.supports('zoom', '1') ||!Object.getOwnPropertyDescriptor(MouseEvent.prototype, 'pageX'))
})()let prevWidth
let timer = null
let hasHackProperties = false// 检查缩放
function checkZoom() {const currentWidth = getLayoutWidth()if (currentWidth === prevWidth) returnprevWidth = currentWidthif (currentWidth <= 1920 || notSupportZoom) {window.PAGEZOOM = 1document.documentElement.style.zoom = ''document.documentElement.style.setProperty('--zoom-level', '1')document.body.classList.remove('page-zoom')} else {const zoom =currentWidth <= 2560? getZoomLevel(currentWidth, { width: 1920, zoom: 1 }, { width: 2560, zoom: 1.25 }): currentWidth > 2560 && currentWidth <= 3840? getZoomLevel(currentWidth, { width: 2560, zoom: 1.25 }, { width: 3840, zoom: 1.75 }): 1.75window.PAGEZOOM = zoomdocument.documentElement.style.zoom = zoomdocument.documentElement.style.setProperty('--zoom-level', zoom)document.body.classList.add('page-zoom')if (!hasHackProperties) {// 重写属性Object.defineProperty(document.documentElement, 'clientHeight', {get: function () {return this.offsetHeight}})Object.defineProperty(document.documentElement, 'clientWidth', {get: function () {return this.offsetWidth}})try {const originalElementFromPoint = document.elementFromPointconst originalElementsFromPoint = document.elementsFromPointdocument.elementFromPoint = function (x, y) {return originalElementFromPoint.call(this, x * window.PAGEZOOM, y * window.PAGEZOOM)}document.elementsFromPoint = function (x, y) {return originalElementsFromPoint.call(this, x * window.PAGEZOOM, y * window.PAGEZOOM)}function rewriteNativeGetter(targetObj, props, nativeObj) {var getters = props.map(function (prop) {return Object.getOwnPropertyDescriptor(nativeObj || targetObj, prop).get})var setters = props.map(function (prop) {return Object.getOwnPropertyDescriptor(nativeObj || targetObj, prop).set})Object.defineProperties(targetObj,props.reduce(function (prev, next, i) {prev[next] = {get: function () {return getters[i].call(this) / window.PAGEZOOM}}if (nativeObj && setters[i]) {prev[next].set = function (value) {return setters[i].call(this, value * window.PAGEZOOM)}}return prev}, {}))}// 重写鼠标事件rewriteNativeGetter(MouseEvent.prototype, ['pageX', 'pageY', 'clientX', 'clientY'])// 重写元素属性rewriteNativeGetter(document.documentElement,['scrollTop', 'scrollLeft', 'scrollHeight', 'scrollWidth'],Element.prototype)// 重写窗口属性rewriteNativeGetter(window, ['scrollX', 'scrollY', 'pageXOffset', 'pageYOffset', 'innerHeight', 'innerWidth'])} catch (e) {console.error(e)}hasHackProperties = true}}if (!notSupportZoom && !timer) {timer = setInterval(checkZoom, 1000) // 定时检查缩放}
}window.addEventListener('DOMContentLoaded', checkZoom) // 监听DOM加载事件

这篇关于[大屏适配]根据屏幕尺寸获取伸缩比例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078296

相关文章

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

C#实现获取电脑中的端口号和硬件信息

《C#实现获取电脑中的端口号和硬件信息》这篇文章主要为大家详细介绍了C#实现获取电脑中的端口号和硬件信息的相关方法,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 我们经常在使用一个串口软件的时候,发现软件中的端口号并不是普通的COM1,而是带有硬件信息的。那么如果我们使用C#编写软件时候,如

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

python中os.stat().st_size、os.path.getsize()获取文件大小

《python中os.stat().st_size、os.path.getsize()获取文件大小》本文介绍了使用os.stat()和os.path.getsize()函数获取文件大小,文中通过示例代... 目录一、os.stat().st_size二、os.path.getsize()三、函数封装一、os

python获取当前文件和目录路径的方法详解

《python获取当前文件和目录路径的方法详解》:本文主要介绍Python中获取当前文件路径和目录的方法,包括使用__file__关键字、os.path.abspath、os.path.realp... 目录1、获取当前文件路径2、获取当前文件所在目录3、os.path.abspath和os.path.re

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

鸿蒙开发搭建flutter适配的开发环境

《鸿蒙开发搭建flutter适配的开发环境》文章详细介绍了在Windows系统上如何创建和运行鸿蒙Flutter项目,包括使用flutterdoctor检测环境、创建项目、编译HAP包以及在真机上运... 目录环境搭建创建运行项目打包项目总结环境搭建1.安装 DevEco Studio NEXT IDE

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

JS和jQuery获取节点的兄弟,父级,子级元素

原文转自http://blog.csdn.net/duanshuyong/article/details/7562423 先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比。 JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当最DOM元素。 <div id="test"><div></div><div></div