起因:
中午小姨發來一個某音視頻,標題是: 【程序員女朋友的相冊是這樣的】
小姨表示很感興趣 😮 !
不刷抖音的我點進去看看有啥新奇
大致內容是:
普通人的相冊
vs
程序員的相冊
咋看很炫酷,很有趣;作爲 程序媛
一眼識破,這不就是css3動畫嘛,小case;
於是,打開我的HBuilder~
以我的女神(韓孝周)爲例:
仿某音-3d旋轉相冊效果如下:
同一篇源碼,大家複製粘貼運行:
補充源碼鏈接:https://gitee.com/cungudafa/css-3d
下載解壓,只需替換css-3d項目中img下的照片就可以了,注意不要修改照片的名字
解壓:
替換項目目錄下,img資源文件夾中的圖片即可,不能更改名字!!!
雙擊
index.html就可以顯示
3d相冊 的網頁效果啦!
源碼:
hovertree.css
/*背景頁面顏色設置*/
html{
background:linear-gradient(#FF6666 0%,#336699 20%);/*背景顏色漸變*/
height: 100%;
color:#99cc33;/*字體顏色*/
}
/*動態樣式設置*/
/*最外層容器樣式*/
.wrap{
width: 200px;
height: 200px;
/*改變左右上下,圖片方塊移動*/
margin: 150px auto;
position: relative;
}
/*包裹所有容器樣式*/
.cube{
width: 200px;
height: 200px;
margin: 0 auto;
transform-style: preserve-3d;
transform: rotateX(-30deg) rotateY(-80deg);
-webkit-animation: rotate 20s infinite;
/*勻速*/
animation-timing-function: linear;
}
@-webkit-keyframes rotate{
from{transform: rotateX(0deg) rotateY(0deg);}
to{transform: rotateX(360deg) rotateY(360deg);}
}
.cube div{
position: absolute;
width: 200px;
height: 200px;
opacity: 0.8;
transition: all .4s;
}
/*定義所有圖片樣式*/
.pic{
width: 200px;
height: 200px;
}
.cube .out_front{
transform: rotateY(0deg) translateZ(100px);
}
.cube .out_back{
transform: translateZ(-100px) rotateY(180deg);
}
.cube .out_left{
transform: rotateY(90deg) translateZ(100px);
}
.cube .out_right{
transform: rotateY(-90deg) translateZ(100px);
}
.cube .out_top{
transform: rotateX(90deg) translateZ(100px);
}
.cube .out_bottom{
transform: rotateX(-90deg) translateZ(100px);
}
/*定義小正方體樣式
*/
.cube span{
display: bloack;
width: 100px;
height: 100px;
position: absolute;
top: 50px;
left: 50px;
}
.cube .in_pic{
width: 100px;
height: 100px;
}
.cube .in_front{
transform: rotateY(0deg) translateZ(50px);
}
.cube .in_back{
transform: translateZ(-50px) rotateY(180deg);
}
.cube .in_left{
transform: rotateY(90deg) translateZ(50px);
}
.cube .in_right{
transform: rotateY(-90deg) translateZ(50px);
}
.cube .in_top{
transform: rotateX(90deg) translateZ(50px);
}
.cube .in_bottom{
transform: rotateX(-90deg) translateZ(50px);
}
/*鼠標移入後樣式*/
.cube:hover .out_front{
transform: rotateY(0deg) translateZ(200px);
}
.cube:hover .out_back{
transform: translateZ(-200px) rotateY(180deg);
}
.cube:hover .out_left{
transform: rotateY(90deg) translateZ(200px);
}
.cube:hover .out_right{
transform: rotateY(-90deg) translateZ(200px);
}
.cube:hover .out_top{
transform: rotateX(90deg) translateZ(200px);
}
.cube:hover .out_bottom{
transform: rotateX(-90deg) translateZ(200px);
}
.hovertreeinfo{text-align:center;}
.hovertreeinfo a{color:white}
index.html
1. 本地圖片版:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>css-3d旋轉相冊</title>
<link rel="stylesheet" href="css/hovertree.css" />
</head>
<body>
<div class="hovertreeinfo">
<h2></h2>紅豆
</div>
<!--/*外層最大容器*/-->
<div class="wrap">
<!-- /*包裹所有元素的容器*/-->
<div class="cube">
<!--前面圖片 -->
<div class="out_front">
<img src="img/img01.jpg " class="pic" />
</div>
<!--後面圖片 -->
<div class="out_back">
<img src="img/img02.jpg" class="pic"/>
</div>
<!--左圖片 -->
<div class="out_left">
<img src="img/img03.jpg" class="pic" />
</div>
<div class="out_right">
<img src="img/img04.jpg" class="pic" />
</div>
<div class="out_top">
<img src="img/img05.jpg" class="pic" />
</div>
<div class="out_bottom">
<img src="img/img06.jpg" class="pic" />
</div>
<!--小正方體 -->
<span class="in_front">
<img src="img/img07.jpg" class="in_pic" />
</span>
<span class="in_back">
<img src="img/img08.jpg" class="in_pic" />
</span>
<span class="in_left">
<img src="img/img09.jpg" class="in_pic" />
</span>
<span class="in_right">
<img src="img/img10.jpg" class="in_pic" />
</span>
<span class="in_top">
<img src="img/img11.jpg" class="in_pic" />
</span>
<span class="in_bottom">
<img src="img/img12.jpg" class="in_pic" />
</span>
</div>
</div>
</body>
</html>
2. 網絡圖片版,可以直接放鏈接:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>css-3d旋轉相冊</title>
<link rel="stylesheet" href="css/hovertree.css" />
</head>
<body>
<div class="hovertreeinfo">
<h2>css-3d旋轉相冊</h2>請把光標移到立方體上面,或者點擊圖片。
</div>
<!--/*外層最大容器*/-->
<div class="wrap">
<!-- /*包裹所有元素的容器*/-->
<div class="cube">
<!--前面圖片 -->
<div class="out_front">
<img src="http://www.jd-tv.com/uploads/allimg/180822/18-1PR2110G0N0.jpg" class="pic" />
</div>
<!--後面圖片 -->
<div class="out_back">
<img src="https://img.yna.co.kr/etc/inner/CK/2018/07/26/ACK20180726001500881_01_i_P4.jpg" class="pic" />
</div>
<!--左圖片 -->
<div class="out_left">
<img src="http://www.weimeicun.com/uploads/allimg/181109/1010-1Q109152421Q8.jpg" class="pic" />
</div>
<div class="out_right">
<img src="http://p3.ifengimg.com/cmpp/2016/07/20/13/cdf377cd-ca7f-41f3-b481-c99561a0a40e_size29_w500_h332.jpg" class="pic" />
</div>
<div class="out_top">
<img src="http://img.mm4000.com/file/9/49/c43d6065b5_1044.jpg" class="pic" />
</div>
<div class="out_bottom">
<img src="http://imgs.jushuo.com/dimg/2016-12-16/58535d65478d9.jpg" class="pic" />
</div>
<!--小正方體 -->
<span class="in_front">
<img src="http://p0.ifengimg.com/pmop/2018/0404/B05F7F3EEDA9A308722D757446A5357677F77C79_size64_w540_h700.jpeg" class="in_pic" />
</span>
<span class="in_back">
<img src="http://p3.ifengimg.com/a/2018_30/e7dfb1ff77a73ff_size29_w499_h624.jpg" class="in_pic" />
</span>
<span class="in_left">
<img src="http://img1.xiazaizhijia.com/walls/20160801/middle_510aafcd093f6a2.jpg" class="in_pic" />
</span>
<span class="in_right">
<img src="https://cn.bing.com/th?id=OIP.LpZnh1XtRA4buMi5P4qOegHaKh&pid=Api&rs=1" class="in_pic" />
</span>
<span class="in_top">
<img src="http://www.sosoxian.com/uploads/allimg/160926/1-160926091526.jpg" class="in_pic" />
</span>
<span class="in_bottom">
<img src="https://n.sinaimg.cn/ent/transform/20160720/Cdjh-fxuapvw2412326.jpg" class="in_pic" />
</span>
</div>
</div>
</body>
</html>
題外話:
之前有小哥哥問我:如何做表白網站
,這不就是一個很炫酷的效果嗎?
你與女神不是差一個表白網站,而是差一個html。 ___cungudafa
皮完就逃~ 😃
炫酷相冊下文:
(錄製了15s視頻發給小姨~)
此時我的內心:
既然做了,那就尷尬而不失微笑的美化吧~
加音頻,這麼簡單的事,怎麼能難倒小王呢~
-
第一步:網上下載mp3
-
第二步:html加音頻自動播放
3. 加音樂版音樂和圖片都在img文件夾目錄下,如果目錄不同,注意修改。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>css-3d旋轉相冊</title>
<link rel="stylesheet" href="css/hovertree.css" />
</head>
<body>
<div class="hovertreeinfo">
<h2></h2>紅豆
</div>
<!-- 僅自動播放音樂 -->
<audio loop src="img/qianyuqianxun.mp3" id="audio" autoplay preload="auto">該瀏覽器不支持audio屬性</audio>
<!-- 顯示播放條 controls -->
<!-- <audio loop src="img/qianyuqianxun.mp3" id="audio" controls autoplay preload="auto">該瀏覽器不支持audio屬性</audio> -->
<script type="text/javascript">
//--創建頁面監聽,等待微信端頁面加載完畢 觸發音頻播放
document.addEventListener('DOMContentLoaded', function () {
function audioAutoPlay() {
var audio = document.getElementById('audio');
audio.play();
document.addEventListener("WeixinJSBridgeReady", function () {
audio.play();
}, false);
}
audioAutoPlay();
});
//--創建觸摸監聽,當瀏覽器打開頁面時,觸摸屏幕觸發事件,進行音頻播放
document.addEventListener('touchstart', function () {
function audioAutoPlay() {
var audio = document.getElementById('audio');
audio.play();
}
audioAutoPlay();
});
</script>
<!--/*外層最大容器*/-->
<div class="wrap">
<!-- /*包裹所有元素的容器*/-->
<div class="cube">
<!--前面圖片 -->
<div class="out_front">
<img src="img/img06.jpg " class="pic" />
</div>
<!--後面圖片 -->
<div class="out_back">
<img src="img/img07.jpg" class="pic"/>
</div>
<!--左圖片 -->
<div class="out_left">
<img src="img/img08.jpg" class="pic" />
</div>
<div class="out_right">
<img src="img/img04.jpg" class="pic" />
</div>
<div class="out_top">
<img src="img/img10.jpg" class="pic" />
</div>
<div class="out_bottom">
<img src="img/img11.jpg" class="pic" />
</div>
<!--小正方體 -->
<span class="in_front">
<img src="img/img01.jpg" class="in_pic" />
</span>
<span class="in_back">
<img src="img/img02.jpg" class="in_pic" />
</span>
<span class="in_left">
<img src="img/img03.jpg" class="in_pic" />
</span>
<span class="in_right">
<img src="img/img09.jpg" class="in_pic" />
</span>
<span class="in_top">
<img src="img/img05.jpg" class="in_pic" />
</span>
<span class="in_bottom">
<img src="img/img12.jpg" class="in_pic" />
</span>
</div>
</div>
</body>
</html>
旋轉圖像,播放音樂
- 第三步:提交驗收
小姨表示:百度免費下載的音質太雜,效果不好;併發來了某狗鏈接~
抱着試一試心態,點擊打開網頁源碼,果真,未加密音頻原鏈接:
複製audio
標籤鏈接,到瀏覽器打開
可下載!!!
此時的我 😃😕😕
我現在可驕傲的用win+G
錄製音視頻給小姨看成果!
我的內心os:
如何解決錄製視頻音質雜,畫面截取,添加純音頻,調整視頻大小????
程序媛小王打開了Pr,Pr完美解決所有難題呢 😃 真香~