#當我學完css和js後,冒出來一個想法。自己去實現一個可愛的卡通人物。於是我就去codepen找素材,最後選擇了使用CSS實現皮卡丘,如下圖。
在開始寫使用CSS實現皮卡丘之前,我先觀察了使用CSS實現皮卡丘的整個頁面。發現如果要很好的實現這個使用CSS實現皮卡丘你不能像寫傳統網頁那樣從左到右佈局,而是要從中間佈局,因為左右兩邊對稱。理清楚了思路之後現在開始寫頁面結構。
頁面結構如上圖所示,當我們寫完html結構,就可以動手去寫css。
在這個地方我們可以暫時先停一下,再次理清思路。這個使用CSS實現皮卡丘的最難點的部分在哪裡?在於使用CSS實現皮卡丘嘴巴上的弧線以及下面橢圓形的舌頭。
在實現使用CSS實現皮卡丘嘴巴上的弧線時,我產生了兩個想法。第一用一個標籤包裹實現這個弧線,第二分別用兩個標籤去包裹實現這兩個弧線。最終我選擇了第二種。這裡我觀察到使用CSS實現皮卡丘嘴巴上的弧線發現這個弧線就是圓角矩形的四分之一,加上旋轉就可以實現這兩個弧線。
具體實作如下
.mouth .up { position: relative; top: -20px; z-index: 1; }.mouth .up .lip { border: 3px solid black; height: 30px; width: 100px; background: #ffe600; border-top-color: transparent; border-right-color: transparent; position: relative; position: absolute; left: 50%; margin-left: -50px; }.mouth .up .lip.left { border-radius: 0 0 0 35px; transform: rotate(-20deg) translateX(-53px); }.mouth .up .lip.right { border-radius: 0 0 35px 0; transform: rotate(20deg) translateX(53px); }.mouth .up .lip::before { content: ''; display: block; width: 7px; height: 30px; position: absolute; bottom: 0; background: #ffe600; }.mouth .up .lip.left::before { right: -6px; }.mouth .up .lip.right::before { left: -6px; }
第一個大難點已經解決,接下來解決第二個難點。如何實現使用CSS實現皮卡丘的下嘴唇。
觀察使用CSS實現皮卡丘的舌頭我發現這實際上是一個橢圓的一部分或者圓角矩形的一部分,那我就需要截取一部分的橢圓或者圓角矩形就能實現使用CSS實現皮卡丘的舌頭。第二個解決點怎麼實現使用CSS實現皮卡丘舌頭粉紅色的部分,有了上面的思路之後,沿著這個思路繼續想,實際上這就是兩個圓角矩形或者橢圓形的交界處實現的。
畫的不是太好各位客官見諒了。
具體的程式碼的實作如下
.mouth .down { height: 180px; position: absolute; top: 5px; width: 100%; overflow: hidden; }.mouth .down .yuan1 { border: 3px solid black; width: 150px; height: 1000px; position: absolute; bottom: 0; left: 50%; margin-left: -75px; border-radius: 75px/300px; background: #9b000a; overflow: hidden; }.mouth .down .yuan1 .yuan2 { width: 200px; height: 300px; background: #ff485f; position: absolute; bottom: -160px; left: 50%; margin-left: -100px; border-radius: 100px; }
這兩個難點解決了差不多就完成了整個使用CSS實現皮卡丘的一半,剩下的就可以自己去完成了。
當我寫完了使用CSS實現皮卡丘的css之後只能感嘆於css的神奇,也讓我更加深刻的理解了css。在此之前我認為css很簡單,但是真正做使用CSS實現皮卡丘的時候,還是特別特別難,這個難在於需要你用各種各樣的方法去實現你想要的效果,這就需要很好的基礎以及想法,在此感謝指導我的各位老師和同學了。
推薦教學:《CSS》
以上是使用CSS實現皮卡丘的詳細內容。更多資訊請關注PHP中文網其他相關文章!