博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
css平行四边形与菱形变换
阅读量:7094 次
发布时间:2019-06-28

本文共 1107 字,大约阅读时间需要 3 分钟。

*以下技巧均源自于Lea Verou所著《CSS Secrets》

平行四边形

  平行四边形的构造可以基于矩形通过skew()的变形属性进行斜向拉升得到(skew所用的坐标系,纵向是X轴,横向是Y轴,与常见的坐标系相反)。

    
Title
click

  但是内容倾斜可能不是我们所需要的效果,一种常规的解决方案就是在内层嵌套一个div,然后加上一个反方向的拉升transform: skewX(45deg);但是有代码洁癖的人表示接受不能。

  另一种思路是将所有样式应用到伪元素上。然后再对伪元素进行变形。

 

    
Title
click

  这样不但解决了内容倾斜的问题,而且html结构还是和之前一样干净。不过要注意伪元素生成的图案是重叠在内容之上的,一旦给它设置背景,就会遮住内容,所以要加上z-index: -1。

 菱形图片

  如果是在正方形的基础之上,菱形就是正方形图案旋转45度的图形。我们很容易想到将外层div旋转45度再将内层img反向旋转45度。得到如下的图案。

    
Title

  是个挺漂亮的正八边形呢,如果你能说服产品经理,那工作也算完成啦。好吧,我猜你不能说服。。。

  这里由于旋转方向不一致,外层div截取了超出的部分(注意overflow:hidden),然后一部分又空出来了。只要填充完空出的部分就是菱形啦,这里你可以画个草图用勾股定理算一算。

  算出的结果是放大1.42倍填充完全。我们在img的transform属性改为transform: rotate(45deg) scale(1.42);得到下图:

  

  这个构造菱形的方案有一个缺陷,就是当原图不是正方形就需要使用更大的放大系数,截取的图片内容就更有限了。

  而且方案本身也不算简洁优雅。这里向大家介绍一个属性clip-path(遗憾的是支持性似乎并不好),它可以通过传入固定的位置点将图片裁剪成任意的多边形。

  

    
Title

  希望在不远的将来clip-path这个属性在各游览器得到更好的支持。

 

(转载):http://www.cnblogs.com/sharpall/p/6113377.html

转载于:https://www.cnblogs.com/snowlove/p/6124050.html

你可能感兴趣的文章
Java代码自动部署
查看>>
jboss eap6.1(5)(ejb升级)
查看>>
在VS中用正则表达式查找或替换
查看>>
《项目管理之美》读书笔记
查看>>
Java下载文件的几种方式
查看>>
【福州活动】| "福州首届.NET开源社区线下技术交流会"(2018.11.10)
查看>>
6月第5周业务风控关注 | 《网络安全等级保护条例(征求意见稿)》本周正式发布...
查看>>
智能车学习(三)—— ADC学习
查看>>
精通iOS开发(第5版)
查看>>
json对象的封装与解析
查看>>
YARN & HDFS2 安装和配置Kerberos
查看>>
HDU1698:Just a Hook(线段树区间更新)
查看>>
SoapUI Pro Project Solution Collection-DataSource(jdbc,excel)
查看>>
Docker学习总结
查看>>
文件服务器 之 ProFTPD+MySQL 认证
查看>>
SQL Server Logins, Database Users, Database Roles and Schemas
查看>>
makefile语法
查看>>
Python3.x和Python2.x的区别
查看>>
pickle和cPickle:Python对象的序列化(上)
查看>>
C#操作RTF文档
查看>>