教你用CSS3打造HTML5的Logo

开发 前端
本文将向大家介绍如何利用CSS3的新样式属性制作一个HTML5的Logo。

本文将向大家介绍如何利用CSS3的新样式属性制作一个HTML5的Logo。我们先来看看最终的效果:

 

不要怀疑,上面的logo完全由HTML+CSS实现。我们将logo划分为盾形、数字5和辐射背景三大部分,下面将分别实现每个部分。

盾形

盾形在外形上是左右对称的,因此我们可先完成左半边,右半边可复制过来再修改一些参数。左半边准备用三个div实现,其中有两个div需要倾斜一定的角度来实现盾形的左边和底边,这里使用transform的skew来完成。代码如下(注意,这里只使用了webkit前缀的样式,仅在Chrome、Safari等Webkit内核浏览器支持):

<!-- left side -->  
<div class="dark_orange" style="left:32px;width:140px;height:346px;"></div>  
<div class="dark_orange" style="-webkit-transform:skewx(5deg);left:16px;width:100px;height:346px;"></div>  
<div class="dark_orange" style="-webkit-transform:skewy(15deg);top:265px;left:32px;width:140px;height:100px;"></div> 
  • 1.
  • 2.
  • 3.
  • 4.

其中,CSS样式定义所有div都是绝对定位,dark_orange类指定了一个橘色背景:

div{position:absolute}  
.dark_orange{background:#e15016
  • 1.
  • 2.

我们看一下效果:

 

下面我们再复制一遍HTML,修改一些参数作为盾形的右侧:

<!-- right side -->  
<div class="dark_orange" style="left:32px;width:140px;height:346px;"></div>  
<div class="dark_orange" style="-webkit-transform:skewx(5deg);left:16px;width:100px;height:346px;"></div>  
<div class="dark_orange" style="-webkit-transform:skewy(15deg);top:265px;left:32px;width:140px;height:100px;"></div> 
  • 1.
  • 2.
  • 3.
  • 4.

效果如下:

 

盾形的右侧里面有浅色的区域,我们将盾的右侧复制一份通过scale缩小一点,此外还需要调整一些样式属性:

<!-- inner -->  
<div style="-webkit-transform:scale(0.82);left:31px;top:25px">  
  <div class="light_orange" style="left:172px;width:140px;height:346px;"></div>  
  <div class="light_orange" style="-webkit-transform:skewx(-5deg);left:227px;width:100px;height:363px;"></div>  
  <div class="light_orange" style="-webkit-transform:skewy(-15deg);top:282px;left:172px;width:138px;height:100px;"></div>  
</div> 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.

light_orange对应浅一点儿的背景色:

.light_orange{background:#ee6812
  • 1.

盾形已经完成了:

 

#p#

数字5

数字5由若干div组成,倾斜的效果依旧通过skew来控制:

<!-- 5 -->  
<div class="light_gray" style="height:43px;width:102px;left:70px;top:70px"></div>  
<div class="light_gray" style="width:46px;height:216px;-webkit-transform:skewx(5deg);top:70px;left:75px;"></div>  
<div class="light_gray" style="height:43px;width:95px;left:77px;top:156px"></div>  
<div class="light_gray" style="height:47px;width:87px;left:85px;top:251px;-webkit-transform:skewy(15deg)"></div>  
<div class="white" style="height:43px;width:102px;left:172px;top:70px"></div>  
<div class="white" style="width:46px;height:216px;-webkit-transform:skewx(-5deg);top:70px;left:223px;"></div>  
<div class="white" style="height:43px;width:95px;left:172px;top:156px"></div>  
<div class="white" style="height:47px;width:87px;left:172px;top:251px;-webkit-transform:skewy(-15deg)"></div>  
 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.

light_gray类和white类对应的样式:

.light_gray{background:#ebebeb}  
.white{background:#fff
  • 1.
  • 2.

我们看到如下效果:

 

为了最终实现数字5,我们需要在两个位置打两个“补丁”:

<!-- patch -->  
<div class="dark_orange" style="height:20px;top:199px;width:80px;left:60px;"></div>  
<div class="light_orange" style="height:43px;top:113px;width:100px;left:180px;"></div> 
  • 1.
  • 2.
  • 3.

最终效果:

 

#p#

辐射背景

辐射背景主要使用rotate来完成,这里我贴出完整的代码:

<!DOCTYPE html>  
<html>  
<head>  
<meta charset="utf-8" />  
<title>HTML5 logo</title>  
<style>  
div{position:absolute}  
.dark_orange{background:#e15016}  
.light_orange{background:#ee6812}  
.light_gray{background:#ebebeb}  
.white{background:#fff}  
.beam{width:1600px;  
height:20px;  
-webkit-transform-origin:800 10;  
top:290px;  
left:-400px}  
</style>  
</head>  
<body style="margin:0;padding:0">  
<div class="bg" style="width:800px;height:600px;background:#f2f2f2;overflow:hidden">  
   <div class="white beam" style="-webkit-transform:rotate(5deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(15deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(25deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(35deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(45deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(55deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(65deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(75deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(85deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(95deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(105deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(115deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(125deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(135deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(145deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(155deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(165deg)"></div>  
   <div class="white beam" style="-webkit-transform:rotate(175deg)"></div>  
   <div class="logo" style="top:120px;left:229px;">  
      <!-- left side -->  
      <div class="dark_orange" style="left:32px;width:140px;height:346px;"></div>  
      <div class="dark_orange" style="-webkit-transform:skewx(5deg);left:16px;width:100px;height:346px;"></div>  
      <div class="dark_orange" style="-webkit-transform:skewy(15deg);top:265px;left:32px;width:140px;height:100px;"></div>  
      <!-- right side --><div class="dark_orange" style="left:172px;width:140px;height:346px;"></div>  
      <div class="dark_orange" style="-webkit-transform:skewx(-5deg);left:227px;width:100px;height:346px;"></div>  
      <div class="dark_orange" style="-webkit-transform:skewy(-15deg);top:265px;left:172px;width:140px;height:100px;"></div>  
      <!-- inner -->  
      <div style="-webkit-transform:scale(0.82);left:31px;top:25px">  
         <div class="light_orange" style="left:172px;width:140px;height:346px;"></div>  
         <div class="light_orange" style="-webkit-transform:skewx(-5deg);left:227px;width:100px;height:363px;"></div>  
         <div class="light_orange" style="-webkit-transform:skewy(-15deg);top:282px;left:172px;width:138px;height:100px;"></div>  
      </div>  
      <!-- 5 -->  
      <div class="light_gray" style="height:43px;width:102px;left:70px;top:70px"></div>  
      <div class="light_gray" style="width:46px;height:216px;-webkit-transform:skewx(5deg);top:70px;left:75px;"></div>  
      <div class="light_gray" style="height:43px;width:95px;left:77px;top:156px"></div>  
      <div class="light_gray" style="height:47px;width:87px;left:85px;top:251px;-webkit-transform:skewy(15deg)"></div>  
      <div class="white" style="height:43px;width:102px;left:172px;top:70px"></div>  
      <div class="white" style="width:46px;height:216px;-webkit-transform:skewx(-5deg);top:70px;left:223px;"></div>  
      <div class="white" style="height:43px;width:95px;left:172px;top:156px"></div>  
      <div class="white" style="height:47px;width:87px;left:172px;top:251px;-webkit-transform:skewy(-15deg)"></div>  
      <!-- patch -->  
      <div class="dark_orange" style="height:20px;top:199px;width:80px;left:60px;"></div>  
      <div class="light_orange" style="height:43px;top:113px;width:100px;left:180px;"></div>  
   </div>  
   <!-- end of logo -->  
</div>  
<!-- end of bg -->  
</body>  
</html> 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.
  • 64.
  • 65.
  • 66.
  • 67.
  • 68.
  • 69.
  • 70.

HTML5的logo已经完成了!

 

 【小编碎语】5555555,小编通过这个方法做出来的标志,已经扭曲变形的另一个样子了,现在还在研究这事为什么,以后会相应补充上。

【编辑推荐】

  1. ***HTML 5与Flash性能比较报告出炉:大跌你的眼球
  2. HTML 5来袭:Web前端开发面临十字路口
  3. 20佳惊艳超炫的HTML 5应用程序示例
  4. 九个令人惊叹的HTML 5和JavaScript实验
  5. 20个HTML 5和CSS3的免费网站模板与教程

 

责任编辑:艾婧 来源: jz1108的博客
相关推荐

2011-06-27 09:47:37

HTML 5

2012-05-21 09:31:56

HTML5

2011-11-21 14:21:56

HTML 5

2012-07-02 14:58:16

HTML5

2011-11-18 13:25:48

HTML 5

2013-07-09 09:24:29

响应式HTML5CSS3

2012-05-30 09:22:56

Hybrid App助HTML5JavaScript

2021-11-18 11:52:49

HTML5小游戏JS

2011-11-25 13:18:40

HTML 5

2012-02-29 09:27:36

ibmdw

2013-08-21 13:19:33

HTML5CSS3表单设计

2010-05-05 17:23:30

OperaCTO

2013-03-04 14:13:13

HTML5CSS3响应式

2011-03-22 08:54:02

HTML 5CSS3JavaScript

2012-05-11 09:37:34

HTML5

2013-03-04 13:14:00

Adobe Edge HTML5

2014-12-03 10:21:50

HTML5

2013-08-09 11:06:20

HTML5CSS3资源

2012-05-24 11:03:55

HTML5

2014-02-24 13:49:13

HTML5CSS3下拉菜单
点赞
收藏

51CTO技术栈公众号