使用CSS3做一个飘动的照片效果

2023-10-11 07:30

本文主要是介绍使用CSS3做一个飘动的照片效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这个照片飘动的效果,最早是在我的婚纱电子相册中看到了,本来以为是要像AE这种专业制作特效的视频软件才能做,后来发现,其实CSS3也能简单制作出来。
先来看下CSS3做出来的效果:
在这里插入图片描述

其实做起来不难,只是有几个地方需要注意下,不然你会发现效果无法出现。
主要用到下面几个属性:
1、perspective,设置元素被查看位置的视图
2、transform,对元素进行旋转、缩放、移动或倾斜
3、animation,设置元素动画

一、设置perspective

目前浏览器都不支持 perspective 属性。
Chrome 和 Safari 支持替代的 -webkit-perspective 属性。
这里就是第一个要注意的地方了,需要使用-webkit-perspective才能达到想要的效果。
-webkit-perspective属性是对其子元素起作用,使子元素会获得透视效果。所以我们要在img外层加上一层div来设置这个属性。

<style>
div{-webkit-perspective:150;//这个数值可自行修改
}
</style>
<div>
<img src=""/>
</div>

二、设置transform属性

接着就是给img标签设置transform属性,使用照片有旋转效果。

<style>
img{width:10em;height:15em;box-shadow:0 0 0 1em white;transform:rotateY(20deg);
}
</style>
<img src="" />

上面的rotateY()就是绕Y轴(垂直方向)进行旋转,正常情况下是没有效果的,但是配合上层div的-webkit-perspective属性,效果就会出现了。
这里有第二个要注意的地方,就是img的width和div的width要设置成一样的,不然左右旋转(rotate参数正负)时,效果会有差异。

三、设置动画

因为我们是要做飘动的效果,所以是要“动”起来的。

<style>
img{animation:rotate-anim 5s ease-in-out infinite;
}
@keyframes rotate-anim{0%{transform:rotateY(-20deg);}50%{transform:rotateY(20deg);}100%{transform:rotateY(-20deg);}
}
</style>

为了使用效果逼真一点,这里animation的速度曲线使用easa-in-out,表示动画以低速开始和结束。

好了,到这里就结束了。有需要demo的,可以点击下载。

这篇关于使用CSS3做一个飘动的照片效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/186498

相关文章

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳