首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在two.js中创建深度

如何在two.js中创建深度
EN

Stack Overflow用户
提问于 2016-12-30 10:25:42
回答 1查看 254关注 0票数 1

我最近一直在学习如何使用two.js,我想围绕另一个物体做一个圆的轨道,比如行星。由于它需要经过它环绕的物体的后面,我尝试在它移动时动态地改变圆的大小,以创造深度的错觉。我看到了另一个关于使用矩阵在two.js中更改大小的溢出问题,并尝试将其应用于此,但我无法获得与轨道运动同步的大小更改。如果有任何帮助,我将不胜感激。

JS (因为它需要two.js库,所以一开始不会产生任何东西,但我这样做是为了方便任何想要提供帮助的人):https://jsbin.com/rugakojivu/edit?html,output

代码语言:javascript
复制
<html>
<head>
<script src = "two.js"></script>
</head>
<body>
<div id = "frame"></div>
<script>
var el = document.getElementById("frame");
var two = new Two({fullscreen:true}).appendTo(el);
var bigAngle = 0,
smallAngle  = 0,
distance   = 10,
radius     = 50,
orbit      = 200,
orbits     = two.makeGroup();
var  offset = 300;

function getPositions(angle, orbit) {
return {
    x: Math.cos(angle * Math.PI / 180) * orbit,
    y: Math.sin(angle * Math.PI / 180) * orbit
};
}

var pos = getPositions(bigAngle,orbit),
big = two.makeCircle(pos.x+offset,pos.y+offset,radius);

big.stroke="#123456";
big.linewidth=7;
big.fill="#194878";

big._matrix.manual=true;

two.bind("update",function(frameCount){
  var pos = getPositions(bigAngle++,orbit);
  big.translation.x=pos.x+offset;
  big.translation.y=pos.y+offset;
});

  two.bind("update",function(frameCount,timeDelta){
  var sx=Math.sin(frameCount/200);
  big._matrix
    .identity()
    .translate(big.translation.x, big.translation.y)
    .rotate(big.rotation)
    .scale(sx);

    });
    two.play();


    </script>
    </body>
    </html>
EN

回答 1

Stack Overflow用户

发布于 2019-01-03 05:01:48

你的圆圈不会平滑地扩大和缩小,因为浏览器不能像你需要的那样快速地渲染它。

这是来自Two.js.org

two.play()以60fps的速度调用two.update()。然而,如果每帧有太多的内容要渲染,那么这个速度就会变慢

无论你使用的是frameCount还是timeDelta,这种情况都会发生。

Poor performance - SVG animations中的答案回顾了一些提高two.js性能的策略。此外,您可以使用带有@keystrokes的CSS动画重新创建此动画,以获得相同的动画。

我认为这与您所做的非常接近:https://jsfiddle.net/merhoo/skmz279w/1/

希望这能有所帮助!

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

https://stackoverflow.com/questions/41389816

复制
相关文章

相似问题

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