Warning: Undefined array key "language" in /volume1/web/blog_view.php on line 69 Warning: Undefined array key "lan_code" in /volume1/web/blog_view.php on line 71 Warning: Undefined array key "lan" in /volume1/web/blog_view.php on line 72 Warning: Undefined array key "lan" in /volume1/web/blog_view.php on line 74 Warning: Trying to access array offset on value of type null in /volume1/web/blog_view.php on line 74 Warning: Undefined array key "lan" in /volume1/web/blog_view.php on line 74 Warning: Trying to access array offset on value of type null in /volume1/web/blog_view.php on line 74 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 72 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 79 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 75 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 74 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 73 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 72 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 82 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 81 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 80 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 78 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 77 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 76 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 75 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 82 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 80 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 77 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 74 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 72 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 71 Warning: Trying to access array offset on value of type null in /volume1/web/blog_tree.php on line 80 Warning: Trying to access array offset on value of type null in /volume1/web/put_products.php on line 30 Warning: Attempt to read property "plaintext" on array in /volume1/web/put_products.php on line 33 Warning: Trying to access array offset on value of type null in /volume1/web/put_products.php on line 37 Warning: Trying to access array offset on value of type null in /volume1/web/put_products.php on line 30 Warning: Attempt to read property "plaintext" on array in /volume1/web/put_products.php on line 33 Warning: Trying to access array offset on value of type null in /volume1/web/put_products.php on line 37 Warning: Undefined array key "lan" in /volume1/web/blog_view.php on line 125 Warning: Trying to access array offset on value of type null in /volume1/web/blog_view.php on line 125 Warning: Undefined array key "lan" in /volume1/web/blog_view.php on line 126 Warning: Trying to access array offset on value of type null in /volume1/web/blog_view.php on line 126
以滑動事件為導向的動畫
GSAP 中一個非常重要的動畫模式~ScrollTrigger~以滑鼠滾輪或是手指滑動事件作為動畫的依據,以下簡稱滾輪動畫,滾輪動畫當然就是發生在視窗進行滾動時,由事件來觸發動畫的播放,滾輪動畫可分為兩種類型
只負責播放動畫,不干涉其運作
如果你還不知道如何用 GSAP 做一段動畫,請參考之前的教學,這裡我們還是沿用小蜘蛛人做範例,同樣用蜘蛛人當作觸發器,當蜘蛛人的位置來到視窗的中央時,就播放動畫。
gsap.to('#spider1', { x: '200%', //往右移動100% duration: 0.5, //動畫時間0.5秒 scrollTrigger: { //滾輪觸發器 trigger: '#spider1', //觸發的元素 start: 'top center', //觸發時機-當蜘蛛人的top位置與視窗center位置交會時 end: 'bottom center', //觸發結束時機-當蜘蛛人的bottom位置與視窗center位置交會時 toggleActions: 'play reverse play reverse', //定義滾輪往返元素時的動作 markers: true //顯示元素與視窗的輔助標記 } })
非常流行的 Scroll 應用

gsap.to('#spider2', { x: '200%', //往右移動100% rotate: 360,//旋轉360度 scrollTrigger: { //滾輪觸發器 trigger: '#spider2', //觸發的元素 start: 'top center', //觸發時機-當蜘蛛人的top位置與視窗center位置交會時 end: 'bottom center', //觸發結束時機-當蜘蛛人的bottom位置與視窗center位置交會時 scrub: true, //定義由滾輪來控制動畫進度 markers: true //顯示元素與視窗的輔助標記 } })
使用 SlimWeb TinyMCE 內的調整元素,快速得到動畫參數
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Exercitationem perspiciatis voluptatum a, quo nobis, non commodi quia repellendus sequi nulla voluptatem dicta reprehenderit, placeat laborum ut beatae ullam suscipit veniam.
gsap.from('#c_1739618909084', { rotateY: 120, //初始的Y軸旋轉120度 scrollTrigger: { trigger: '#c_1739618909084', //使用卡片本身當觸發器 start: 'top bottom', //卡片的 top 與視窗的 bottom 交會時 end: 'top top', //卡片的 top 到達視窗的 top scrub: true, //使用滾輪控制動畫 markers: true //顯示元素與視窗的輔助標記 } })

#c_1739618909084 { transform-origin: 0% 50%; }
$('#c_1739618909084').css('transformOrigin', '0% 50%'); //或是使用 GSAP 的 set 方法 gsap.set('#c_1739618909084', { transformOrigin: '0% 50%' });
//先將#c_body元素隱藏起來 gsap.set('#c_body', { visibility: 'hidden' }); gsap.from('#c_body', { y: '-110%', //初始位置為上方-110% scrollTrigger: { trigger: '#c_1739618909084', //設定觸發元素是卡片上的圖片 start: 'top top', //當圖片 top 與視窗 top 交會時觸發 scrub: true, //由滾輪來控制動畫 pin: true, //暫停視窗滾動直到動畫完成 //markers: true, onEnter: function() { //當觸發時,將#_body元素設定為可見 $('#c_body').css('visibility', 'visible'); }, onLeaveBack: function() { //當視窗往上滾動時將#_body元素設定為不可見 $('#c_body').css('visibility', 'hidden'); } } })


一個在五濁亂世中
不願靠話術生存的工程師
More Related...
TinyMCE/AI 編輯器介紹ChatGPT的資料庫應用為什麼不用WordPress來架設網站?GSAP入門