簡體   English   中英

將Popmotion示例轉換為GreenSock

[英]Converting Popmotion example to GreenSock

我正在嘗試將此Popmotion示例轉換為GreenSock

https://codepen.io/popmotion/pen/xVeWmm

var SELECTOR      = '.box';
var velocityRange = [-1000, 1000];
var maxRotate     = 30;
var smoothing     = 100;

var box = ui.select(SELECTOR, {
    values: {
        x: 0,
        y: 0,
        rotateY: {
            watch: function (actor) {
                return actor.values.x.velocity;
            },
            mapFrom: velocityRange,
            mapTo: [-maxRotate, maxRotate],
            smooth: smoothing
        },
        rotateX: {
            watch: function (actor) {
                return actor.values.y.velocity;
            },
            mapFrom: velocityRange,
            mapTo: [maxRotate, -maxRotate],
            smooth: smoothing
        }
    }
});

var track2D = new ui.Track({
    values: {
        x: {},
        y: {}
    }
});

var springBack = new ui.Simulate({
    simulate: 'spring',
    spring: 500,
    friction: 0.3,
    values: {
        x: 0,
        y: 0
    }
});

$('body').on('touchstart mousedown', SELECTOR, function (e) {

    e.preventDefault();        
    box.start(track2D, e);

});

$('body').on('touchend mouseup', function () {

    box.start(springBack);

});

作為GreenSock的總GreenSock ,這很容易嗎? GreenSock有演員和模擬器嗎?

我從未使用GreenSock制作連續的動態動畫(也許有可能,我不是GreenSock的專家)。 我更喜歡離開這個庫來制作一個特定的動畫。 在下一個示例中,我嘗試使用自己的計算復制您發布的相同Popmotion效果,我只使用動畫庫將框返回到其原始位置。 我認為它可以幫助您達到目的:

我刪除了供應商前綴以使代碼更易於閱讀,但CodePen示例具有前綴。

HTML代碼:

<div id="container">

  <div class="box"></div>

</div>

CSS代碼

html {
    height: 100%;
}

body {
    background: #e25875;
    height: 100%;
}

#container {
    height: 100%;
    perspective: 700;
    perspective-origin: 50% 50%;
    position: relative;
    transform-style: preserve-3d;
    width: 100%;
}

.box {
    background: white;
    border-radius: 4px;
    height: 150px;
    left: 50%;
    margin-left: -75px;
    margin-top: -75px;
    position: absolute;
    cursor: pointer;
    top: 50%;
    will-change: transform;
    width: 150px;
}

JavaScript代碼:

//---Variables
var doc = document,
    box = doc.querySelector(".box"),
    startX = 0,
    startY = 0,
    posX = 0,
    posY = 0,
    speedX = 0,
    speedY = 0,
    obj = {x: 0, y: 0, speedX: 0, speedY: 0};

//---Main Events
box.addEventListener("mousedown", startMove);
doc.addEventListener("mouseup", stopMove);

//---Start the movement
function startMove (evt) {

    startX = evt.pageX;
    startY = evt.pageY;

    //---Add the mouse move events
    doc.addEventListener("mousemove", updatePosition);

}

//---Update variables
function updatePosition (evt) {

    speedX = (evt.pageX - posX) * 5;
    speedY = (evt.pageY - posY) * 5;

    if (speedX < -45) { speedX = -45 }
    if (speedX > 45) { speedX = 45 }
    if (speedY < -45) { speedY = -45 }
    if (speedY > 45) { speedY = 45 }

    posX = evt.pageX;
    posY = evt.pageY;

    obj.x += (posX - startX - obj.x) * .15;
    obj.y += (posY - startY - obj.y) * .15;
    obj.speedX += (speedX - obj.speedX) * .15;
    obj.speedY += (speedY - obj.speedY) * .15; 

    updateTransform();

}

//---Stop movement, returns the box to its place
function stopMove () {

    TweenLite.to(obj, 0.75, {
        ease: Elastic.easeOut.config(1, 0.3),
        x: 0,
        y: 0,
        speedX: 0,
        speedY: 0,
        onUpdate: updateTransform
    });

    doc.removeEventListener("mousemove", updatePosition);

}

//---Update the box transformations
function updateTransform () {

    var transformStr = "translate(" + obj.x + "px, " + obj.y + "px) rotateX(" + (-obj.speedY) + "deg) rotateY(" + obj.speedX + "deg)";

    box.style.transform = transformStr;

}

這里有一個CodePen和一個工作示例。

編輯:我已更新CodePen以使用Touch Events

CodePen

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM