设计师提供的2倍图有啥用?(移动端适配基础知识)

物理像素&物理像素比

物理像素点指的是屏幕显示的最小颗粒,是物理真实存在的。这是厂商在出厂时就设置好了,比如苹果6\7\8 是 750* 1334

物理像素比就是屏幕的分辨率,分辨率越高,显示越清楚,750* 1334就是横的有750的像素点,竖的有1334的像素点

物理像素就是我们说的分辨率,例如iphone8的物理像素是750

我们开发时候的1px 不是一定等于1个物理像素的

例如在iPhone8里面 1px 开发像素 = 2个物理像素

设计稿通常都是以iphone6/7/8为准,即375(开发尺寸)

PC端 和 早前的手机屏幕 / 普通手机屏幕: 1CSS像素 = 1 物理像素的

Retina(视网膜屏幕)是一种显示技术,可以将把更多的物理像素点压缩至一块屏幕里,从而达到更高的分辨率,并提高屏幕显示的细腻程度。

多倍图

对于一张 50px * 50px 的图片,在手机 Retina 屏中打开,按照刚才的物理像素比会放大倍数,这样会造成图片模糊

在标准的viewport设置中,使用倍图来提高图片质量,解决在高清设备中的模糊问题

通常使用二倍图, 因为iPhone 6\7\8 的影响,但是现在还存在3倍图4倍图的情况,这个看实际开发公司需求

背景图片 注意缩放问题

xml 复制代码
<!DOCTYPE html> 
<html lang="en"> 
<head> 
<meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> 
<title>Document</title> 
<style> 
/* 我们需要一个50*50像素(css像素)的图片 直接放到我们的iphone8 里面会放大2倍 100* 100 就会模糊 */ 
/* 我们采取的是 放一个 100* 100 图片 然后手动的把这个图片 缩小为 50* 50 (css像素) */ 
/* 我们准备的图片 比我们实际需要的大小 大2倍,这就方式就是 2倍图 */ 
img:nth-child(2) { width: 50px; height: 50px; } 
</style> 
</head> 
<body> 
<!-- 模糊的 --> 
<img src="images/apple50(1).jpg" alt="">
<!-- 我们采取2倍图 -->
<img src="images/apple100.jpg" alt="">
</body> 
</html>

就是原先用50x50放到移动端会放大,变的模糊,但是如果我们采用100100然后压缩成5050,在放到移动端又变成了100*100实际上并没有变化,但是实际没有模糊

背景缩放 background-size

background-size: 背景图片宽度 背景图片高

单位: 长度|百分比|cover|contain;

cover把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。

contain把图像图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域

多倍图切图 cutterma

@3X 3倍图

@2X 2倍图

@1X 1倍图原图

现在要收费了,可以去淘宝上买

相关推荐
一颗青果7 分钟前
Cookie 与 Session 超详细讲解
服务器·前端·github
zs宝来了15 分钟前
React 18 并发模式:Fiber 架构与时间切片
前端·javascript·框架
万物得其道者成25 分钟前
Vue3 使用 Notification 浏览器通知,解决页面关闭后旧通知点击无法跳转问题
前端·vue.js·edge浏览器
ShineWinsu28 分钟前
CSS 技术文章
前端·css
张风捷特烈39 分钟前
状态管理大乱斗#02 | Bloc 源码全面评析
android·前端·flutter
将心ONE1 小时前
pathlib Path函数的使用
java·linux·前端
lingzhilab1 小时前
零知派——ESP32-S3 AI 小智 使用 Preferences NVS 实现Web配网持久化
前端
阿亮爱学代码1 小时前
日期与滚动视图
java·前端·scrollview
欧米欧1 小时前
STRING的底层实现
前端·c++·算法
2301_814809861 小时前
踩坑实战pywebview:用 Python + Web 技术打造轻量级桌面应用
开发语言·前端·python