本文转自奇舞周刊学习使用侵权删

先来看个例子,热热身。

上面这张图像的原始尺寸是:宽 54px 高 49px。

那么,在以下代码中,每张图像显示的最终尺寸是多少?

https://p1.ssl.qhimg.com/t01068da1826ad05875.png 是该图片的 url

图像由<img src="">指定,代码如下:

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png">

 

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png" width="30" height="30">

 

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png" width="30">

 

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png" height="30">

 

显示的尺寸依次是...

  1. 宽 54px,高 49px

  2. 宽 30px,高 30px

  3. 宽 30px,高 30/(54/49)=27.22px

  4. 宽 30*(54/49)=33.06px,高 30px

图像由background-image指定,代码如下:

<style>

 

.img {

 

 display: inline-block;

 

 background-color: #eee;

 

 background-image: url('https://p1.ssl.qhimg.com/t01068da1826ad05875.png');

 

 background-repeat: no-repeat;

 

 background-size: auto; /*auto 是默认值*/

 

}

 

</style>

 

<span class="img" style="width: 100px; height: 100px;"></span>

 

<span class="img" style="width: 30px; height: 30px;"></span>

 

<span class="img" style="width: 30px; height: 30px; background-size: 10px 10px;"></span>

 

<span class="img" style="width: 30px; height: 30px; background-size: contain;"></span>

 

<span class="img" style="width: 100px; height: 100px; background-size: cover;"></span>

 

显示的尺寸依次是...

  1. 宽 54px,高 49px

  2. 宽 54px,高 49px

  3. 宽 10px,高 10px

  4. 宽 30px,高 27.22px

  5. 宽 100px,高 100px

以上 9 道题,你都答对了吗?

确定图像大小的过程

为了方便讨论,我们先来认识四个术语:

  1. 固有尺寸:是固有宽度、固有高度和固有宽高比的集合。对于特定对象,这三个尺寸可能都存在,也可能都不存在。比如光栅图像同时拥有这三个,SVG 图像只有固有宽高比,CSS 渐变就没有任何固有尺寸。

  2. 指定大小:是通过width  height  background-size中的一个或多个指定的。

  3. 默认对象大小:是一个具有确定宽高的矩形。在既没有固有尺寸,也没有指定大小时生效。

  4. 具体对象大小:是对象最终显示的大小,即有明确宽度和高度值的矩形。

通常情况,计算图像大小的默认过程是:

  1. 优先使用指定大小,得到要显示的宽和高

  2. 如果只指定了一个宽度,或只指定了一个高度,那么

    2.1 如果有固有宽高比,则用它和给出的那个,计算出来另一个

    2.2 否则,就取固有尺寸里的

    2.3 如果也没有固有尺寸,那就取默认对象大小的

  3. 如果没有指定大小

    3.1 先用固有尺寸里的

    3.2 如果没有固有尺寸,那就取默认对象大小的

 

初听起来有些绕,我们用刚才提到的例子具象下这个过程。

光栅图像是有三个固有尺寸的。以开头给出的 Logo 图像为例,它的固有尺寸分别是:

  • 固有宽度 54px

  • 固有高度 49px

  • 固有宽高比 54/49

 

<img>

我们先来看用<img src="">指定的那四个:

demo1.

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png">

没有指定大小,那就用固有尺寸。所以,最终显示的尺寸是宽 54px,高 49px。

demo2.

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png" width="30" height="30">

有指定的宽和高,所以,最终显示的尺寸是宽 30px,高 30px。

demo3.

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png" width="30">

只有一个指定的宽,那就用固有宽高比计算出高来。所以,最终显示的尺寸是宽 30px,高 30/(54/49)=27.22px。

demo4.

<img src="https://p1.ssl.qhimg.com/t01068da1826ad05875.png" height="30">

只有一个指定的高,那就用固有宽高比计算出宽来。所以,最终显示的尺寸是宽 30*(54/49)=33.06px,高 30px。

以上四个示例的 UI 依次是:

background-image

接下来,看用background-image指定的五个。

在这个上下文里,背景区域的大小即图像的默认对象大小,background-size属性提供指定大小。

background-size有两个关键字contain和cover,它们分别对应包含约束和覆盖约束。

  • 包含约束(contain constraint )遵循固有宽高比,宽高都小于等于背景区域,然后尽可能的大。

  • 覆盖约束(cover constraint)遵循固有宽高比,宽高都大于等于背景区域,然后尽可能的小。

demo1.

<span class="img" style="width: 100px; height: 100px;"></span>

auto是background-size的默认值,意思是按图像的固有尺寸来,所以最终显示的尺寸是宽 54px,高 49px。

demo2.

<span class="img" style="width: 30px; height: 30px;"></span>

同上,auto按图像的固有尺寸来,所以最终显示的尺寸是宽 54px,高 49px。

demo3.

<span class="img" style="width: 30px; height: 30px; background-size: 10px 10px;"></span>

这里background-size: 10px 10px给出了具体的指定大小,所以最终显示显示的尺寸就是宽 10px,高 10px。

demo4.

<span class="img" style="width: 30px; height: 30px; background-size: contain;"></span>

根据contain的含义,包含约束要在背景框里尽可能的大。背景框宽 30px 高 30px,图像固有宽 54px 固有高 49px,所以包含约束取宽 30px,高根据固有宽高比算出来 30/(54/49)=27.22px,也就是指定大小是宽 30px 高 27.22px。对于背景区域未覆盖到的地方将会用背景色来填充。所以最终显示的尺寸是宽 30px 高 27.22px。

demo5.

<span class="img" style="width: 100px; height: 100px; background-size: cover;"></span>

根据cover的含义,覆盖约束要在大于等于背景框的前提下尽可能的小。背景框宽 100px 高 100px,图像固有宽 54px 固有高 49px,所以覆盖约束取高 100px,宽根据固有宽高比算出来 100*(54/49)=110.20px,也就是指定大小是宽 110.20px 高 100px。 对于超出背景区域的部分,会被裁切掉,所以最终显示的尺寸是宽 100px 高 100px。

以上五个示例的 UI 依次是:

总结

  1. 理解四个尺寸

    • 固有尺寸:固有宽度、固有高度、固有宽高比

    • 指定大小:width  height  background-size

    • 默认对象大小:依据不同的上下文而定

    • 具体对象大小:它就是最终要显示的大小

       

       

  2. 计算图像大小的过程,即算图像最终要显示的大小,也就是算它最终的“具体对象大小”

    • 根据固有尺寸 + 指定大小 + 默认对象大小,计算具体对象大小

    • 使用的优先级:指定大小 > 固有尺寸 > 默认对象大小

    • 两种比较常见的指定大小约束:包含约束、覆盖约束

  3. 当计算出的“具体对象大小”和图像的“固有尺寸”不一致时,图像就要调整自身,以匹配“具体对象大小”

    • 图像超出背景区域的部分,会被裁剪掉;覆盖不全的部分,会用背景色来填充

    • 当是<img>时,也有个相应的属性可以调整图像大小,即 object-fit

    • 调整图像大小的属性background-size

CSS 是怎样确定图像大小的?的更多相关文章

  1. CSS 图像大小

    CSS 图像大小 虽然在HTML中,img标签有属性height.width设置高和宽,在工作中却使用得非常少,通常使用CSS来控制大小. 给盒子设置属性height.width限制大小.单位通常是像 ...

  2. CSS的模板资源+编辑图像大小

    模板资源 源码之家搜登录页面,链接:https://www.mycodes.net/190/10144.htm        (或者搜门户网站 模板之家,里面页面更强大!) 编辑图像大小      然 ...

  3. 如何在 HTML 中调整图像大小?

    了解在 HTML 中调整图像大小的不同技术.何时应避免在浏览器端调整大小,以及在 Web 上操作和提供图像的正确方法. 如果您的图像不适合布局,您可以在 HTML 中调整其大小.在 HTML 中调整图 ...

  4. C#中如何调整图像大小

    在本篇文章中,我将介绍如何在C#中来调整你想要的图像大小.要实现这一目标,我们可以采取以下几个步骤: 1.首先要获取你想要调整大小的图像: string path = Server.MapPath(& ...

  5. [译]Android调整图像大小的一些方法

    翻译自 某大神在Stack Overflow里的自问自答 (一般我们将Bitmap翻译为位图,但为了更好理解,在本文中我将它翻译成图像): 我们在开发的时候,经常需要从服务器中加载图像到客户端中,但有 ...

  6. Matlab绘图基础——图形绘制的插值  以及 图像大小的重采样

    使用说明:图形绘制时的插值 interp1   %1-D data interpolation interpft  %使用fft算法插值     %将原数据x转换到频率域,再逆转换回来更密集的数据采样 ...

  7. IE对CSS样式的数量和大小的限制

    项目中遇到的问题,css写的样式无法渲染,各种百度后发现大概是这个原因: IE对CSS样式的数量和大小的限制 文档中只有前31个link或style标记关联的CSS能够应用. 从第32个开始,其标记关 ...

  8. AForge,Emgu.CV抓拍图像大小

    原文:AForge,Emgu.CV抓拍图像大小 2017年,忙忙碌碌地过去了,象往年一样,依然没有时间上CSDN,博客园. 这一年是打工以来最辛苦的一年. 这一年用了不少自己没有接触过的东西.如人脸识 ...

  9. COS数据处理WebP压缩 | 减少70%图像大小

    当前网络中,图片仍是占用流量较大的一部分,在网站的视觉效果和加载速度之间,我们始终面临着两难选择. 一个网站的内容,不仅仅只有文字,图片.动图.视频等众多元素都在帮助用户从我们的网站获取更多的信息,当 ...

随机推荐

  1. windows server 2012 R2修改默认远程端口

    因客户现场网络复杂,将windows系统的默认远程端口3389归入安全策略中,所以服务器需要修改此端口,配置如下: 首先:登录操作系统,win+R调出运行菜单后输入regedit, 进入注册表编辑相关 ...

  2. Django 模型层 ORM 操作

    运行环境 1. Django:2.1.3 version 2. PyMysql: 0.9.3 version 3. pip :19.0.3 version 4. python : 3.7 versio ...

  3. Codeforces 1183H DP 计算子序列数目

    题意及思路:https://blog.csdn.net/mmk27_word/article/details/93999633 第一次见这种DP,有点像退背包的思想,如果发现有可能因为字母相同和前面算 ...

  4. JavaSE---多线程---集合类

    1.概述 1.1 Java提供的ArrayList.LinkedList.HashMap等都是线程不安全的类,如何解决: 1.1 使用Collections类提供的方法将  其  包装成线程安全类: ...

  5. vue.js 分页

    <template> <div class="index"> <el-pagination background :hide-on-single-pa ...

  6. shell倒计时下班时间

    #!/bin/sh offWorkTime="19:00:00" offWorkHour=${offWorkTime::} offWorkMinute=${offWorkTime: ...

  7. Hibernate学习 (一)

    Hibernate错误总结: 1:不能自动创建表.把MySQL的版本的方言修改一下. 首先自己要注意自己的MYSQL版本,然后设置对应的方言 兼容性模式 <property name=" ...

  8. Android动画效果 translate、scale、alpha、rotate 切换Activity动画 控件位置调整

    2011.10.28注:如果需要控件停在动画后的位置,需要设置android:fillAfter属性为true,在set节点中.默认在动画结束后回到动画前位置.设置android:fillAfter后 ...

  9. VC连接SQLite3的方法(MFC封装类)

    SQLite,是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,支持跨平台,操作简单,能够使用很多语言直接创建数据库.官方网站:www.sqlite.org 在VC环境下编写连接SQLite的 ...

  10. MVC MVC3中 ViewBag、ViewData和TempData的使用和区别 【转】

    在MVC3开始,视图数据可以通过ViewBag属性访问,在MVC2中则是使用ViewData.MVC3中保留了ViewData的使用.ViewBag 是动态类型(dynamic),ViewData 是 ...