`
xhload3d
  • 浏览: 209372 次
社区版块
存档分类
最新评论

基于 HTML5 的 WebGL 技术构建 3D 场景(一)

阅读更多

今天和大家分享的是 3D 系列之 3D 预定义模型。

HT for Web 提供了多种基础类型供用户建模使用,不同于传统的 3D 建模方式,HT 的建模核心都是基于 API 的接口方式,通过 HT 预定义的图元类型和参数接口,进行设置达到三维模型的构建。接下来我们就来谈谈预定义的 3D 模型及参数设置。

HT 预定义的 3D 模型有:box、sphere、cone、torus、cylinder、star、rect、roundRect、triangle、tightTriangle、parallelogram 和 trapezoid 这十二种,那么这十二种类型又是怎么设置的呢?

在网络拓扑图 GraphView 的 2D 图形上,呈现各种图形是通过 style 中的 shape 属性决定的,HT 在 3D 上提供了 shape3d 属性预定义多种 3D 形体。shape3d 属性的默认值为 undefined,图元显示为六面立方图形,当 shape3d 指定值时,则显示为 shape3d 指定的形体,接下来我们来一一介绍 3D 模型的各个形体。

1. box:立方体,不同于默认的六面体,立方体类型的六个面颜色和贴图只能相同,绘制性能比默认六面体高;

就如上图所示,左边是 shape3d 设置为 box,右边是默认的六面体,两个节点都对上表面设置了贴图,但是从效果上看 shape3d 设置为 box 的节点直接无视了上表面的贴图设置,这也应证了上面描述的,box 类型六个面的颜色和贴图只能相同,只对 shape3d.image 和 shape3d.color 起效,下面是具体的设置代码:

node = new ht.Node();
node.s3(80, 80, 80);
node.s({
    'shape3d': 'box',
    'shape3d.image': 'img11',
    'shape3d.top.image': 'img10'
});
dm.add(node);

node = new ht.Node();
node.s3(80, 80, 80);
node.p3(100, 0, 0);
node.s({
    'all.image': 'img11',
    'top.image': 'img10'
});
dm.add(node);

2. sphere:球体,可通过 shape3d.side 分成多片,结合 shape3d.side.from 和 shape3d.side.to 可形成半球体等

就如上图所示,球被裁切掉了一部分,被裁切的两个面可以单独控制,通过 shape3d.from.* 和 shape3d.to.* 两组参数就可以单独控制两面的显示效果,在上图中,我通过 shape3d.to.visible 将 to 的面隐藏了,将 from 面通过 shape3d.from.image 设置了新的贴图,具体代码如下:

node.s({
    'shape3d': 'sphere',
    'shape3d.image': 'img11',
    'shape3d.side': 100,
    'shape3d.side.from': 0,
    'shape3d.side.to': 65,
    'shape3d.from.image': 'img10',
    'shape3d.to.visible': false
});

3. cone:锥体,可通过 shape3d.side 形成三角锥、四角锥等形状

从上图可以看到,side 值越大,椎体就越圆滑,完全可以比拟圆锥。具体如何设置的,我们来看看代码:

[3, 4, 5, 6, 10, 20, 40, 80, 100].forEach(function(side, index) {
    var x = ((index / 3) >> 0) * 100 - 100,
        y = index % 3 * 100 - 100;
    node = new ht.Node();
    node.p3(x, 40, y);
    node.s3(80, 80, 80);
    node.s({
        'shape3d': 'cone',
        'shape3d.image': 'img11',
        'shape3d.side': side,
        'note': 'side: ' + side,
        'note.autorotate': true,
        'note.position': 17,
        'note.face': 'top',
        'note.background': '#979EAF'
    });
    dm.add(node);
});

当然,椎体也可以和球体一样,可以设置 shape3d.side.from 和 shape3d.side.to 参数来控制裁切;还可以通过 shape3d.from.* 和 shape3d.to.* 参数来控制两个面的表现效果;还可以通过 shape3d.bottom.* 样式来控制椎体地面的表现效果。

在上面的代码中,可以看到 note 相关的设置,在这边也顺带介绍下,note.autorotate 样式是用来控制 note 的朝向,如果设置为 true,那么这个 note 永远是朝向眼睛的方向,不管场景如何旋转。

4. torus:圆环,可通过 shape3d.side 分成多片,结合 shape3d.side.from 和 shape3d.side.to 可形成半圆环等

在上图中可以看出,圆环其实和圆锥是一样的,也是可以设置边数,构成三角环,四角环等形状,当边数达到一定的程度,边数越多,圆环就越平滑。

在上图中可以看到 note 中多加了一个 radius 值的打印,这个值对应的是样式中的 shape3d.torus.radius,那么这个值的作用是什么呢,我想从上图也可以看得出来,radius 值是用来控制圆环的半径,但是为什么 radius 为 0.25 的时候圆环中间就被填上了,没有像其他的圆环中间都漏空呢?我们可以这样理解,一个圆环的切面有两个圆环直径,那就有四个圆环半径,那按百分比去计算的话,一个半径就是占整个图元宽的 1/4,也就是 0.25,所以这个 shape3d.torus.radius 样式的取值范围为 0~0.25。

[3, 4, 5, 6, 10, 20, 40, 80, 100].forEach(function(side, index) {
    var x = ((index / 3) >> 0) * 100 - 100,
        y = index % 3 * 100 - 100;
    radius = (Math.random() * 0.25).toFixed(2);
    node = new ht.Node();
    node.p3(x, 40, y);
    node.s3(80, 80, 80);
    node.s({
        'shape3d': 'torus',
        'shape3d.image': 'img11',
        'shape3d.side': side,
        'shape3d.torus.radius': radius,
        'note': 'side: ' + side + ', radius: ' + radius,
        'note.autorotate': true,
        'note.position': 17,
        'note.face': 'top',
        'note.background': '#979EAF'
    });
    dm.add(node);
});

5. cylinder:圆柱,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

圆柱的参数除了 shape3d.top.* 之外,其他的都和前面提到的圆锥的参数一样,因为圆柱体其实就是比圆锥体多了一个面。

[3, 4, 5, 6, 10, 20, 40, 80, 100].forEach(function(side, index) {
    var x = ((index / 3) >> 0) * 100 - 100,
        y = index % 3 * 100 - 100;
    node = new ht.Node();
    node.p3(x, 40, y);
    node.s3(80, 80, 80);
    node.s({
        'shape3d': 'cylinder',
        'shape3d.image': 'img11',
        'shape3d.side': side,
        'note': 'side: ' + side,
        'note.autorotate': true,
        'note.position': 17,
        'note.face': 'top',
        'note.background': '#979EAF'
    });
    dm.add(node);
});

到这里所有的可裁切的基本模型都介绍完了,下面要介绍的几个基本模型就没有 side 的相关属性了,也就意味着,它们将没有 from 和 to 的相关参数,没有裁切的功能。

如果想让不能裁切的基本图元达到裁切的效果,还是有其他方案和方法的,这些,我们就在后续的章节中介绍,还望耐心等待。

6. star:星形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

7. rect:矩形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

8. roundRect:圆矩形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

9. triangle:三角形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

10. rightTriangle:直角三角形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

11. parallelogram:平行四边形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

12. trapezoid:梯形体,可通过 shape3d.top.* 和 shape3d.bottom.* 可控制顶面和底面的参数

上图就是几个还未介绍的基本模型。

[
    'star', 'rect', 'roundRect', 'triangle',
    'rightTriangle', 'parallelogram', 'trapezoid'
].forEach(function(shape, index) {
    var x = index * 100 - 300;
    node = new ht.Node();
    node.p3(x, 40, 0);
    node.s3(80, 80, 80);
    node.s({
        'shape3d': shape,
        'shape3d.image': 'img11'
    });
    dm.add(node);
});


仔细观察上图,你会发现,从左算起,第二个和第四个好像在前面的例子中有见过。没错,在形状上是一样的,但是在表现上却是有些差异,到底存在什么差异呢,我们通过图来瞧瞧。

左边是基本模型 rect 和 triangle,右边是通过基本模型 cylinder 模拟出来的 rect 和 triangle,四个图元设置的大小都是一样的,边长都是 80,可以发现基本模型 rect 和 triangle 在表现上会比通过 cylinder 模拟出来的 rect 和 triangle 来的大些,原因很简单,通过 cylinder  模拟出来的 rect 和 triangle 因为其本质还是圆柱体,side 参数是是让图形能够更接近圆形而已,所以绘制出来的图形将会是在一个圆柱体内,也就是 rect 基本模型上表面的内切圆范围内,也就是说通过 cylinder 模拟出来的 rect 上表面的对角线才是图元的变成 80。

以下是相关代码,大家可以尝试下,通过不同角度的观察,可能会更好理解一些。

node = new ht.Node();
node.s3(80, 80, 80);
node.p3(-50, 40, 50);
node.s({
    'shape3d': 'cylinder',
    'shape3d.side': 4,
    'shape3d.image': 'img11'
});
dm.add(node);

node = new ht.Node();
node.s3(80, 80, 80);
node.p3(50, 40, 50);
node.s({
    'shape3d': 'cylinder',
    'shape3d.side': 3,
    'shape3d.image': 'img11'
});
dm.add(node);

node = new ht.Node();
node.s3(80, 80, 80);
node.p3(-50, 40, -50);
node.s({
    'shape3d': 'rect',
    'shape3d.image': 'img11'
});
dm.add(node);

node = new ht.Node();
node.s3(80, 80, 80);
node.p3(50, 40, -50);
node.s({
    'shape3d': 'triangle',
    'shape3d.image': 'img11'
});
dm.add(node);

这样,HT 的 3D 预定义模型就介绍完了,可以结合 HT 的官方文档(http://www.hightopo.com/guide/guide/core/3d/ht-3d-guide.html)一起阅读,可能更好理解些。那么在下一章节,我们将会重点介绍 3d Max 设计导出的模型在 HT 中应用。

 

0
0
分享到:
评论

相关推荐

    HTML5 WebGL 3D 仓储管理系统

    此外,ht.js可能是一个用于构建3D场景的JavaScript库,它为开发者提供了更高级的工具和函数,简化了WebGL的编程复杂性。通过这个库,开发者可以轻松地添加交互式元素,如点击某个货位获取详细信息,或者拖放货物进行...

    基于HTML5的WebGL技术电信3D机房漫游源代码

    HTML5是下一代网页标记语言,它的出现极大地扩展了网页的交互性和功能,其中WebGL(Web Graphics Library)是一项关键的技术,它使得浏览器可以直接在用户的设备上进行硬件加速的3D图形渲染,无需任何插件。...

    基于webgl的办公室3D场景(简化版)

    本项目“基于WebGL的办公室3D场景(简化版)”就是利用WebGL技术构建的一个3D展示环境,特别是借助了流行的JavaScript库——three.js,来简化3D编程的过程。 【描述】: WebGL是一个基于OpenGL标准的JavaScript ...

    基于WebGL实现3D图片特效

    在这个案例中,可能使用的库可能包括Three.js或 Babylon.js,它们都是基于WebGL的库,提供了丰富的3D建模和动画功能,使得开发者可以更轻松地创建复杂的3D场景和交互效果。 接着,我们关注到压缩包内的文件,例如`...

    HTML5 WebGL酷炫3D旋转星云动画特效

    总之,"HTML5 WebGL酷炫3D旋转星云动画特效"是结合HTML5的WebGL技术和JavaScript的创新应用,通过精心设计的代码和视觉效果,为用户呈现了一种极具沉浸感的3D体验。对于想要学习WebGL或者提升网页互动性的开发者来说...

    基于HTML5原生WebGL实现的轻量级Google Earth三维地图引擎.zip

    "基于HTML5原生WebGL实现的轻量级Google Earth三维地图引擎"这个标题揭示了我们讨论的核心技术。HTML5是下一代网页标准,它在互联网上提供了更丰富的交互性和多媒体功能。而WebGL是HTML5的一个重要组成部分,它允许...

    HTML5+CSS+WEBGL网页3D游戏开发

    通过WebGL,开发者可以直接在浏览器上构建复杂的3D场景,无需任何插件。WebGL与Three.js等库结合,可以简化3D图形编程,让开发者更专注于游戏逻辑和交互设计。 在"HTML5 Games Creating Fun with HTML5, CSS3, and ...

    Babylonjs一个用HTML5和WebGL构建3D游戏的完整JavaScript框架

    它利用了HTML5的Canvas元素和WebGL图形接口,为开发者提供了丰富的功能和高效的性能,使他们能够在网页上创建复杂的3D场景和交互式体验。 Babylon.js的核心特性包括: 1. **渲染引擎**:Babylon.js内置了一个高级...

    WebGL技术初步评估

    WebGL基于OpenGL ES 2.0标准,由Khronos Group开发并维护,这是一个开放的3D图形标准,旨在为HTML5的Canvas元素提供硬件加速的3D渲染能力。 WebGL的核心在于将JavaScript与OpenGL ES 2.0结合,使得Web开发者可以...

    TypeScript图形渲染实战:基于WebGL的3D架构与实现_源代码+视频.zip

    在本资源中,"TypeScript图形渲染实战:基于WebGL的3D架构与实现",我们探讨了如何利用TypeScript这一强大的静态类型语言,结合WebGL技术,来构建高效的3D图形渲染应用。WebGL是一种JavaScript API,允许在浏览器中...

    HTML5 WebGL酷炫粒子爆炸动画特效

    这款"HTML5 WebGL酷炫粒子爆炸动画特效"正是基于这一技术,为网页带来了惊人的视觉体验。 WebGL(Web Graphics Library)是基于OpenGL ES 2.0的一个JavaScript API,用于在任何兼容的Web浏览器中渲染交互式2D和3D...

    WebGl的3D空间

    WebGL是一种基于OpenGL标准的JavaScript API,用于在任何兼容的Web浏览器中呈现交互式的2D和3D图形,无需插件。它充分利用了现代GPU的能力,使得网页开发者能够创建复杂的3D场景,为用户带来沉浸式的体验。在这个...

    【3D模型】webGL人体3D动态模型

    WebGL是一种基于OpenGL标准的JavaScript API,它在Web浏览器中实现了硬件加速的3D图形渲染,使得开发者可以构建交互式的、复杂的3D场景。在"3D人物模型"的领域中,WebGL被广泛用于创建逼真的角色动画,包括人体动作...

    html5 webgl绘制3D洞穴穿越无限延伸动画特效.zip

    HTML5的WebGL技术是网页开发中的一个强大工具,它允许开发者在浏览器中直接进行3D图形渲染,无需借助任何额外的插件。这个“html5 webgl绘制3D洞穴穿越无限延伸动画特效.zip”文件包含了一套完整的实现3D洞穴穿越...

    HTML5+WebGL 3D雪花飘落动画特效

    在这个“HTML5+WebGL 3D雪花飘落动画特效”项目中,开发者利用这两种技术构建了一个逼真的3D下雪场景,为网页增添了视觉吸引力。 HTML5是超文本标记语言的最新版本,它引入了许多新特性,如离线存储(localStorage...

    基于WebGL技术和Oak3D引擎的交互式三维地球模型研究

    WebGL技术是一种基于Web的3D图形标准,它允许Web页面通过JavaScript与OpenGL ES 2.0结合使用,为HTML5的Canvas元素提供硬件加速的3D图形渲染能力。这种技术的出现,极大地推动了Web中三维图形应用的发展,使得开发者...

    HTML5+WebGL实现带多层视差响应的游戏场景3D视图效果源码.zip

    学习和研究这个源码,开发者可以深入理解如何结合HTML5和WebGL构建3D游戏场景,以及如何实现视差滚动效果。这对于想要提升网页游戏开发技能或者对3D网页技术感兴趣的人来说是一份宝贵的资源。通过分析源码,可以学习...

    html5_3d_webgl_多个旋转地球materials

    5. **渲染**:使用WebGL API将所有元素组合成一个完整的3D场景,并在浏览器窗口中渲染出来。 在项目文件"008"中,可能包含了实现上述功能的源代码,如HTML文件、CSS样式表和JavaScript脚本。这些文件可能包含详细的...

    HTML5 WebGL实现的2050地球未来水世界3D场景模拟动画效果源码.zip

    这个压缩包“HTML5 WebGL实现的2050地球未来水世界3D场景模拟动画效果源码.zip”提供了一个基于WebGL的3D地球模型,模拟了2050年的未来地球可能面临的水世界情景。 WebGL是一个JavaScript API,它允许开发者在...

    Html5 WebGL.Beginners.Guide

    HTML5作为现代网页开发的标准,极大地扩展了Web的潜力,而WebGL则是HTML5中的一项重要技术,它使得开发者可以直接在浏览器中创建交互式的3D图形,无需依赖任何插件。这本书结合了HTML、CSS3和JavaScript的相关知识,...

Global site tag (gtag.js) - Google Analytics