今天是520。
一句溫柔的問候,一束美麗的鮮花,一段真情的告白。
可是做爲一名不同凡響的程序員,咱們可不單單擁有上面的傳情方法,別忘了每一個人的手上但是都有其餘人不具有的神奇技能,就是咱們天天辛辛苦苦敲下的代碼。css
在這個特殊的日子,就用咱們手中的魔法代碼,來給你的她(他)製做出一個不同凡響的禮物吧。
下面,介紹三種CSS畫心形的方法。實現過程都很是簡單,保證你一看就會。css3
用一個div畫出一個心,核心的方法就是使用僞元素。
首先,咱們在頁面上先寫出一個div:程序員
<div></div>
使用CSS,將這個div變爲一個橘紅色的正方形:wordpress
div { position:relative; top: 100px; left: 50%; width: 100px; height: 100px; background-color: tomato; }
接着咱們利用元素的兩個僞元素: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%; }
再來,將剛剛實現的兩個圓變成和正方形同樣的顏色:spa
div:before { ... background-color: tomato; } div:after{ ... background-color: tomato; }
最後,將元素div旋轉45度,咱們要的心形就實現了!就是這麼簡單。3d
div { position:relative; top: 100px; left: 50%; width: 100px; height: 100px; background-color: tomato; transform: rotate(-45deg); }
一顆心不夠表達個人心意,那麼就給她畫出一屏幕的心。
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤
❤❤❤❤❤❤❤❤❤❤❤❤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%; }
讓左右心房都旋轉45度,就造成了我滿滿的一屏幕心:
.heart:before, .heart:after{ ... transform: rotate(-45deg); } .heart:after{ ... transform: rotate(45deg); }
「之前我看事物,是用肉眼去看,可是在我死去的那一剎那,我開始用心眼去看這個世界,全部的事物,真的能夠看得史無前例的那麼清楚。」 -周星馳
不管有多少顆心都不能表達出我對你的愛意有多深,因而,我要讓你看到個人心都是由每個愛你的細胞所組成的:
<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; }
就這樣,一個像素級的心形就完成了,接着咱們還能夠給它添加上一個動畫效果,讓它的每個細胞都產生動畫的效果,你能夠嘗試一下。
最後,再送你一個CSS心形動畫效果:
獲取上面全部心形的代碼能夠: