利用JS製作 IPhone SE
A13 動畫(弱化版)
2020/5/24 (日) 講者:Cuboid
Outline
- 動畫預覽
- Html架構
- CSS的部分
- JS的部分
-
完整程式碼
- 參考資料
動畫預覽
HTML 架構
<div id="container">
<video src="https://www.apple.com/105/media/us/iphone-se/2020/90024c0f-285a-4bf5-af04-2c38de97b06e/anim/arcade-loop/large.mp4" muted autoplay loop></video>
<h1>
LIS Bunny<br>
Hello World!!!!Hello World!!!!
</h1>
<div id="wrap">
<img id="lisbunny" src="https://i.imgur.com/SZ6Cym1.png" />
</div>
</div>
muted 靜音
autoplay 自動播放
loop 無限循環
<video src="...." muted autoplay loop></video>
CSS 的部分
step1.
* {
padding: 0;
margin: 0;
list-style: none;
}
body {
background-color: black;
}
#container {
position: sticky;
top: 0;
width: 100%;
height: 1200px;
overflow: hidden;
}
#container video {
height: 100vh;
width: auto;
position: relative;
transform: translate(0, 50%);
}
#container h1 {
width: 100%;
position: absolute;
top: 0;
left: 0;
color: aliceblue;
font-size: 64px;
font-family: Helvetica;
z-index: 20;
text-align: center;
transform: translate(0,200%);
opacity: 1;
}
step3.
wrap 設定
#wrap {
width: 300px;
height: 300px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
box-shadow: 0px 0px 0px 100vh black;
z-index: 10;
min-width: 300px;
min-height: 300px;
background-color: black;
opacity: 1;
}
#wrap #lisbunny {
width: 100%;
height: 100%;
opacity: 0;
}
完整css 程式碼
<style>
* {
padding: 0;
margin: 0;
list-style: none;
}
body {
background-color: black;
}
#container {
position: sticky;
top: 0;
width: 100%;
height: 1200px;
overflow: hidden;
}
#container video {
height: 100vh;
width: auto;
position: relative;
transform: translate(0, 50%);
}
#container h1 {
width: 100%;
position: absolute;
top: 0;
left: 0;
color: aliceblue;
font-size: 64px;
font-family: Helvetica;
z-index: 20;
text-align: center;
transform: translate(0,200%);
opacity: 1;
}
#wrap {
width: 300px;
height: 300px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
box-shadow: 0px 0px 0px 100vh black;
z-index: 10;
min-width: 300px;
min-height: 300px;
background-color: black;
opacity: 1;
}
#wrap #lisbunny {
width: 100%;
height: 100%;
opacity: 0;
}
</style>
JS 的部分
step1.
window.addEventListener('scroll', (e) => {})
step2.
let scrolled = document.documentElement.scrollTop /
(document.documentElement.scrollHeight - document.documentElement.clientHeight)
console.log(scrolled)
//目前捲動距離/頁面總高度-視窗高度
document.documentElement.scrollTop 目前捲動距離document.documentElement.scrollHeight 頁面總高度
document.documentElement.clientHeight 視窗高度
scrolled 是介於0-1的數
step3.
let $h1 = document.querySelector('h1') //是指 h1 標籤這句標題
let $wrap = document.querySelector('#wrap') //指圖片的 容器
let $lisbunny = document.querySelector('#lisbunny') //指lisbunny圖片
step4.
$wrap.style.width = $wrap.style.height =
document.documentElement.clientWidth * 20 * (scrolled * scrolled * scrolled) + "px"
即是圖片在放到最大時,亦即是頁面捲動到最底時,它的大小會等於頁面寬度的 20 倍,再乘以 scrolled,即是捲動的百份比,最後加上 px 這個單位
scrolled乘以3次(加速度公式)
step5.
h1 標題動畫
if (scrolled <= 0.1) {
$h1.style.opacity = (0.1 - scrolled) / 0.1
$h1.style.marginTop = scrolled * 1000 * -1 + 'px'
} else {
$h1.style.opacity = 0
}
讓h1標題 往上淡去
step6.
圖片顯現 動畫
if (0.1<scrolled <= 0.2) {
$lisbunny.style.opacity = (scrolled - 0.1) / 0.1
} else {
$lisbunny.style.opacity = 1
}
step7.
為了讓影片完整顯現,所以要把黑色背景去掉
if (scrolled >= 0.6) {
$wrap.style.opacity = 0
} else {
$wrap.style.opacity = 1;
}
完整程式碼
<!DOCTYPE html>
<html class="no-js">
<head>
<meta charset="utf-8">
<title>lab3</title>
<style>
* {
padding: 0;
margin: 0;
list-style: none;
}
body {
background-color: black;
}
#container {
position: sticky;
top: 0;
width: 100%;
height: 1200px;
overflow: hidden;
}
#container video {
height: 100vh;
width: auto;
position: relative;
transform: translate(0, 50%);
}
#container h1 {
width: 100%;
position: absolute;
top: 0;
left: 0;
color: aliceblue;
font-size: 64px;
font-family: Helvetica;
z-index: 20;
text-align: center;
transform: translate(0,200%);
opacity: 1;
}
#wrap {
width: 300px;
height: 300px;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
box-shadow: 0px 0px 0px 100vh black;
z-index: 10;
min-width: 300px;
min-height: 300px;
background-color: black;
opacity: 1;
}
#wrap #lisbunny {
width: 100%;
height: 100%;
opacity: 0;
}
</style>
</head>
<body>
<div id="container">
<video
src="https://www.apple.com/105/media/us/iphone-se/2020/90024c0f-285a-4bf5-af04-2c38de97b06e/anim/arcade-loop/large.mp4"
muted autoplay loop></video>
<h1>
LIS Bunny<br>
Hello World!!!! Hello World!!!!
</h1>
<div id="wrap">
<img id="lisbunny" src="https://i.imgur.com/SZ6Cym1.png" />
</div>
</div>
<script>
window.addEventListener('scroll', (e) => {
//目前捲動距離/頁面總高度-視窗高度
let scrolled = document.documentElement.scrollTop /
(document.documentElement.scrollHeight - document.documentElement.clientHeight)
console.log(scrolled)
let $h1 = document.querySelector('h1') //是指 h1 標籤這句標題
let $wrap = document.querySelector('#wrap') //指圖片的 容器
let $lisbunny = document.querySelector('#lisbunny') //指lisbunny圖片
$wrap.style.width = $wrap.style.height =
document.documentElement.clientWidth * 20 * (scrolled * scrolled * scrolled) + "px"
//即是圖片在放到最大時,亦即是頁面捲動到最底時,它的大小會等於頁面寬度的 20 倍,再乘以 scrolled,即是捲動的百份比,最後加上 px 這個單位
//scrolled乘以3次方,(加速度公式)
if (scrolled <= 0.1) {
$h1.style.opacity = (0.1 - scrolled) / 0.1
$h1.style.marginTop = scrolled * 1000 * -1 + 'px'
} else {
$h1.style.opacity = 0
}
if (scrolled <= 0.2) {
$lisbunny.style.opacity = (scrolled - 0.1) / 0.1
} else {
$lisbunny.style.opacity = 1
}
if (scrolled >= 0.6) {
$wrap.style.opacity = 0
} else {
$wrap.style.opacity = 1;
}
})
</script>
</body>
</html>
參考資料
THANKS
利用JS製作IPhone SE A13 動畫(弱化版)
By Hong di Chen
利用JS製作IPhone SE A13 動畫(弱化版)
- 127