首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将Popmotion示例转换为GreenSock

将Popmotion示例转换为GreenSock
EN

Stack Overflow用户
提问于 2016-02-15 04:29:22
回答 1查看 601关注 0票数 7

我正在尝试将这个Popmotion示例转换为GreenSock

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

代码语言:javascript
复制
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有演员和模拟器吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-02-03 00:05:08

我从来没有使用GreenSock来进行连续的动态动画(可能是可能的,我不是GreenSock方面的专家)。我宁愿离开这个库来制作一个特定的动画。在下一个例子中,我尝试复制使用我自己的计算发布的相同的Popmotion效果,我只是使用动画库将这个框返回到它原来的位置。我认为它能帮助你达到你的目的:

为了使代码更容易阅读,我删除了供应商前缀,但是CodePen示例中有前缀。

HTML代码:

代码语言:javascript
复制
<div id="container">

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

</div>

CSS代码

代码语言:javascript
复制
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代码:

代码语言: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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35401503

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档