❤520,就用CSS給你的她(他)送顆心❤

clipboard.png

今天是520。
一句溫柔的問候,一束美麗的鮮花,一段真情的告白。
可是做爲一名不同凡響的程序員,咱們可不單單擁有上面的傳情方法,別忘了每一個人的手上但是都有其餘人不具有的神奇技能,就是咱們天天辛辛苦苦敲下的代碼。css

在這個特殊的日子,就用咱們手中的魔法代碼,來給你的她(他)製做出一個不同凡響的禮物吧。
下面,介紹三種CSS畫心形的方法。實現過程都很是簡單,保證你一看就會。css3

1.一顆div一顆心

用一個div畫出一個心,核心的方法就是使用僞元素。
首先,咱們在頁面上先寫出一個div:程序員

<div></div>

使用CSS,將這個div變爲一個橘紅色的正方形:wordpress

div {
  position:relative;
  top: 100px;
  left: 50%;
  width: 100px;
  height: 100px;
  background-color: tomato;
}

clipboard.png

接着咱們利用元素的兩個僞元素:before和:after,畫出一個藍色的圓和一個黃色的圓,而且將它們的圓心分別定位在正方形的上邊和右邊。動畫

div:before {
  content: "";
  position:absolute;
  top: -50px;
  left: 0;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background-color: blue;
}
div:after{
  content: "";
  position: absolute;
  top: 0px;
  left: 50px;
  width: 100px;
  height: 100px;
  background-color: yellow;
  border-radius: 50%;
}

clipboard.png

再來,將剛剛實現的兩個圓變成和正方形同樣的顏色:spa

div:before {
  ...
  background-color: tomato;
}
div:after{
  ...
  background-color: tomato;
}

clipboard.png

最後,將元素div旋轉45度,咱們要的心形就實現了!就是這麼簡單。3d

div {
  position:relative;
  top: 100px;
  left: 50%;
  width: 100px;
  height: 100px;
  background-color: tomato;
  transform: rotate(-45deg);
}

clipboard.png

2.一顆心不夠,那咱們就畫一屏

一顆心不夠表達個人心意,那麼就給她畫出一屏幕的心。
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤code

我對你有表達不完的心意,就有寫不完的div:orm

HTML:blog

<h1>愛無處不在...</h1>
<div class="heart"></div>
<div class="heart"></div>
<div class="heart"></div>
<div class="heart"></div>
<div class="heart"></div>
<div class="heart"></div>
<div class="heart"></div>
<div class="heart"></div>
...

浮動讓它們填滿整個屏幕:

.heart{
  position: relative;
  width: 100px;
  height: 90px;
  float: left;
}

兩個僞元素表明個人左心房和右心房:

.heart:before,
.heart:after{
  position: absolute;
  content: "";
  left: 50px;
  top: 0;
  width: 50px;
  height: 80px;
  background: #fc2e5a;
  border-radius: 50px 50px 0 0;
  transform-origin: 0 100%;
}
.heart:after{
  left: 0;
  transform-origin :100% 100%;
}

clipboard.png

讓左右心房都旋轉45度,就造成了我滿滿的一屏幕心:

.heart:before,
.heart:after{
  ...
  transform: rotate(-45deg);
}
.heart:after{
  ...
  transform: rotate(45deg);
}

clipboard.png

3.我對你的愛有多深

「之前我看事物,是用肉眼去看,可是在我死去的那一剎那,我開始用心眼去看這個世界,全部的事物,真的能夠看得史無前例的那麼清楚。」 -周星馳

不管有多少顆心都不能表達出我對你的愛意有多深,因而,我要讓你看到個人心都是由每個愛你的細胞所組成的:

<div class="heart"></div>

CSS:

.heart {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 105px;
  height: 105px;
  margin: -52.5px 0 0 -52.5px;
}

像素級的世界能夠由box-shadow屬性實現(參考文章《CSS3 box-shadow盒陰影圖形生成技術》):

.heart::before {
  content: '';
  display: block;
  transition: all 400ms;
  width: 15px;
  height: 15px;
  margin: -15px 0 0 -15px;
  box-shadow: 30px 15px #8e1a19, 45px 15px #ac0500, 75px 15px #f73f0c, 90px 15px #fa5f27, 15px 30px #740100, 30px 30px #8e0500, 45px 30px #8e1918, 60px 30px #ca1300, 75px 30px #f34f2b, 90px 30px #df351f, 105px 30px #f77c2a, 15px 45px #4b0000, 30px 45px #690100, 45px 45px #8e0f0b, 60px 45px #bf1000, 75px 45px #f84010, 90px 45px #f04222, 105px 45px #fa5724, 15px 60px #451312, 30px 60px #5a0100, 45px 60px #840e0c, 60px 60px #a51d1a, 75px 60px #ed2805, 90px 60px #d9321e, 105px 60px #f44622, 30px 75px #3b0000, 45px 75px #5d1a1b, 60px 75px #8e1a19, 75px 75px #a80700, 90px 75px #b90a00, 45px 90px #3d0000, 60px 90px #551415, 75px 90px #670100, 60px 105px #340000;
  animation: pulse 1.2s steps(1) infinite;
}

clipboard.png

就這樣,一個像素級的心形就完成了,接着咱們還能夠給它添加上一個動畫效果,讓它的每個細胞都產生動畫的效果,你能夠嘗試一下。

最後,再送你一個CSS心形動畫效果:
圖片描述

獲取上面全部心形的代碼能夠:
圖片描述

相關文章
相關標籤/搜索