BABYLONJS镜头动画

1、最近做核电站的镜头控制;产品要求切换镜头的时候要有个过渡动画;这种简单的东西也没啥好讲的;直接上效果由于做的核电站项目担心被公式起诉;所以搞了类似的东西展示效果;
图书馆(镜头切换)[link](http://3dmad.online.fr/WebGL/Library_Interactive_Map_Mtp/index.html)

2、核心代码

	var speed1 = 45;
    var speed2 = 45;
    var frameCount = 200;
    
    //Animation Camera position
    var animateCameraToPosition = function(cam, speed, frameCount, newPos) {
        var ease = new BABYLON.CubicEase();
        ease.setEasingMode(BABYLON.EasingFunction.EASINGMODE_EASEINOUT);
        BABYLON.Animation.CreateAndStartAnimation('at5', cam, 'position', speed, frameCount, cam.position, newPos, 0, ease);
    }
    animateCameraToPosition(camera, speed1, frameCount, new BABYLON.Vector3(5, 10, -0));

    //Animation Camera target
    var animateCameraTargetToPosition = function(cam, speed, frameCount, newPos) {
        var ease = new BABYLON.CubicEase();
        ease.setEasingMode(BABYLON.EasingFunction.EASINGMODE_EASEINOUT);
        BABYLON.Animation.CreateAndStartAnimation('at5', cam, 'target', speed, frameCount, cam.target, newPos, 0, ease);
    }
    animateCameraTargetToPosition(camera, speed2, frameCount, new BABYLON.Vector3(11.4, 0, -0));

要控制镜头改变目标值就用targer 改变位置就用position

CubicEase表示一个缓动函数,该函数创建一个使用公式 f(t) = t3 进行加速和/或减速的动画。Babylonjs金主是微软所以也继承了他爸爸类具体解释
参考链接:
https://docs.microsoft.com/zh-cn/dotnet/api/system.windows.media.animation.cubicease?view=net-5.0

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值