今天在网上看到一个国外写的CSS3 3D Bouncing Ball(3D反弹球),很有意思,并且实现起来也不难,于是忍不住自己也试写一遍。

好玩的东西当然要大家一起分享,所以接下来我就简单讲解一下如何实现跳动的效果

首先讲解一下结构,wrap是用来控制小球跳动的区域,ball就是小球啦,ballshadow是用来制作小球的投影,因为小球的运动和投影部分的运动(动画)效果是分开的,所以小球和投影部分要两个div来组成,而wrap设置的高度即为小球运动的高度,此时我们就可以通过top属性来很好的控制小球的位置变化。

小球运动区域CSS

.wrap {

width: 150px;

height: 300px;

position: absolute;

left: 50%;

top: 50%;

margin: -150px 0 0 -75px;

}

小球的CSS

通过渐变和投影来制作小球的立体感

.ball {

width: 100px;

height: 100px;

border-radius: 50%;

background: rgb(187,187,187);

background: url();

background: -moz-linear-gradient(top, rgba(187,187,187,1) 0%, rgba(119,119,119,1) 99%);

background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(187,187,187,1)), color-stop(99%,rgba(119,119,119,1)));

background: -webkit-linear-gradient(top, rgba(187,187,187,1) 0%,rgba(119,119,119,1) 99%);

background: -o-linear-gradient(top, rgba(187,187,187,1) 0%,rgba(119,119,119,1) 99%);

background: -ms-linear-gradient(top, rgba(187,187,187,1) 0%,rgba(119,119,119,1) 99%);

background: linear-gradient(top, rgba(187,187,187,1) 0%,rgba(119,119,119,1) 99%);

filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#bbbbbb', endColorstr='#777777',GradientType=0 );

box-shadow: inset 0 -5px 15px rgba(255,255,255,0.4),

inset -2px -1px 40px rgba(0,0,0,0.4),

0 0 1px #000;

position: absolute;

z-index: 99;

}

小球反光面的CSS

利用after伪类来实现,通过渐变和圆角属性来实现半透明椭圆形遮罩

.ball::after {

content: "";

width: 60px;

height: 30px;

position: absolute;

left: 20px;

top: 10px;

z-index: 10;

background: url();

background: -moz-linear-gradient(top, rgba(232,232,232,1) 0%, rgba(232,232,232,1) 1%, rgba(255,255,255,0) 100%);

background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(232,232,232,1)), color-stop(1%,rgba(232,232,232,1)), color-stop(100%,rgba(255,255,255,0)));

background: -webkit-linear-gradient(top, rgba(232,232,232,1) 0%,rgba(232,232,232,1) 1%,rgba(255,255,255,0) 100%);

background: -o-linear-gradient(top, rgba(232,232,232,1) 0%,rgba(232,232,232,1) 1%,rgba(255,255,255,0) 100%);

background: -ms-linear-gradient(top, rgba(232,232,232,1) 0%,rgba(232,232,232,1) 1%,rgba(255,255,255,0) 100%);

background: linear-gradient(top, rgba(232,232,232,1) 0%,rgba(232,232,232,1) 1%,rgba(255,255,255,0) 100%);

filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e8e8e8', endColorstr='#00ffffff',GradientType=0 );

border-radius: 40px / 20px;

}

投影部分的CSS

利用半透明的背景和模糊滤镜来制作投影效果

.ballshadow {

width: 100px;

height: 50px;

border-radius: 50%;

background: rgba(0,0,0,0.3);

position: absolute;

filter: url(blur.svg#blur); /* FireFox, Chrome, Opera */

-webkit-filter: blur(10px); /* Chrome, Opera */

-moz-filter: blur(10px);

-ms-filter: blur(10px);

filter: blur(10px);

filter: progid:DXImageTransform.Microsoft.Blur(PixelRadius=10, MakeShadow=false); /* IE6~IE9 */

bottom: 0;

}

这样就完成了整个画布的布局,接下来我们要为他增加动画效果,首先是小球的运动

这里只贴出一个兼容-webkit-的写法,通过scale(缩放)来使当小球产生一种反弹挤压的效果,原作中是通过控制border-radius的变化来产生挤压效果,感觉不太好计算,倒不如缩放来的爽快。

同时有一点要注意,当小球的top等于wrap的高度减去小球自身的高度时就是小球碰撞到底部的位置了。

@-webkit-keyframes bounce {

0% {top: 0;

-webkit-animation-timing-function: ease-in;

}

40% {}

50% {

top: 180px;

-webkit-animation-timing-function: ease-out;

-webkit-transform:scale(1);

}

55% {

top: 200px;

-webkit-transform:scale(1, 0.65);

-webkit-animation-timing-function: ease-in;

}

65% {

top: 160px;

-webkit-transform:scale(1);

-webkit-animation-timing-function: ease-out;}

95% {

top: 0;

-webkit-animation-timing-function: ease-in;

}

100% {

top: 0;

-webkit-animation-timing-function: ease-in;

}

}

投影部分的动画:

投影部分的动画再简单不过了,原作中同样是使用border-radius来控制一个缩放的效果,这里我们直接使用scale,并且配合动画的速度曲线属性来迎合跳动小球变化

@-webkit-keyframes shrink {

0% {

-webkit-transform:scale(1);

-webkit-animation-timing-function: ease-in;

}

50% {

-webkit-transform:scale(0.7);

-webkit-animation-timing-function: ease-out;

}

100% {

-webkit-transform:(1);

-webkit-animation-timing-function: ease-in;

}

}

接着我们为元素添加上相应的动画就OK了

.ball {

animation: bounce 1s infinite linear;

-webkit-animation: bounce 1s infinite linear;

-moz-animation: bounce 1s infinite linear;

-o-animation: bounce 1s infinite linear;

}

.ballshadow {

-webkit-animation: shrink 1s infinite linear;

-moz-animation: shrink 1s infinite linear;

animation: shrink 1s infinite linear;

-o-animation: shrink 1s infinite linear;

}

那么该如何实现点击hold住的时候让小球越跳越远?其实这只是利用了一个视觉效果,让整个wrap缩放,由1至0就会产生这样的效果,这里的实现方式就不说了,有兴趣的话大家自己尝试一下,利用active伪类就可以实现按下hold出现的状态。

html和css如何制作小球,雨林寒舍 | CSS3制作3D跳动的小球相关推荐

  1. css金币动画_用纯CSS3制作的金币(铜币 | 钱币)

    CSS 语言: CSSSCSS 确定 body { margin: 0; background: #262626; } span { font-family: "Montserrat&quo ...

  2. css中如何写出长方体,CSS3 可伸缩3D长方体

    CSS 语言: CSSSCSS 确定 html, body { height: 100%; } body { font-size: 200px; background: #000; overflow: ...

  3. css拖动音乐进度条,利用CSS3实现3D滑块进度条拖动动画特效

    特效描述:利用CSS3实现 3D滑块 进度条拖动 动画特效.利用CSS3实现3D滑块进度条拖动动画特效 代码结构 1. HTML代码 Scalable 3D Range Sliders Simple ...

  4. html局部可复制,截取网页局部区域css样式的方法和系统的制作方法

    截取网页局部区域css样式的方法和系统的制作方法 [技术领域] [0001]本发明涉及计算机网络技术领域,特别是涉及一种截取网页局部区域CSS样式的方法和系统. [背景技术] [0002]CSS(Ca ...

  5. 谈谈一些有趣的CSS题目(十三)-- 巧妙地制作背景色渐变动画!

    谈谈一些有趣的CSS题目(十三)-- 巧妙地制作背景色渐变动画! 原文:谈谈一些有趣的CSS题目(十三)-- 巧妙地制作背景色渐变动画! 开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到 ...

  6. HTML5期末大作业:漫画网站设计——海贼王我当定了(6页) web前端期末大作业 html+css+javascript网页设计实例 企业网站制作 计算机毕设网页设计源码

    HTML5期末大作业:漫画网站设计--海贼王我当定了(6页) web前端期末大作业 html+css+javascript网页设计实例 企业网站制作 计算机毕设网页设计源码 常见网页设计作业题材有 个 ...

  7. 用html和css制作日历,CSS3制作日历

    前面使用了CSS3制作过Progress Bars.分页导航.Login栏.Search Box等等.今天一起和大家使用css3来制作一个日历效果,希望大家喜欢. 目标 今天我们的目标是制作如下面DE ...

  8. css html 高仿word 格式,制作的可编辑的微软Word样式文档 HTML-Sheets-of-Paper

    这是一款使用HTML和CSS3制作的可编辑的微软Word样式文档.该特效提供一组预定义的样式,用于在WEB页面中生成各种尺寸的Word样式的文档效果.它提供的样式包括: sheets-of-paper ...

  9. web前端期末大作业(月饼美食网站) html+css+javascript网页设计实例 企业网站制作...

    web前端期末大作业(月饼美食网站) html+css+javascript网页设计实例 企业网站制作 临近期末, 你还在为HTML网页设计结课作业,老师的作业要求感到头大?HTML网页作业无从下手? ...

  10. HTML+CSS 简单的顶部导航栏菜单制作

    导航栏的制作: 技术要求: CSS HTML各类标签 实现目的: 制作导航栏菜单 代码分析: 基本样式清除 无序列原点删除 下划线删除 文字默认居中 a标签设置块级元素 伪类选择器对a状态修饰 分步实 ...

最新文章

  1. 深入理解 Spring Boot Starters 原理
  2. 【Hibernate步步为营】--双向关联一对一映射具体解释(一)
  3. mysql调度触发器,MySQL触发器:达到某个datetime时更新
  4. php.ini 老薛,出现Allowed memory size of 134217728 bytes exhausted怎么办?
  5. 差分隐私中随机响应的抛硬币问题(LDP)
  6. Python day 9(3) 定制类
  7. 6N137中文说明书 光耦资料 6N137资料
  8. “2021年度全球十大人工智能治理事件”:数据、算法、伦理受关注,AI发展需治理同行
  9. 曹则贤:从一元二次方程到规范场论 | 中国科学院2022跨年科学演讲
  10. VMware虚拟机安装Windows XP学习教程
  11. html边界填充边框,CSS边界与填充
  12. VMware 磁碟機未備妥
  13. 用python画分段函数图像_使用Python的matplotlib画出一个分段函数的图像
  14. Python使用OpenPyXl设置Excel表格中的单元格大小(行高和列宽)
  15. method.invoke()和invoke()简单理解
  16. c++ 中的生僻关键字
  17. 菜鸟后端程序员花了两天半模仿写出了赶集网主页,速来围观!
  18. 基于jsp的旅游信息网站的设计
  19. 安卓一键清理内存_【安卓】手机垃圾清理,拯救内存空间
  20. hdu2838(树状数组)

热门文章

  1. 雅虎市值_也许不算雅虎! 刚出来
  2. chessbase(ChessBase Mega)
  3. HTML嵌入百度地图
  4. 人生七年,耗时56年跟拍14个孩子,结局道尽人生残酷真相
  5. 《人生七年》纪录片-个体心理学中的自卑与超越角度解读
  6. cdr 表格自动填充文字_【Excel技巧】excel单元格自动填充英文字母编号
  7. win7定时关机命令_如何让win7操作系统实现定时关机,以防我们忘记电脑关机
  8. 字符串intern()方法详解
  9. 直播活动策划方案怎么做
  10. 善战者 说——孙子兵法