利用TweenMax針對HTML頁面製作動畫 – jQuery Mobile篇

在Dreamweaver5.5之後多了一個jQuery Mobile面板,主要是利用jQuery來製作一些行動裝置的元素,接下來這篇文章就利用Dreamweaver提供的幾項元素加上TweenMax來製作手機動畫頁面。

因為這篇文章應用到的動畫功能,依舊和前兩篇差不多,所以就直接看範例吧!首先,第一個範例是利用「jQuery 翻轉切換開關」來控制動畫的播放,除了可以從前面的連結看到這個範例之外,也因為這是特別針對行動裝置所設計的案例,大家也可以在手機輸入「goo.gl/LofiK」網址來觀賞,下面是本範例整個網頁的程式碼:

<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalabke=no, width=device-width" />
    <title>貓咪欣賞</title>
    <link href="jquery-mobile/jquery.mobile-1.0.min.css" rel="stylesheet" type="text/css">
    <script src="jquery-mobile/jquery-1.6.4.min.js" type="text/javascript"></script>
    <script src="jquery-mobile/jquery.mobile-1.0.min.js" type="text/javascript"></script>
    <script src="src/minified/TweenMax.min.js"></script>
    <style type="text/css">
        * {
            margin: 0px;
            padding: 0px;
        }

        #photo {
            text-align: center;
        }

        #selector {
            text-align: center;
            width: 50%;
            margin-left: auto;
            margin-right: auto;
        }
    </style>
    <script language="javascript">
        var playNo = 1; /* 定義目前播放張數變數 */
        function photoPlay() {
            var controler = document.getElementById("flipswitch");
            if (controler.options[controler.selectedIndex].value == "on") {
                clock = setInterval(timer, 5000);
            } else {
                clearInterval(clock);
            } /* 設定每五秒執行timer函數 */
            function timer() {
                var pic = document.getElementById("photo"); /* 利用pic紀錄畫面中ID為photo的元素 */
                playNo++; /* 增加張數 */
                if (playNo > 19) {
                    playNo = 1;
                } /* 設定超過圖片張數後從頭播放 */
                TweenMax.to(pic, 1, {
                    css: {
                        alpha: 0
                    },
                    ease: Expo.easeIn,
                    onComplete: function () {
                        pic.innerHTML = "<img src=photo/photo" + playNo + ".jpg width=300 height=200>";
                        TweenMax.to(pic, 1, {
                            css: {
                                alpha: 1
                            },
                            ease: Expo.easeOut
                        });
                    }
                });
            }
        }
    </script>
</head>
<body onLoad="photoPlay()">
    <div data-role="page" id="page">
        <div data-role="header">
            <h1>貓咪欣賞</h1>
        </div>
        <div data-role="content">
            <div id="photo"><img src="photo/photo1.jpg"></div>
            <div data-role="fieldcontain" id="selector"> <select name="flipswitch" id="flipswitch"
                    onChange="photoPlay()" data-role="slider">
                    <option value="off">關閉</option>
                    <option value="on" selected>開啟</option>
                </select> </div>
        </div>
        <div data-role="footer">
            <h4>©2012 Copyright Stanley Ma Cloud Research.</h4>
        </div>
    </div>
</body>
</html>

接下來的第二個範例在程式上面會比較複雜,因為想要加強上一個範例的互動性,所以在同樣的範例上面增加「上一張」、「下一張」與「播放控制」的功能,可在手機輸入「goo.gl/GyAVt」網址觀賞,如果你仔細看的話,會發現這個範例中呼叫網頁元素的語法有改變,其實既然是利用jQuery來製作,本來就可以利用jQuery所提供呼叫網頁元素的指令來製作會比較方便,總之是因為有了下面這行語法,才可以利用這種方式來呼叫的喔!

<script src="jquery-mobile/jquery-1.6.4.min.js" type="text/javascript"></script>

下面是本範例整個網頁的程式碼:

<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalabke=no, width=device-width" />
    <title>貓咪欣賞</title>
    <style type="text/css">
        * {
            margin: 0px;
            padding: 0px;
        }

        #photo {
            text-align: center;
        }

        #selector {
            text-align: center;
            width: 50%;
            margin-left: auto;
            margin-right: auto;
        }

        #count {
            text-align: center;
            width: 50%;
            margin-left: auto;
            margin-right: auto;
            font-size: 12px;
        }
    </style>
    <link href="jquery-mobile/jquery.mobile-1.0.min.css" rel="stylesheet" type="text/css">
    <script src="jquery-mobile/jquery-1.6.4.min.js" type="text/javascript"></script>
    <script src="jquery-mobile/jquery.mobile-1.0.min.js" type="text/javascript"></script>
    <script src="src/minified/TweenMax.min.js"></script>
    <script language="javascript">
        var playing = 1; /* 偵測目前是否為播放中的變數(1為播放0為暫停) */
        var playNo = 1; /* 定義目前播放張數變數 */ /* 執行計時器 */
        function photoPlay() {
            clock = setInterval(timer, 5000);
        } /* 計時執行函數 */
        function timer() {
            playNo++; /* 增加張數 */
            checkPlayNo() /* 呼叫檢查張數是否有誤的函數 */ photoSlide(); /* 呼叫動畫切換照片的函數 */
        } /* 動畫切換照片的函數 */
        function photoSlide() {
            var pic = $("#photo"); /* 利用pic紀錄畫面中ID為photo的元素 */
            TweenMax.to(pic, 0.5, {
                css: {
                    alpha: 0
                },
                ease: Expo.easeIn,
                onComplete: function () {
                    pic.html("<img src=photo/photo" + playNo + ".jpg width=300 height=200>");
                    TweenMax.to(pic, 1, {
                        css: {
                            alpha: 1
                        },
                        ease: Expo.easeOut
                    });
                }
            });
            $("#count").html(playNo + " / 19"); /* 更換顯示張數的文字 */
        } /* 檢查張數是否有誤的函數 */
        function checkPlayNo() {
            if (playNo > 19) {
                playNo = 1;
            } else if (playNo < 1) {
                playNo = 19;
            }
        } /* 前往上一張的函數 */
        function prevFn() {
            clearInterval(clock);
            playNo--;
            checkPlayNo() photoSlide();
            photoPlay();
        } /* 前往下一張的函數 */
        function nextFn() {
            clearInterval(clock);
            playNo++;
            checkPlayNo() photoSlide();
            photoPlay();
        } /* 播放控制函數 */
        function controlFn() {
            if (playing == 1) {
                playing = 0;
                $("#controlBtn").html("播放") clearInterval(clock);
            } else if (playing == 0) {
                playing = 1;
                $("#controlBtn").html("暫停") clock = setInterval(timer, 5000);
            }
        }
    </script>
</head>
<body onLoad="photoPlay()">
    <div data-role="page" id="page">
        <div data-role="header">
            <h1>貓咪欣賞</h1>
        </div>
        <div data-role="content">
            <div id="photo"><img src="photo/photo1.jpg"></div>
            <div data-role="controlgroup" data-type="horizontal" id="selector"><a href="#" data-role="button"
                    id="prevBtn" onClick="prevFn()">上一張</a><a href="#" data-role="button" onClick="controlFn()"><label
                        id="controlBtn">暫停</label></a><a href="#" data-role="button" onClick="nextFn()">下一張</a></div>
            <div id="count">1 / 19</div>
        </div>
        <div data-role="footer">
            <h4>©2012 Copyright Stanley Ma Cloud Research.</h4>
        </div>
    </div>
</body>
</html>

希望大家看過這幾篇「利用TweenMax針對HTML頁面製作動畫」的範例之後,可以更順利的創作出自己的網頁。

You may also like...

236,731 Responses

  1. 10 Things That Your Family Taught You About Ignition Key Replacement Cost ignition Key replacement cost

  2. 9 Things Your Parents Taught You About 4 Wheel Electric Scooter
    For Adults 4 Wheel electric Scooter for adults

  3. 12 Companies That Are Leading The Way In Integrated Fridge Freezer With Water
    Dispenser Larder Fridge With Water Dispenser

  4. 5 Killer Quora Answers To Bi Folding Door Repair Bi Folding Door Repair

  5. Situs Toto表示:

    Situs Toto Tools To Ease Your Daily Life Situs Toto Trick
    Every Person Should Be Able To Situs Toto

  6. What Is Boot Mobility Scooter? History Of Boot Mobility Scooter
    In 10 Milestones Car Boot Mobility Scooters

  7. Private Diagnosis For ADHD Tips To Relax Your Everyday Lifethe Only Private Diagnosis For ADHD Trick
    That Everybody Should Know private diagnosis for adhd (minecraftcommand.science)

  8. Pasquale表示:

    Nine Things That Your Parent Taught You About Folding 8mph
    Mobility Scooter folding 8mph mobility scooter (Pasquale)

  9. 9 Lessons Your Parents Taught You About Coffee Machines For Pods Coffee machines For pods

  10. 7 Simple Tips To Totally Rocking Your Bi Fold Door Repairs
    bi fold door repairs Near me (pattern-wiki.win)

  11. Antonetta表示:

    Guide To Replacement Door Handles: The Intermediate Guide Towards Replacement Door Handles replacement door handles (Antonetta)

  12. The Best Private Psychiatrist North London Strategies For Changing Your Life Private psychiatrist near me uk

  13. 24-Hours To Improve Auto Accident Lawyers For Hire auto accident attorney new Orleans

  14. See What Rollator Walker With Seat Tricks The Celebs Are Making Use Of rollator walker with seat

  15. The Bagless Robotic Sweepers Awards: The Best, Worst And
    The Most Bizarre Things We’ve Seen Bagless Robot Vacuum And Mop

  16. Hollis表示:

    Guide To Double Glazing Aylesbury: The Intermediate Guide Towards Double Glazing Aylesbury
    double glazing aylesbury (Hollis)

  17. Here’s A Few Facts About Depression Support
    Groups. Depression Support Groups lithium for treatment resistant depression

  18. Bandar Online Togel Tools To Ease Your Daily Lifethe One Bandar Online Togel Trick That Everybody Should
    Know bandar online Togel

  19. Easydrorbix表示:

    the people pharmacy ambien: rx pharmacy near me – pharmacy viagra malaysia

  20. Adell表示:

    Guide To Private Psychiatrist Cardiff Cost: The Intermediate Guide In Private Psychiatrist Cardiff Cost private psychiatrist cardiff cost, Adell,

  21. Treadmill With Incline Uk: What No One Is Talking About treadmill for small spaces with Incline

  22. 10 Misleading Answers To Common Private Assessments For ADHD Questions Do You Know The Right Ones?
    private adhd Assessment ipswich

  23. Do You Know How To Explain Local SEO London To Your Mom professional seo services in London (bookmarking.win)

  24. Gaye表示:

    15 Things To Give Your Micro Marble Electric Fire Suites Lover In Your Life white marble electric fire suites (Gaye)

  25. 10 Signs To Watch For To Get A New Smallest Treadmill With Incline
    incline treadmill argos

  26. The 10 Scariest Things About Suzuki Key Replacement Uk
    suzuki Key replacement Uk

  27. Tory表示:

    30 Inspirational Quotes For Fridge Freezer fridge freezers (Tory)

  28. What’s The Current Job Market For Lidar Vacuum Professionals Like?
    lidar Vacuum – https://posteezy.com,

  29. 9779342表示:

    10 Wrong Answers To Common Oil Radiator With Timer Questions Do You Know The Right Answers?

    9779342

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。