分享
查看: 1823|回复: 0

[分享] 开发和业务相爱相杀?降低开发门槛,让3D开发变轻松!

[复制链接]

开发和业务相爱相杀?降低开发门槛,让3D开发变轻松!

发表于 2020-8-10 18:47:23 来自 分享 阅读模式 倒序浏览
zzv_icon1823 zzr_icon0 查看全部

开发人员和业务人员沟通的鸿沟有多深?即使很深,感情也可以很好!ThingJS新推出的摄像头动效功能。

在了解摄像机跟随物体移动之前,我们需要先了解摄像机,摄像机作为ThingJS中十分重要的一个对象,需要我们认真了解和学习。

摄像机包含两个重要的位置参数:镜头位置 position 和被拍摄物体的位置 target (又叫目标点)。(具体可以看看

https://www.thingjs.com/guide/cn/tutorial_Introduce/Camera.html

开发和业务相爱相杀?降低开发门槛,让3D开发变轻松!

形象点来说,镜头就像是手机的相机,摄像头的定位决定了拍摄的角度,而被拍摄物体的位置更好理解了,物体可以是静止不动的,也可以是移动的,所以ThingJS新推出摄像机跟随物体移动的新功能,如何一步步实现呢?

在跟随物体移动之前,我们需要了解物体在程序语言里移动方式,例如位移(move to)或让物体沿着不同的路径移动(move path)等,路径有方形路径、圆形路径,网页端通过点击按钮进行切换。

开发和业务相爱相杀?降低开发门槛,让3D开发变轻松!


镜头跟随物体移动


ThingJS中世界坐标系使用position属性,想象一下,跟随物体移动(move path)的时候,摄像头需要一个合适的拍摄位置,比如正前方或后上方,那么改变这个坐标的position值就可以了。ThingJS默认position [0, 5, -10] 代表 摄像机位置为“移动小车后上方”,意味着向后移动到10m处,且向上移动5m,形成俯视定位,这就是世界坐标系下摄影机位置的计算方式。

跟随物体移动用到的path,主要是为物体设计一条有弧度的移动路径,由世界坐标系下的坐标点组成。所以,需要获取一个坐标点构成的数组,通过每一帧更新摄像机的位置实现沿着路径移动,最后使用stop moving接口来终止移动。

  1. var app = new THING.App({
  2. url: 'https://www.thingjs.com/static/models/simplebuilding'
  3. });
  4. // 加载场景后执行
  5. app.on('load', function () {
  6. // 通过 name 查询到场景中的车
  7. var car = app.query('car01')[0];
  8. // 世界坐标系下坐标点构成的数组 关于坐标的获取 可利用「工具」——>「拾取场景坐标」
  9. // 拐角处多取一个点,用于转向插值计算时更平滑
  10. var path = [[0, 0, 0], [2, 0, 0], [20, 0, 0], [20, 0, 2], [20, 0, 10], [18, 0, 10], [0, 0, 10], [0, 0, 8], [0, 0, 0]];
  11. car.position = path[0];
  12. car.movePath({
  13. path: path,
  14. orientToPath: true,
  15. loopType: THING.LoopType.Repeat,
  16. time: 10 * 1000
  17. })
  18. new THING.widget.Button('摄像机跟随物体', function () {
  19. // 每一帧设置摄像机位置 和 目标点
  20. car.on('update', function () {
  21. // 摄像机位置为 移动小车后上方
  22. // 为了便于计算 这里用了坐标转换 将相对于小车的位置 转换为 世界坐标
  23. app.camera.position = car.selfToWorld([0, 5, -10]);
  24. // 摄像机目标点为 移动小车的坐标
  25. app.camera.target = car.position
  26. }, '自定义摄影机跟随');
  27. });
  28. new THING.widget.Button('停止', function () {
  29. car.off('update', null, '自定义摄影机跟随');
  30. });
  31. });
复制代码

非开发人员也能够进行基础的场景搭建,例如地图。ThingJS降低了开发门槛,让3D成为所有人都愿意尝试的一门艺术。


avatar
游客~
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

130700ppkpl8x3t7tt1b1t