css平行四边形与菱形变换

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

平行四边形

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

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><style>.location{position: relative;top: 150px;left: 150px;}.button{color: white;background-color: #51bfff;width: 120px;height: 50px;line-height: 50px;text-align: center;transform: skewX(-45deg);}</style>
</head>
<body><div class="location button">click</div>
</body>
</html>

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

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

 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><style>.location{position: relative;top: 150px;left: 150px;}.button{width: 120px;height: 50px;line-height: 50px;text-align: center;color: white;}.button:before{content: '';position: absolute;top: 0; right: 0; bottom: 0; left: 0;background-color: #51bfff;transform: skewX(-45deg);z-index: -1;}</style>
</head>
<body><div class="location button">click</div>
</body>
</html>

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

 菱形图片

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

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><style>.location{position: relative;top: 150px;left: 150px;}.picture{width: 600px;transform: rotate(45deg);overflow: hidden;}.picture>img{max-width: 100%;transform: rotate(-45deg);}</style>
</head>
<body><div class="location picture"><img src="1.jpeg"></div>
</body>
</html>

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

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

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

  

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

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

  

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><style>.location{position: relative;top: 150px;left: 150px;}.picture{-webkit-clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);-moz-clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);transition: 1s clip-path;}</style>
</head>
<body>
<img class="location picture" src="1.jpeg">
</body>
</html>

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

 

  

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/368121.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis 启动配置文件加载报错 service redis does not support chkconfig

# chkconfig:2345 90 10 # description:Redis is a persistent key-value database 网上资料 上面的注释的意思是&#xff0c;redis服务必须在运行级2&#xff0c;3&#xff0c;4&#xff0c;5下被启动或关闭&#xff0c;启动的优先级是90&#xff0c;关闭的优先级是10。 附录&…

Android 获取ROOT权限原理解析

一、 概述本文介绍了android中获取root权限的方法以及原理&#xff0c;让大家对android玩家中常说的“越狱”有一个更深层次的认识。二、 Root的介绍1. Root 的目的可以让我们拥有掌控手机系统的权限&#xff0c;比如删除一些system/app下面的无用软件&#xff0c;更换开…

oracle事务提交前更新机制,Oracle 事务机制 批量添加,修改,更新

---------------------------------------------------------------------------------------------2011-12-14编辑-------------------------------------------------------------------------------------------------------------------using (OracleConnection oc new Or…

webpack实用配置

注意&#xff1a;以下内容是在vue-cli脚手架的基础上进行添加&#xff01; 1、单个文件抽离 webpack.base.conf.js里边的webpackConfig{}里边对入口文件进行配置&#xff0c;输入你想要抽离的文件&#xff0c;比如vux这个ui框架很大&#xff0c;很有必要抽离 entry: {app: ./sr…

设计模式:原型

创新设计模式之一是原型设计模式 。 尽管原型是创造模式&#xff0c;但它在概念上与其他模式有所不同。 我的意思是原型在某种意义上创造了自己。 我将在下面解释。 原型模式的所有魔力都基于Java Object的clone&#xff08;&#xff09;方法。 因此&#xff0c;让我们考虑一…

SecureCRT连接AWS EC2云主机密码登录

申请了亚马逊的EC2&#xff0c;要通过ssh 加密钥的形式登录&#xff0c;特别麻烦&#xff0c;而且感觉ssh登录AWS的云主机后好卡&#xff0c;这里是更改成用户名和密码的形式登录云主机&#xff0c;可以通过SecureCRT直接登录 1、首先通过ssh登录到EC2&#xff0c;类似于ssh -i…

母版页

一、母版页简介 使用 ASP.NET 母版页可以为应用程序中的页创建一致的布局。单个母版页可以为应用程序中的所有页&#xff08;或一组页&#xff09;定义所需的外观和标准行为。 母版之所以称为母版&#xff0c;就是将大部分网页上固定内容&#xff0c;比如导航栏&#xff0c;版…

解决python中join路径分隔符跨平台移植性

在Windows中路径分隔符是“\”&#xff0c;而Linux中则是“/”。这样一来&#xff0c;如果我们写了这样一段代码&#xff1a; 1 import os 2 3 print(os.path.join(C:\\, a, b.txt)) 在Windows中运行时是没有问题的&#xff0c;但是在Linux当中就有问题了&#xff0c;反之亦然…

现代网络开发

在过去的几年中&#xff0c;网络技术经历了快速增长和重大变化。 我们从框架到表格布局&#xff0c;再到列布局&#xff0c;再到响应式布局。 从html4到xhtml和Flash到html5。 从重型服务器到富客户端。 从rpc到肥皂休息。 从sql到nosql和大数据。 从MVC到MVP等。 在以下文章中…

php脚本来创建一个表,PHP - SQL脚本创建器

我需要的&#xff1a;一个高效的SQL脚本生成器来替换下面的。的背景。一个非常简单的程序&#xff0c;但我需要一个更有效的方式来生成它&#xff0c;我有这个代码的原因是我需要其他开发人员能够在我的平台和数据库表上创建“模块”&#xff0c;但我阻止他们拥有完全访问权限到…

openLayers 4 canvas图例绘制,canvas循环添加图片,解决图片闪烁问题

一、问题来源&#xff1a; 接触Openlayers 一段时间了&#xff0c;最近做了一个农业产业系统&#xff0c;项目中涉及到产业图例&#xff0c;最后考虑用canvas来绘制图例图像。当中带图片的图例移动时&#xff0c;图片会实现闪烁留白情况。闪烁是因为绘制图片本身的复杂性&#…

Akka应用模式:分布式应用程序设计实践指南pdf

下载地址&#xff1a;网盘下载 对于想要学习Akka的Java 和 Scala 开发者们&#xff0c;有很多技术资源可供参考&#xff0c;但是如要想知道如何去应用这些技术就需要不同的思维方式了。为了帮助你正确地使用Akka&#xff0c;《Akka应用模式&#xff1a;分布式应用程序设计实践指…

使用番石榴的5个理由

Guava是一个开放源代码库&#xff0c;其中包含许多Java类&#xff0c;由Google编写。 它是杂项实用程序函数和类的潜在有用来源&#xff0c;我敢肯定&#xff0c;许多开发人员以前已经写过自己&#xff0c;或者只是想要并且从来没有时间编写它们。 这是使用它的5个充分理由&…

哈密尔顿算法matlab,复杂制造过程最优哈密尔顿圈算法的MATLAB仿真与分析.doc

摘要&#xff1a;当今的工业制造过程越来越复杂&#xff0c;产品生产批量化&#xff0c;单个产品组成零部件数量庞大&#xff0c;加工需要多道工序&#xff0c;且工序间连续性强&#xff0c;整个制造过程属于离散制造&#xff0c;这样必然会使生产制造过程复杂化。在这种情况下…

Python 编程核心知识体系(REF)

Python 编程核心知识体系&#xff1a; https://woaielf.github.io/2017/06/13/python3-all/ https://woaielf.github.io/page2/ 转载于:https://www.cnblogs.com/hopesun/p/8340514.html

为input输入框添加圆角并去除阴影

<input type"text" name"bianhao" value"" placeholder"请输入商品编号" maxlength"10" size"10" style"width:105px; margin:0px 0px 0px 12px;height:22px;border-radius:4px;border:1px solid #DBDBD…

flask基础之jinja2模板-语法定义

懂得MVC的人都知道&#xff0c;模型、视图、控制&#xff0c;下面要要介绍的jinja就是视图层的一个渲染模板&#xff0c;类似于jsp&#xff0c;下面来学习 一、jinja2基本语法 jinja2模板可以保存在任何基于文本的文件中&#xff0c;比如XML、HTML、CSV等&#xff0c;所以模板文…

Java DB嵌入式模式

Java DB是基于Java编程语言和SQL的关系数据库管理系统。 这是Apache软件基金会的开源Derby项目的Oracle版本。 Java SE 7 SDK中包含Java DB。 Java DB有两个部署选项&#xff1a; Embedded和Network Server 。 这篇文章是关于嵌入式部署或模式的。 1.嵌入式 在嵌入式模式下&…

php 多线程处理redis,redis的多线程

目录先说明下redis也是多线程的.但是redis的主线程处理业务.而其他三个线程跟主要功能是关系不到的redis的三个线程主要是做什么初始化入口void initServer(void) {...bioInit();...}初始化后redis其他后台线程.void bioInit(void) {pthread_attr_t attr;pthread_t thread;size…

linux内核删不掉,linux 删除内核文件,未能启动,修复方法 CDROM与网络法

当缺少 /boot 内核文件vmlinuz-2….initramfs-2…此时只能借助 光盘 CDROM 来引导生成进入 RESCUE 模式1 chroot /mnt/sysimagemount /dev/cdrom /mnt/cdromcd /mnt/cdromcd isolinux cp vmlinuz /boot/按照…