原文連結
蘋果官方網站使用流暢的滾動動畫來突出其內容。在這篇文章中,我們將分析並複製一個類似的動畫以了解其實現。
?原始蘋果網站(影片)
?轉載實施
1. 滾動同步
- 動畫狀態是根據滾動位置(scrollY)即時計算的。
2. 雙向動畫
- 向下捲動時:文字向上移動並淡出,而影片縮小。
- 向上捲動時:文字向下移動並重新出現,同時影片放大。
3.CSS屬性利用
- 使用變換:translateY 和與滾動位置成比例的縮放值。
- 使用 requestAnimationFrame 確保平滑的動畫。
? HTML結構
HTML 結構由帶有文字和背景影片的簡單佈局組成。
?轉載實施
設定 CSS 以根據捲動位置啟用流暢的動畫。
/* Text Section */ .text-section { position: absolute; top: 20%; width: 100%; text-align: center; color: white; z-index: 2; } .video-section { position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; display: flex; justify-content: center; align-items: center; overflow: hidden; } .background-video { width: 100vw; height: auto; }
? JavaScript(基於滾動的動畫)
根據捲動位置計算文字和影片的狀態並即時更新其樣式。
const textSection = document.querySelector(".text-section"); const videoSection = document.querySelector(".video-section"); function handleScroll() { const scrollY = window.scrollY; const windowHeight = window.innerHeight; const textOpacity = Math.max(0, 1 - scrollY / (windowHeight / 2)); const textTranslateY = Math.min(scrollY / 2, 100); textSection.style.transform = `translateY(-${textTranslateY}px)`; textSection.style.opacity = textOpacity; const videoScale = Math.max(0.5, 1 - scrollY / (windowHeight * 2)); videoSection.style.transform = `scale(${videoScale})`; } window.addEventListener("scroll", () => { requestAnimationFrame(handleScroll); });
?️關鍵操作分解
?️關鍵功能說明
- 基於滾動的計算
textOpacity:依照捲動位置調整文字的不透明度逐漸淡出。
textTranslateY:計算文字與滾動進度成比例向上移動的距離。
videoScale:調整影片的縮放比例,使其隨著滾動位置按比例縮小。
- requestAnimationFrame
- 非同步函數,透過利用瀏覽器最佳化的渲染循環實現流暢操作來增強動畫效能。
- 雙向動畫
向下捲動:文字向上移動並淡出,同時影片縮小。
向上捲動:文字向下移動並重新出現,同時影片放大。
以上是[翻譯]蘋果網站動畫分析(滾動同步)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

文章討論了CSS FlexBox,這是一種佈局方法,用於有效地對齊和分佈響應設計中的空間。它說明了FlexBox用法,將其與CSS網格進行了比較,並詳細瀏覽了瀏覽器支持。

本文討論了使用CSS創建響應網站的技術,包括視口元標籤,靈活的網格,流體媒體,媒體查詢和相對單元。它還涵蓋了使用CSS網格和Flexbox一起使用,並推薦CSS框架

本文討論了CSS盒裝屬性,該屬性控制了元素維度的計算方式。它解釋了諸如Content-Box,Border-Box和Padding-Box之類的值,以及它們對佈局設計和形式對齊的影響。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3漢化版
中文版,非常好用

記事本++7.3.1
好用且免費的程式碼編輯器

Dreamweaver Mac版
視覺化網頁開發工具