分享
查看: 1927|回复: 0

[分享] ThingJS:普通人也可以进行3D开发

[复制链接]

ThingJS:普通人也可以进行3D开发

发表于 2020-9-8 16:06:55 来自 分享 阅读模式 倒序浏览
zzv_icon1927 zzr_icon0 查看全部

二维平面给人最直观的感受,三维立体可以给人想象的空间,ThingJS的3D编辑器也适合非开发者用哦!

ThingJS开发界面中,进行3D场景可视化的编辑区域,我们把它称之为3D容器,也就是展示3D图片的地方,如下图所示。ThingJS 3D开发工具主要提供 'Marker' 物体和 'WebView' 物体以支持 3D 空间界面。

ThingJS:普通人也可以进行3D开发

我们先来看看两者的区别。

Marker:可以将图标、Canvas绘制的图片,展现在3D场景中或绑定在3D物体上。

WebView:可以将页面嵌入到3D场景中,支持iframe元素引用一个新的网页

1. Marker 物体

ThingJS:普通人也可以进行3D开发

Marker 物体可以添加一个图片放置到你希望的位置,也可以将这个图片作为子对象添加到父对象身上,随着父对象一同移动。

例子 1

  1. app.create({
  2. type: "Marker",
  3. offset: [0, 2, 0],
  4. size: [4, 4],
  5. url: "https://thingjs.com/static/images/warning1.png",
  6. parent: app.query("car01")[0]
  7. });
复制代码

参数:

· type : 通知系统创建 Marker 物体;

· offset : 设置自身坐标系下偏移量为[0, 2, 0]

· size : 设置 Marker 物体大小,也可以添单独数字如 4,等同于[4,4],大小是以米计算的;

· url : 图片的 url

· parent :指定 Marker 的父物体;

运行结果见下图。Marker 默认是受距离远近影响,呈现近大远小的 3D 效果,也会在 3D 空间中实现前后遮挡。

ThingJS:普通人也可以进行3D开发

例子 2

  1. app.create({
  2. type: "Marker",
  3. offset: [0, 8, 0],
  4. size: 2,
  5. keepSize: true,
  6. url: "https://thingjs.com/static/images/reminder.png",
  7. parent: app.query(".Building")[1]
  8. });
复制代码


参数:

· keepSize: 控制是否受距离远近影响,呈现近大远小的 3D 效果。如果设置 true,表示保持大小,不随距离近大远小,此时 size 的单位是屏幕的像素点;

· offset : 设置自身坐标系下偏移量为[0, 2, 0]

· size : 设置 Marker 物体大小,也可以添单独数字如 4,等同于[4,4],大小是以米计算的;

· url : 图片的 url

· parent :指定 Marker 的父物体;

运行结果见下图:

ThingJS:普通人也可以进行3D开发

我们还可以使用 h5 canvas 手动创建动态图。

例子 3

  1. function createTextCanvas(text, canvas) {
  2. if (!canvas) {
  3. canvas = document.createElement("canvas");
  4. canvas.width = 64;
  5. canvas.height = 64;
  6. }
  7. const ctx = canvas.getContext("2d");
  8. ctx.fillStyle = "rgb(32, 32, 256)";
  9. ctx.beginPath();
  10. ctx.arc(32, 32, 30, 0, Math.PI * 2);
  11. ctx.fill();
  12. ctx.strokeStyle = "rgb(255, 255, 255)";
  13. ctx.lineWidth = 4;
  14. ctx.beginPath();
  15. ctx.arc(32, 32, 30, 0, Math.PI * 2);
  16. ctx.stroke();
  17. ctx.fillStyle = "rgb(255, 255, 255)";
  18. ctx.font = "32px sans-serif";
  19. ctx.textAlign = "center";
  20. ctx.textBaseline = "middle";
  21. ctx.fillText(text, 32, 32);
  22. return canvas;
  23. }
  24. app.on('load', function (ev) {
  25. var marker = app.create({
  26. type: "Marker",
  27. offset: [0, 2, 0],
  28. size: 3,
  29. canvas: createTextCanvas('100'),
  30. parent: app.query('car02')[0]
  31. }).on('click', function (ev) {
  32. var txt = Math.floor(Math.random() * 100);
  33. ev.object.canvas = createTextCanvas(txt, ev.object.canvas)
  34. })
  35. })
复制代码

参数:

· canvas: 接收 canvas 作为贴图显示

ThingJS:普通人也可以进行3D开发

2. WebView 物体

我们还可以使用 WebView 物体,将其他网站或者页面的内容嵌到 3D 中。

例子 4

  1. var webView01 = app.create({
  2. type: 'WebView',
  3. url: 'https://www.thingjs.com',
  4. position: [10, 13, -5],
  5. width: 1920 * 0.01, // 3D 中实际宽度 单位 米
  6. height: 1080 * 0.01, // 3D 中实际高度 单位 米
  7. domWidth: 1920, // 页面宽度 单位 px
  8. domHeight: 1080// 页面高度 单位 px
  9. });
复制代码


ThingJS:普通人也可以进行3D开发

3D开发不需要专业知识,只需要JS基础,终于可以做自己的商业项目了!


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

本版积分规则

130700ppkpl8x3t7tt1b1t