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

根据矩阵变化实现基于 HTML5 的 WebGL 3D 自动布局

阅读更多

数学中矩阵是以排列数字符号表达式矩形阵列任何矩阵都可以通过相关字段标量乘以元素矩阵的主要应用是表示线性变换,即fx)= 4 x线性函数的推广例如,旋转载体在三空间是一个线性变换,这可以通过一个表示旋转矩阵 [R 如果v是一个列向量描述(只有一列的矩阵)的位置在空间中的点,该产品器Rv是列矢量描述旋转后该点的位置。两个变换矩阵的乘积是表示两个变换组成矩阵矩阵的另一个应用是线性方程组的解如果矩阵是方形的,可以通过计算其行列式来推断它的一些性质例如,当且仅当其行列式不为零时,方阵具有相反的 从矩阵的特征值和特征向量中可以看到线性变换几何结构(以及其他信息)

矩阵的应用可以在大多数科学领域找到。物理学的每一个分支,包括经典力学光学电磁学量子力学量子电动力学,都被用来研究物理现象,比如刚体的运动计算机图形学中,它们被用来操作三维模型并将其投影到二维屏幕上概率论统计学中随机矩阵被用来描述概率集; 例如,它们在PageRank算法中用于对Google搜索中的页面进行排名。[5] 矩阵演算概括经典分析概念,如衍生物指数更高的尺寸。矩阵在经济学中被用来描述经济关系系统。


首先,这个实现真的是非常的酷,我从来不知道分子中的引力和斥力结合矩阵能做出这么炫酷的效果,而且还是代码量非常少的情况下,这个例子在医疗界还有生物界应该是应用非常广泛的,但是如果好好利用,在工业方面也一定有不小的成就。

http://www.hightopo.com/demo/pipeline/index.html


接下来我的任务就是帮助你们也能轻松地实现这个效果,HT 将弹力布局的 js 文件放到了一个独立的文件中,在引用这个 js 文件需要先引入 ht.js,因为我们还做了一个 form 表单,所以也要引入 form 表单的 js 文件, 并不是所有的 HT 封装的的功能都需要引入一个特别的 js 文件,需要引入额外的 js 文件的手册中顶部都会有介绍,这里 forcelayout 弹力布局的 js 和 form 表单的 js 的排放顺序没有关系:

 

<script src="../../guide/lib/core/ht.js"></script>
<script src="../../guide/lib/plugin/ht-forcelayout.js"></script>
<script src="../../guide/lib/plugin/ht-form.js"></script>

首先我们定义一个颜色数组变量,存储各个弹力球的颜色,还定义了一个随机函数,用来生成数随机的数组中的颜色:

 

 

var colorList = ['#FFAFA4', '#B887C5', '#B9EA9C', '#CFD9E7', '#4590B8', '#FF9C30'],
colorLen = colorList.length;
var randomColor = function() {
    var ran = Math.random() * colorLen;
    return colorList[Math.floor(ran)];//随机6种颜色
};

接着创建弹力球,简单生成一个 3D 节点,通过设置这个节点的 style 样式属性来控制节点的显示方式,其中将“shape3d”设置为“sphere”即可将 ht.Node 六面体变成 3D 球体模型,再设置“shape3d”属性为前面定义的随机颜色,s3 也是 HT 封装的设置 3D 节点大小的函数,最后将这个节点添加进数据模型 dataModel 中:

 

 

var createNode = function(dm) {//创建node节点 圆
    var node = new ht.Node();
    node.s({
        'shape3d': 'sphere',
	'shape3d.color': randomColor()
    });
    node.s3(40, 40, 40);
    dm.add(node);
    return node;
};

现在效果图上出现的还有各个弹力球之间的连线,这个连线我们一看就觉得很不一般,也是通过构造一个一个节点,这个节点是通过 HT for Web 建模手册 setShape3dModel函数自定义的一个 3D 模型,将其命名为‘custom’:

 

 

ht.Default.setShape3dModel(//创建模型 根据xy平面的曲线,环绕一周形成3D模型。
    'custom', ht.Default.createRingModel( [0.5, 0.5, -0.2, 0, 0.5, -0.5], [1, 3] )
);

 

HT 将用户自定义的属性和 HT 默认的属性调用方法分为 node.a 和 node.s 这样就能将两者有效地区分开来,我们在创建管线的时候就调用了这种方法:

 

var updatePipeline = function(edge) {//重新设置edge的样式
    var pipeline = edge.a('pipeline');
    pipeline.s3(1, 1, 1);
    pipeline.p3(0, 0, 0);

    var node1 = edge.getSourceAgent(),//获取图形上连接的起始节点
    node2 = edge.getTargetAgent();
    pipeline.s('mat', createMatrix(node1.p3(), node2.p3(), 20));//3d整体图形矩阵变化
};

 

我们知道,矩阵能描述任意线性变换。线性变换保留了直线和平行线,线性变换保留直线的同时,其他的几何性质如长度、角度、面积和体积可能被变换改变了。简单的说,线性变换可能“拉伸”坐标系,但不会“弯曲”或“卷折”坐标系。这个函数主要是将我们的连接线在拖动弹力球后被拖拉的连接线的进行一个“变化矩阵”的操作,变化矩阵也是 HT 封装的 ht.Default.createMatrix 函数,能够非常轻松地创建出变化矩阵:

 

var createMatrix = function(p1, p2, width) {//createMatrix(array, matrix)将一组JSON描述的缩放、移动和旋转等操作转换成对应的变化矩阵
    var vec = [p2[0]-p1[0], p2[1]-p1[1], p2[2]-p1[2]],
        dist = ht.Default.getDistance(p1, p2);//获取两点之间距离,或向量长度
    return ht.Default.createMatrix({
        s3: [width, dist, width],
	r3: [Math.PI/2 - Math.asin(vec[1]/dist), Math.atan2(vec[0], vec[2]), 0],
	rotationMode: 'xyz',
	t3: [(p1[0]+p2[0])/2, (p1[1]+p2[1])/2, (p1[2]+p2[2])/2]
    });
};

基础配件全部定义完毕,接着就是将“shape3d”属性设置为自定义的 3D 模型“custom” ,并将“layoutable”属性设置为“false”阻止图元参与布局,并将点之间的连线通过edge.a('pipeline', node)重新刷新,并添加进数据模型 dataModel 中:

 

 

var createEdge = function(dm, node1, node2) {//创建‘custom’模型的edge
    var node = new ht.Node();
    node.s({
        'shape3d': 'custom',
        'shape3d.color': '#ECE0D4',
        'layoutable': false
    });
    dm.add(node);

    var edge = new ht.Edge(node1, node2);
    edge.a('pipeline', node);
    edge.s('edge.color', 'rgba(0, 0, 0, 0)');
    dm.add(edge);
    return edge;
};

我们还可以在工业上用 HeatMap 热图上做文章,效果依旧很炫,具体地址http://hightopo.com/guide/guide/plugin/forcelayout/examples/example_heatmap3d.html


这里我们还是专注地继续完成这个例子。

界面上的图形全部绘制完毕,剩下的就只有 form 表单,首先将 form 表单添加进 HTML 页面,用的是 HT 封装的 ht.widget.FormPane 函数:

 

var formPane = new ht.widget.FormPane();
formPane.setWidth(230);
formPane.setHeight(125);
formPane.addToDOM();

记住,form 表单要设置宽高,不然不显示。

 

form 表单添加行是通过 addRow 函数,我们重点来说一下下面的几行,Color、Range 和 Intensity,这三个名字主要是用来控制“头灯”的。在 HT 中直接通过 setHeadlightColor/setHeadlightRange/setHeadlightIntensity 三个函数来控制“头灯”的颜色、范围以及灯的强度,onValueChanged 属性,顾名思义属性值改变之后触发的事件:

 

['Color', 'Range', 'Intensity'].forEach(function(name) {
    var obj = { id: name },
    func = function(oV, nV) {
        g3d['setHeadlight' + name](nV);// === g3d.setHeadlightColor(nV)/g3d.setHeadlightRange(nV)/g3d.setHeadlightIntensity(nV)
    };
    if (name === 'Color')
        obj.colorPicker = {//ht.widget.ColorPicker为颜色选择框 
	    instant: true,
	    value: g3d['getHeadlight' + name](),// === g3d.getHeadlightColor()
	    onValueChanged: func
	};
	else 
	    obj.slider = {//滑动条
	        min: 0,
		max: name === 'Range' ? 20000 : 3,
		step: 0.1,
		value: g3d['getHeadlight' + name](),
		onValueChanged: func
	    };
    formPane.addRow([ name, obj ], [ 70, 0.1 ]);
});

slider 和 colorPicker 都是 HT 自定义的滑动条和颜色选择器,详情请参考 HT for Web 表单手册

 

如果还有不懂的请咨询我,或者直接上 HT for Web 官网查阅手册。

 

分享到:
评论

相关推荐

    基于HTML5 WebGL 3D樱花飘落动画

    基于HTML5 WebGL 3D樱花飘落动画 1.网页作品简介 :HTML期末大学生网页设计作业 A+水平 ,喜欢的可以下载,文章页支持手机PC响应式布局。 2.网页作品编辑:作品下载后可使用任意HTML编辑软件(如:DW、HBuilder、...

    基于WebGL实现3D图片特效

    这是一款基于WebGL实现3D图片特效。该特效利用WebGL和一张特定的黑白图片,制作出在鼠标移动时的3D图片特效。

    HTML5 WebGL 3D 仓储管理系统

    基于HTML5 WebGL 3D仓储系统Demo,使用范围还很广!ht.js评论留言邮箱地址,看到留言会发送至邮箱

    基于WebGL实现的3D曲面图表组件

    基于 WebGL 实现的 3D 曲面图表组件

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

    HTML5+CSS+WEBGL网页3D游戏开发,经典教程

    HTML5+WebGL实现可拖拽的3D透明杯子效果源码.zip

    HTML5+WebGL实现可拖拽的3D透明杯子效果源码.zip

    基于HTML5 WebGL的3D机房的示例

    用 WebGL 渲染的 3D 机房现在也不是什么新鲜事儿了,这篇文章的主要目的是说明一下,3D 机房中的 eye 和 center 的问题,刚好在项目中用上了,好生思考了一番,最终觉得这个例子最符合我的要求,就拿来作为记录。...

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

    HTML5+WebGL 3D雪花飘落动画特效,比较逼真的一款下雪网页背景动画效果。

    Programming 3D Applications with HTML5 and WebGL

    Create engaging 3D applications for the Web with HTML5 and the emerging web graphics standard, WebGL. With this book, you'll learn hands-on how to take your website's production value to a new level ...

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

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

    地图Web3D可视化-WebGL、Three.js

    有前端基础,想基于Web实现地图数据的3D可视化效果 课程目录: 章节1、学前内容 章节2、Three.js解析渲染GeoJSON数据 章节3、行政区射线拾取、信息标签和热点 章节4、行政区数据可视化 章节5、密集位置数据可视化 ...

    基于HTML5WebGL的3D仓储管理系统

    仓储管理系统(WMS)是一个实时的计算机软件系统,它能够按照运作的业务规则和运算法则,对信息、资源、行为、存货和分销运作进行更完美地管理,使其最大化满足有效产出和精确性的要求。从财务软件、进销存软件CIMS...

    网页动画素材 WebGL基于canvas画布绘制3D噪音线条酷炫动画特效。(抖音资料)

    网页动画素材 WebGL基于canvas画布绘制3D噪音线条酷炫动画特效。(抖音资料)网页动画素材 WebGL基于canvas画布绘制3D噪音线条酷炫动画特效。(抖音资料)网页动画素材 WebGL基于canvas画布绘制3D噪音线条酷炫动画...

    基于HTML5的WebGL3D档案馆可视化管理系统

    为企事业单位的档案现代化管理,提供完整的解决方案,档案管理系统既可以自成系统,为用户提供完整的档案管理和网络查询功能,也可以与本单位的OA办公自动化和DPM设计过程管理,或者与MIS信息管理系统相结合,形成...

    基于 HTML5 WebGL 的 3D 仓储管理系统

    仓储系统!仓库管理可以说即不省力也不省事,而且使用范围还很广,数学中经常使用仓储系统来计算市场需求,物流中的动力学建模等等,所以仓储系统必不可少,在这个时间就是金钱的时代,能省时就能带来非常大的效益,...

    基于WEBGL的3D试衣系统的设计与实现

    基于WEBGL的3D试衣系统的实现。使用了HTML5、JavaScript以及Three.js库。通过多种接口,使数据在不同系统之间流畅传递与转换,实现面向真人的三维虚拟试衣的目标

    基于HTML5 WebGL的3D星云动画特效

    今天我们给大家分享一个基于HTML5 Canvas的星云动画特效,整个画面模拟了一个星系的外观,比如模拟了太阳系,有很多小行星围绕着星系中心旋转,星系中心也显得格外亮丽。这些小星点都是在Canvas上绘制而成,同时我们...

    SuperMap-webgl3D vue示例demo

    超图三维地球开发代码,vscode直接运行,感兴趣下载

Global site tag (gtag.js) - Google Analytics