WP酷 WP酷
  • 主题
  • 教程
  • 插件
  • 官方 QQ 群
  • 建站推荐
  • 联系
  • nicetheme® 奈思主题
  • 注册
    登录
立即登录
  • 请到 [后台->外观->菜单] 中设置菜单
首页 › 杂记 › HTML5+CSS3 完美实现WWDC 2015动画效果

HTML5+CSS3 完美实现WWDC 2015动画效果

PCDotFan8年前

译文 Via @W3CPlus,原文 Via @CSSAnimation。

每年,苹果都会召开一次重大的会议。WWDC(苹果开发者大会)是iOS开发者和OSX开发者学习苹果先进高科技和移动设备与桌面软件新概念的好机会。

每一年的这个时候,他们都会制造出很多新创意,今年,我被一个用简单圆圈和形状制作出来的图标所惊艳,于是我决定用 HTML 和 CSS 来实现它。

 

WWDC 15邀请卡

苹果的图标通常都会使用颜色和形状的叠加,比如iOS 7 Photos图标。今年WWDC邀请函用了下面这货。

HTML5+CSS3 完美实现WWDC 2015动画效果-WP酷

它由一些列层叠和半透明的形状构成,非常适合用HTML和CSS来实现。

 

HTML

设计这样一块负责的东西需要稍微分析一下。首先,我把它分解成各个部分。 大方向看它是由三种形状构成的,主要图形为8个大圆,我先把它们列出来:

这里我分割成几个类,这样做方便后面把large  article 等类提取出来单独写,代码会整洁很多。

然后我们有八个小形状,处于大圆的上边,这些形状由4个圆形和4个方形构成,方形是由圆角的,我这样写HTML:

我用了circle 、squircle  以及数字1到8来为各个div 设置类名,这样做的好处是,后面为它们设置形状和颜色的时候很方便。

最后我们把两个大方形反倒logo中间。

同样,我用了large  、squircle 做Logo和内容。

接下来我们给中间的方形增添点内容。

The epicenter of change.

WWDC15

这里我们用了一个SVG图片,还有邀请函的内容。邀请函的字体为San Francisco 。但是字体不是OSX标准的,所以这里我换成Helvetica Neue Light 。

 

写圆和方块样式

我要做的第一件事是把circle 、squircle 的样式写好。

.circle, .squircle {
  border-top: 0.1em solid rgba(255,255,255,0.4);
  height: 12.5em;
  position: absolute;
  width: 12.5em;
}

大部分形状偏大。每个元素的定位都是absolute 并且有一个白的边框。边框可能不会跟邀请函的一模一样,但是可以给形状多点光泽。

接下来我们给大圆加上样式,设置border-radius 为50% ,并且使用left 、top值设置位置。

.circle {
  border-radius: 50%;
  box-shadow: 0 1em 2em rgba(0,0,0,0.5);
  left: calc(50% - 6.25em);
  top: calc(50% - 12.5em);
  transform-origin: 50% 12.5em;
}

这个时候所有的圆都是在同一个位置上边。我们使用点小技巧,通过transform-origin 
的值来改变位置。默认的transform-origin 值为(50%,50%),这里我们把值设为圆的底部,然后我们稍微旋转一下,形状就出来了。

HTML5+CSS3 完美实现WWDC 2015动画效果-WP酷

让我们给每个圆添加CSS样式,仔细研究邀请函的图片,我们可以看到一个圆的位置在左下角。知道了这一点,我们就可以写出其他与圆圈的旋转角度。

.one {
  background: rgba(16, 63, 236, 0.75);
  transform: rotateZ(225deg);
}
.two {
  background: rgba(37, 172, 162, 0.75);
  transform: rotateZ(180deg);
}
.three {
  background: rgba(233, 124, 32, 0.75);
  transform: rotateZ(135deg);
}
.four {
  background: rgba(235, 67, 35, 0.75);
  transform: rotateZ(90deg);
}
.five {
  background: rgba(190, 28, 65, 0.75);
  transform: rotateZ(45deg);
}
.six {
  background: rgba(208, 57, 159, 0.75);
  transform: rotateZ(0);
}
.seven {
  background: rgba(150, 32, 198, 0.75);
  transform: rotateZ(-45deg);
}
.eight {
  background: rgba(95, 33, 203, 0.75);
  transform: rotateZ(-90deg);
}

每个块都有一个颜色,并且旋转一定角度。下面的动画动态展示了生成过程。

HTML5+CSS3 完美实现WWDC 2015动画效果-WP酷

有了上面这些原型,我们给其他形状写样式。首先方形也可以看成有不同圆角的圆。

.squircle {
  border-radius: 25%;
}

当我们定位了圆以后,我们给了特定的旋转角度和颜色。高兴的是,相同的形状也可以使用相同的样式,我们写好小形状的样式。

.small {
  width: 4em;
  height: 4em;
  left: calc(50% - 2em);
  top: calc(50% - 15em);
  transform-origin: 50% 15em;
  box-shadow: 0 0.25em 0.5em rgba(0,0,0,0.2);
}

我们把这些形状设得小一些,并且离中心更远的距离。并且使用跟上面相同的Trick。

 

小方块

小的方形角度错了,我们需要给它旋转45deg 。

HTML5+CSS3 完美实现WWDC 2015动画效果-WP酷

这里有两种方法可供选择,我们可以给每个方形加多一个额外的元素,并旋转,或者我们选择CSS中的伪类。两种方法都行,不过我更倾向于后者。

首先我们把背景颜色,边框,盒子阴影去掉。

.small.squircle {
  background: none;
  border: none;
  box-shadow: none;
}

我们使用::after 伪类来创建一个相同的方形,并旋转45deg 。

.small.squircle::after {
  background: red;
  border-radius: 25%;
  box-shadow: -0.25em 0.25em 0.5em rgba(0,0,0,0.2);
  content: "";
  height: 100%;
  position: absolute;
  transform: rotateZ(-45deg);
  width: 100%;
}
.small.squircle.two::after {
  background: rgba(37, 172, 162, 0.75);
}
.small.squircle.four::after {
  background: rgba(235, 67, 35, 0.75);
}
.small.squircle.six::after {
  background: rgba(208, 57, 159, 0.75);
}
.small.squircle.eight::after {
  background: rgba(95, 33, 203, 0.75);
}

现在我们有了大圆和其他小形状了。

HTML5+CSS3 完美实现WWDC 2015动画效果-WP酷

 

内容方块

两个大的方形包含所有内容,我们把他们定位到中间,并且给他们一个比较深的透明色。

.large.squircle {
  background: rgba(30, 7, 66, 0.65);
  border: none;
  height: 15em;
  left: calc(50% - 7.5em);
  position: absolute;
  top: calc(50% - 7.5em);
  transform: none;
  width: 15em;
}

我们可以旋转一下第一个大方形。

.large.squircle.one {
  transform: rotateZ(45deg);
}

HTML5+CSS3 完美实现WWDC 2015动画效果-WP酷

 

添加动画

最初的邀请函是静态的,但是我们的网站叫做 CSS Animation Rocks,这可不是浪得虚名。

我像把每个集合分开,为了做到这一点,我用span 元素把它们分别包裹起来,后面就把动画应用到span 元素上即可。


  


  

  

  

我们先给span 元素定位,防止他们溢出。

span {
  display: block;
  height: 20em;
  left: calc(50% - 10em);
  position: absolute;
  top: calc(50% - 10em);
  width: 20em;
}

每个span 元素都定位到中点。

接下来我们把动画应用到每个span元素上面。

.large-circles {
  animation: spin 10s linear infinite;
}
.small-shapes {
  animation: spin 30s linear infinite;
}
.content-squircle {
  animation: spin 20s linear infinite;
}

我们使用了相同的keyframes 但是改变了动画时间,分别为 10s, 20s, 30s。于是他们一分钟后回到原来的位置。如下所示

@keyframes spin {
  0% {
    transform: rotateZ(0);
  }
  100% {
    transform: rotateZ(360deg);
  }
}

 

重用CSS

这是个有趣的实验,但是我觉得最大的收获是重用了CSS.旋转和小形状使用相同的CSS很方便。还有所有的animation 用了同一个keyframes 。这样有助于压缩CSS文件的大小,保证加载速度。

 

前缀

创建这个例子的时候,我用了autoprefixer,这样就不用每次写动画都要考虑浏览器内核了。

#CSS#Light#logo#半透明
3
分享

本站下载管理系统「dl.mywpku.com」因年久失修而永久关闭。若需获得往年主题,请至 WP酷的百度网盘(提取码: 5rbm) 自行搜索下载。默认解压密码为「www.mywpku.com」。

对您造成的不便,敬请谅解!

PCDotFan 站长
文章 435评论 859
相关文章
  • 近疫 – 新冠疫情地图小程序
  • Aragaki – 极简自适应 Bitcron 博客主题
  • [持续更新]Diaspora – 素色响应式单栏 WordPress 博客主题
  • 各位…再见?
  • [¥88]PCKr – 多功能响应式 WordPress 资讯主题
  • 硬广:金主恒创西南大数据中心节点上线
  • 主阵地转移到 WordPress Log
  • Mandy 2.0 – 让美延续下去 WordPress 手机主题
评论 (4)
再想想
  • alinwei

    炫酷

    8年前
  • 蚊哥

    叼炸天的技能

    8年前
  • 小冰

    太炫了吧,酷!

    8年前
  • 何关东

    对技术牛逼的人我表示深深的崇拜!

    8年前
PCDotFan
站长
若无特别注明,则默认我发布的所有文章均为内容原创 / 翻译原创,转载时请保留来源。
435文章
859评论
3K获赞
猜你喜欢
WordPressER恶意采集本站文章行为
9年前
我最喜爱的十佳WordPress博客
9年前
GoodNice – 双栏简白WordPress博客主题
9年前
  • 杂记
  • WordPress 付费主题推荐
Copyright © 2023 WP酷. Designed by nicetheme. 琼ICP备13002067号-1