首页
/
每日頭條
/
寵物
/
薇薇貓創意畫
薇薇貓創意畫
更新时间:2025-04-04 10:13:40

周末找了點輕松的話題,css畫大熊貓。

先上效果圖

歡迎競猜大熊貓到底說了什麼??

薇薇貓創意畫(周末愉快css畫大熊貓)1

打招呼

薇薇貓創意畫(周末愉快css畫大熊貓)2

眼睛跟随鼠标移動

再上源碼

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, viewport-fit=cover, user-scalable=no"> <title>純css畫大熊貓</title> </head> <body> <div id="scene1" class="scene-1"> <!--熊貓坐着--> <div class="head"> <div class="ear ear-left"></div> <div class="ear ear-right"></div> <div class="face"> <div class="eye-out eye-left"> <div id="leftEyeOut" class="eye"> <div id="leftEye" class="eyeball"></div> </div> </div> <div class="eye-out eye-right"> <div class="eye"> <div id="rightEye" class="eyeball"></div> </div> </div> <div class="nose"></div> <div id="mouth" class="mouth"> <div id="tongue" class="tongue"></div> </div> </div> </div> <div id="pandaBody" class="body"> <div id="leftArm" class="arm-left"></div> <div id="rightArm" class="arm-right"></div> <div class="foot foot-left"> <div class="toe"></div> </div> <div class="foot foot-right"> <div class="toe"></div> </div> </div> </div> <style> /*動畫相關*/ @keyframes mouth_animation { 0% { top: 132px; height: 14px; } 25% { top: 123px; height: 32px; } 50% { top: 125px; height: 26px; } 75% { top: 123px; height: 32px; } 100% { top: 132px; height: 14px; } } .mouth-animation { /*animation: infinite;*/ animation-name: mouth_animation; animation-duration: 3s; } .tongue-animation { /*animation: infinite;*/ animation-name: tongue_animation; animation-duration: 3s; } @keyframes tongue_animation { 10% { bottom: 3px; height: 8px; opacity: 0; } 15% { bottom: 4px; height: 14px; opacity: 1; } 50% { bottom: 4px; height: 16px; opacity: 1; } 85% { bottom: 4px; height: 14px; opacity: 1; } 90% { bottom: 3px; height: 8px; opacity: 0; } } .arm-left-animation { animation-name: arm_left_animation; animation-duration: 3s; } @keyframes arm_left_animation { 0% { transform: rotate(75deg); } 50% { transform: rotate(125deg); } 100% { transform: rotate(75deg); } } .arm-right-animation { animation-name: arm_right_animation; animation-duration: 3s; } @keyframes arm_right_animation { 0% { transform: rotate(-75deg); } 50% { transform: rotate(-125deg); } 100% { transform: rotate(-75deg); } } </style> <script> // 打招呼 var hasanimation = false function doAnimation(e, centerx) { let arm, ani; if (centerx > e.pageX) { arm = document.getElementById('leftArm'); ani = 'arm-left-animation' } else { arm = document.getElementById('rightArm'); ani = 'arm-right-animation' } var mouth = document.getElementById('mouth'); mouth.classList.add("mouth-animation"); var tongue = document.getElementById('tongue'); tongue.classList.add("tongue-animation"); arm.classList.add(ani); setTimeout(() => { hasAnimation = false mouth.classList.remove("mouth-animation"); tongue.classList.remove("tongue-animation"); arm.classList.remove(ani); }, 3000) } var pandaBody = document.getElementById('pandaBody'); pandaBody.addEventListener("dblclick", function (e) { if (hasAnimation) { return ; } hasAnimation = true var x = pandaBody.getBoundingClientRect().x pandaBody.getBoundingClientRect().width / 2.0; doAnimation(e, x) }) </script> <script> // 眼睛跟随動 var leftEyeCenter = {}, rightEyeCenter = {} setTimeout(() => { var eyel = document.getElementById('leftEye'); var eyeCenterX = eyel.getBoundingClientRect().x eyel.getBoundingClientRect().width / 2.0; var eyeCenterY = eyel.getBoundingClientRect().y eyel.getBoundingClientRect().height / 2.0; leftEyeCenter = {x: eyeCenterX, y: eyeCenterY, dom: eyel} var eyer = document.getElementById('rightEye'); eyeCenterX = eyer.getBoundingClientRect().x eyer.getBoundingClientRect().width / 2.0; eyeCenterY = eyer.getBoundingClientRect().y eyer.getBoundingClientRect().height / 2.0; rightEyeCenter = {x: eyeCenterX, y: eyeCenterY, dom: eyer} }, 100) var body = document.body; body.addEventListener("click", function (e) { eyePosition(leftEyeCenter, e); eyePosition(rightEyeCenter, e); }) function eyePosition(eyeCenter, e) { var cx = e.pageX, cy = e.pageY; var eye = eyeCenter.dom; if ((cx < eyeCenter.x 8 && cx > eyeCenter.x - 8) && cy < eyeCenter.y 8 && cy > eyeCenter.y - 8) { eye.style = ""; } else { var st = Math.atan2((cy - eyeCenter.y), (cx - eyeCenter.x)); var x = 6 6 * Math.cos(st); var y = 6 6 * Math.sin(st); eye.style.left = x 'px'; eye.style.top = y 'px'; } } var timeOut = null; body.addEventListener("mousemove", function (e) { if (timeOut) { return ; } eyePosition(leftEyeCenter, e); eyePosition(rightEyeCenter, e); timeOut = setTimeout(() => { timeOut = null }, 50) }) </script> <style> html, body { margin: 0; width: 100%; height: 100%; position: relative; } .scene-1 { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 300px; height: 360px; } </style> <style> /*頭*/ .head { position: absolute; top: 0; left: 50%; transform: translateX(-50%); height: 160px; width: 200px; z-index: 10; } .head .face { position: relative; height: 160px; width: 200px; border-radius: 50% 50% 40% 40%; background: white; border: 1px solid black; z-index: 1; } .head .ear { position: absolute; top: -15px; height: 70px; width: 70px; border-radius: 50%; background: black; } .head .ear:after { content: ' '; position: absolute; left: 20px; top: 20px; height: 30px; width: 30px; border-radius: 50%; background-color: darkgrey; } .head .ear-left { left: -15px; } .head .ear-right { right: -15px; } .head .eye-out { position: absolute; top: 30px; height: 80px; width: 60px; border-radius: 50%; background: black; } .head .eye { position: absolute; top: 20px; height: 32px; width: 32px; border-radius: 50%; border: 2px solid white; background-color: white; } .head .eye-left { left: 50px; transform: rotate(30deg); transform-origin: 0% 0%; } .head .eye-left .eye { left: 15px; transform: rotate(-30deg); transform-origin: 50% 50%; } .head .eye-right { right: 50px; transform: rotate(-30deg); transform-origin: 100% 0%; } .head .eye-right .eye { right: 15px; transform: rotate(30deg); transform-origin: 50% 50%; } .head .eyeball { position: absolute; top: 6px; left: 6px; height: 20px; width: 20px; border-radius: 50%; background-color: black; } .head .eyeball:before { content: " "; position: absolute; left: 3px; top: 2px; width: 8px; height: 8px; border-radius: 50% / 50%; background-color: white; } .head .eyeball:after { content: " "; position: absolute; left: 10px; top: 10px; width: 4px; height: 4px; border-radius: 50% / 50%; background-color: white; } .head .nose { position: absolute; top: 100px; left: 50%; width: 30px; height: 20px; transform: translateX(-50%); border-radius: 50% 50% 40% 40%; background-color: black; } .head .nose:after { content: ' '; position: absolute; left: 6px; top: 3px; width: 12px; height: 8px; border-radius: 50% / 50%; background-color: white; } .head .mouth { position: absolute; top: 132px; left: 50%; width: 70px; height: 14px; transform: translateX(-50%); border-radius: 40% 40% 50% 50%; background-color: black; } .head .mouth .tongue { position: absolute; bottom: 3px; left: 50%; width: 40px; height: 8px; transform: translateX(-50%); border-radius: 50%; background-color: red; opacity: 0; } </style> <style> /*身子*/ .body { position: absolute; top: 130px; left: 50%; transform: translateX(-50%); height: 220px; width: 240px; z-index: 5; } .body:before { content: ''; position: absolute; top: 0px; left: 0; height: 220px; width: 240px; border-radius: 50% 50% 20% 20%; background-color: black; z-index: 2; } .body:after { content: ''; position: absolute; left: 5px; top: 60px; width: 228px; height: 160px; overflow: hidden; border-radius: 160px 160px 40% 40%; background-color: white; border: 1px solid black; z-index: 3; } .body .arm-left { position: absolute; top: 40px; left: 20px; height: 120px; width: 60px; transform: rotate(75deg); transform-origin: 50% 10%; background-color: black; border-radius: 0 0 30px 30px; } .body .arm-right { position: absolute; top: 40px; right: 20px; height: 120px; width: 60px; transform: rotate(-75deg); transform-origin: 50% 10%; background-color: black; border-radius: 0 0 30px 30px; } .body .foot { position: absolute; top: 150px; height: 80px; width: 80px; background-color: black; border-radius: 40px; z-index: 5; } .body .foot:after { content: ''; position: absolute; top: 30px; left: 20px; height: 40px; width: 40px; background-color: darkgrey; border-radius: 40px; z-index: 5; } .body .foot-left { left: -10px; } .body .foot-right { right: -10px; } .body .toe { position: absolute; top: 10px; left: 32px; height: 16px; width: 16px; background-color: darkgrey; border-radius: 40px; } .body .toe:before { content: " "; position: absolute; top: 4px; left: -18px; height: 16px; width: 16px; background-color: darkgrey; border-radius: 40px; } .body .toe:after { content: " "; position: absolute; top: 4px; left: 18px; height: 16px; width: 16px; background-color: darkgrey; border-radius: 40px; } </style> </body> </html>

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
貓與狗睡前故事(貓和狗的小故事)
貓與狗睡前故事(貓和狗的小故事)
  小時候家裡養過一隻貓和一隻狗,狗總是被貓欺負。不是狗憨厚,而是鬥不過貓。比如貓藏在鞋盒偷襲狗,狗隻能繞着鞋盒轉圈。後來狗去世了,貓沒看見它去世的樣子,隻是沒見狗回來,半年過去了,有天我故意在門口喊了聲狗的名字,貓從屋裡飛奔到門口左右張望……這事很多年了我一直還記得。      ,
2025-04-04
北京尋狗啟示(史上最随緣的尋狗啟事)
北京尋狗啟示(史上最随緣的尋狗啟事)
    現在愛狗人士,愛貓人士越來越多了,甚至有很多的人把這些貓狗當做了自己的祖宗看待。其實呢,你如果想要一個寵物的話,那麼就一定要把這個寵物當作自己的家人和朋友看待,另外呢,也要對他們的生命負責任,因為不管物種的高低貴賤,他們都是一條生命,同樣的生命都值得我們尊敬,但是呢,有很多主人他們去養狗養的非常的佛系,就連狗丢了,他們的尋狗啟事寫的也是非常的随便讓很...
2025-04-04
追狗不要追到深巷子(女人緣不好怎麼辦)
追狗不要追到深巷子(女人緣不好怎麼辦)
  原來銷冠的收入這麼高!      香蕉買回來第二天就發黑了,後來就研究出了這個小妙招,快來學學吧。      這誰家的煎餅火了      要想女人緣好首先你先養一條狗      為什麼說2021年3月26日8:20不要擡頭看太陽?有沒有網友解釋一下淚奔      大家都以為會出現第二個台階,沒想到。。。      差點撞上前邊的進口車      我那奇葩...
2025-04-04
寵愛陳偉霆鐘楚曦采訪(寵愛陳偉霆鐘楚曦親密被狗打斷)
寵愛陳偉霆鐘楚曦采訪(寵愛陳偉霆鐘楚曦親密被狗打斷)
  由徐峥監制,楊子導演的跨年電影《寵愛》即将在跨年夜上映,目前電影發布了7支預告片,從預告片、路演以及首映中觀衆們的表現,可以看出來這是一部有笑有淚的溫馨電影。這部電影主打治愈和跨年,雲集了衆多重量級明星,六段故事讓你目不暇接,喚醒你最溫暖的回憶,讓這個寒冬不再寒冷。      父女情深在通過此前的首映和路演片段中可以看出來,高銘(于和偉 飾)和高萌萌(李...
2025-04-04
肖鋼玉的身份(萌萌哒的肖鋼玉)
肖鋼玉的身份(萌萌哒的肖鋼玉)
  人民的名義後期侯亮平被栽贓陷害有一個重要人物就是肖鋼玉,原來是省檢察院的一位副檢察長.陸亦可對肖鋼玉的評價原話是肖鋼玉這人架子很大,不好說話,與山水集團,祁同偉等在一起牟利,每次看到他我都感覺他長得是這樣的.     高育良在浴室威脅他讓他做事的時候他是這樣的  再看看劉新建對他的評價,就是一個土鼈  再看看他的著名事迹,賣中華煙,兩箱中華煙,非要賣給劉...
2025-04-04
Copyright 2023-2025 - www.tftnews.com All Rights Reserved