riskers / blog

:pencil2: 博客写在 Issues 里
http://riskers.github.io/
MIT License
1.13k stars 96 forks source link

CSS Contain&Cover的数学公式 #10

Open riskers opened 8 years ago

riskers commented 8 years ago

background-sizecontaincover是怎么用的,大家应该都明白。但是里面也有一些有趣的数学关系。

基本概念

上面就是我们对于 rimage (图片宽高比)、rviewport (容器宽高比) 的定义。

将图片放进容器

三种方法

宽高比的影响

不知道大家注意到没有,刚才我们推导contain的 h'imagecover的 w'image 时使用的图片的宽高比总是大于容器的宽高比。

这导致了什么?导致了我们推导时使用的 条件3 是不一定正确的。 额,这么说我也有点晕,看图:

可以看到,我们只考虑了 rimage > rviewport的情况。

结论

我们考虑rimage < rviewport后加完整了,图片放进容器之后的宽、高如下:

这样我们就求到了图片在应用background-size属性之后在容器中实际的宽、高。

比例 hidden

现在讨论图片放进容器后的图片与容器的比例关系hidden,这样我们就可以以此关系让图片随着容器的变化而变化。 注意,hidden是一个小于1的比例,至于为什么要这样设定后面有解释。

contain布局为例,rimage > rviewport :

而以cover布局为例,rimage > rviewport :

以此类推,得到所有情况的 hidden

这样可以看到四种可能性,但是别忘了我们在上面可是推导过 w'image 、h'image

所以hidden最终的结果是:

可以看出来,hidden就只有两种结果,rimage / rviewportr viewport / rimage,而且这个数是小于1的(这是上面就确定的)。

所以,hidden的计算可以简化为:

后记

你可能想,搞了半天,这到底能干吗?直接用background-size不就好了,为什么还要得到具体的宽、高,得到了伸缩比又能怎么样。 我也想了想,如果只是图片,似乎上面都是废话。但如果是DOM呢?这是不是就是一种布局方式?

我也不知道,知识有时候就是这样。当你需要用到的时候,你才觉得有用。

参考文章

CSS – Contain & Cover


向我捐助 | 关于我 | 工作机会


zsusyt commented 6 years ago

有用

jun58 commented 6 years ago

对于 “知道了hidden就可以让图片随着容器的变化而变化” 不是很理解,知道了有什么用呢?手动改变图片大小?

riskers commented 6 years ago

@jun58 后面说了,如果是一张图片,是没什么意义的。但是如果是 DOM,就是一种布局了。后面也写了一篇文章说这个 https://github.com/riskers/blog/issues/15