**

一、学习资料

**
1.入门教程:
http://ourjs.com/wiki/view/three
数字孪生技术底层实现技术框架之一。
2.一些例子
分享数百个 HT 工业互联网 2D 3D 可视化应用案例之 2019 篇
3.数百个 HTML5 例子学习 HT 图形组件

掌握 HT 基础:
1、先入门手册 http://www.hightopo.com/guide/guide/core/beginners/ht-beginners-guide.html
2、看数据模型 http://www.hightopo.com/guide/guide/core/datamodel/ht-datamodel-guide.html
3、阅矢量手册 http://www.hightopo.com/guide/guide/core/vector/ht-vector-guide.html
4、读数据绑定 http://www.hightopo.com/guide/guide/core/databinding/ht-databinding-guide.html
5、序列化机制 hightopo.com/guide/guide/core/serialization/ht-serialization-guide.html

如有三维需求:
1、入门手册 http://www.hightopo.com/guide/guide/core/3d/ht-3d-guide.html
2、建模手册 http://www.hightopo.com/guide/guide/plugin/modeling/ht-modeling-guide.html
3、OBJ 导入 http://www.hightopo.com/guide/guide/plugin/obj/ht-obj-guide.html

**

!!!!主要学习:

Three.js零基础入门教程(郭隆邦)

**:Three.js零基础入门教程

WebGL零基础入门教程(郭隆邦)

:http://www.yanhuangxueyuan.com/WebGL/

three.js官网

:https://threejs.org/

学习过程中引用的three.js路径:

<!--引入three.js三维引擎--><!--    <script src="http://www.yanhuangxueyuan.com/3D/example/three.js"></script>--><script src="http://www.yanhuangxueyuan.com/versions/threejsR92/build/three.js"></script><script src="http://www.yanhuangxueyuan.com/3D/example/three.min.js"></script><!--鼠标操作三维场景--><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/controls/OrbitControls.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/STLLoader.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/OBJLoader.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/MTLLoader.js"></script>

二、跟着官网学习过程中需要自己完善的案例代码:

1、three.js-纹理动画

动画效果:

纹理动画

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><title>8.4纹理对象-案例-纹理动画</title><style>body {margin: 0;overflow: hidden;/* 隐藏body窗口区域滚动条 */}</style><!--引入three.js三维引擎--><!--    <script src="http://www.yanhuangxueyuan.com/3D/example/three.js"></script>--><script src="http://www.yanhuangxueyuan.com/versions/threejsR92/build/three.js"></script><script src="http://www.yanhuangxueyuan.com/3D/example/three.min.js"></script><!--鼠标操作三维场景--><!--    <script type="text/javascript" th:src="@{/static/js/OrbitControls.js}"></script>--><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/controls/OrbitControls.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/STLLoader.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/OBJLoader.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/MTLLoader.js"></script></head>
<body><script>var scene=new THREE.Scene();//纹理动画//创建盒子模型var geometry1=new THREE.BoxGeometry(40,60,40);var geometry2=geometry1.clone();geometry1.translate(-80,-25,0);//模型1沿x轴移动-80geometry2.translate(80,-25,0);//模型2沿x轴移动80/*** 创建一个设置重复纹理的管道*/var curve = new THREE.CatmullRomCurve3([new THREE.Vector3(-80, -40, 0),new THREE.Vector3(-70, 40, 0),new THREE.Vector3(70, 40, 0),new THREE.Vector3(80, -40, 0)]);//创建管道模型对象var tubeGeometry = new THREE.TubeGeometry(curve, 200, 2, 10, false);//curve:扫描路径;200:路径方向细分数;1:管道圆弧细分数;false:不闭合var textureLoader = new THREE.TextureLoader();var texture = textureLoader.load("../picture/orange.jpg");//创建纹理加载器对象加载图片// 设置阵列模式为 RepeatWrappingtexture.wrapS = THREE.RepeatWrapping //wrapS:纹理贴图在水平方向上将如何进行包裹texture.wrapT=THREE.RepeatWrapping  //wrapT :纹理贴图在垂直方向上将如何包裹// 设置x方向的偏移(沿着管道路径方向),y方向默认1//等价texture.repeat= new THREE.Vector2(20,1)texture.repeat.x = 20;//管道的材质var tubeMaterial = new THREE.MeshPhongMaterial({map: texture,transparent: true,});//盒子的材质var material=new THREE.MeshLambertMaterial({color:0xff00ff,side:THREE.DoubleSide})var mesh1=new THREE.Mesh(geometry1,material);var mesh2=new THREE.Mesh(geometry2,material);var mesh3=new THREE.Mesh(tubeGeometry,tubeMaterial);scene.add(mesh1,mesh2,mesh3);//光源var point = new THREE.PointLight(0xffffff);point.position.set(400, 200, 300); //点光源位置scene.add(point); //点光源添加到场景中var point1 = new THREE.PointLight(0xffffff);point1.position.set(-400, -200, -300); //点光源位置scene.add(point1); //点光源添加到场景中//环境光var ambient = new THREE.AmbientLight(0x777777);scene.add(ambient);//相机var width = window.innerWidth; //窗口宽度var height = window.innerHeight; //窗口高度var k = width / height; //窗口宽高比var s = 200; //三维场景显示范围控制系数,系数越大,显示的范围越大//创建相机对象var camera = new THREE.OrthographicCamera(-s * k, s * k, s, -s, 1, 1000);camera.position.set(200, 200, 200); //设置相机位置camera.lookAt(scene.position); //设置相机方向(指向的场景对象)//创建渲染器对象var renderer = new THREE.WebGLRenderer();renderer.setSize(width, height);//设置渲染区域尺寸renderer.setClearColor(0x000000, 1); //设置背景颜色document.body.appendChild(renderer.domElement); //body元素中插入canvas对象// renderer.render(scene,camera);//执行渲染操作//鼠标操作function render() {renderer.render(scene,camera);//执行渲染操作// mesh.rotateY(0.01);//每次绕y轴旋转0.01弧度requestAnimationFrame(render);//请求再次执行渲染函数render// 使用加减法可以设置不同的运动方向// 设置纹理偏移texture.offset.x -= 0.05}render();var controls = new THREE.OrbitControls(camera,renderer.domElement);//创建控件对象// 辅助坐标系  参数250表示坐标系大小,可以根据场景大小去设置var axisHelper = new THREE.AxisHelper(1000);scene.add(axisHelper);</script>
</body>
</html>

其中引用到的贴图是自己用ppt粗略弄的图片:

目录位置:

2-Canvas画布加载图片

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><title>8.5canvas画布加载图片</title><style>body {margin: 0;overflow: hidden;/* 隐藏body窗口区域滚动条 */}</style><!--引入three.js三维引擎--><!--    <script src="http://www.yanhuangxueyuan.com/3D/example/three.js"></script>--><script src="http://www.yanhuangxueyuan.com/versions/threejsR92/build/three.js"></script><script src="http://www.yanhuangxueyuan.com/3D/example/three.min.js"></script><!--鼠标操作三维场景--><!--    <script type="text/javascript" th:src="@{/static/js/OrbitControls.js}"></script>--><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/controls/OrbitControls.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/STLLoader.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/OBJLoader.js"></script><script src="http://www.yanhuangxueyuan.com/threejs/examples/js/loaders/MTLLoader.js"></script></head>
<body><script>var texture;var scene=new THREE.Scene();var canvas=document.createElement("canvas");//创建一个canvas对象canvas.width=200;canvas.height=200;var ctx=canvas.getContext('2d');var Image=new Image();Image.src="../picture/earth.png";Image.onload=function(){ctx.drawImage(Image,0,0,200,200);// var bg=ctx.createPattern(Image,"no-repeat");// canvas画布对象作为CanvasTexture的参数重建一个纹理对象// canvas画布可以理解为一张图片texture = new THREE.CanvasTexture(canvas);texture.needsUpdate = true;// 注意图片加载完成执行canvas相关方法后,要更新一下纹理//打印纹理对象的image属性// console.log(texture.image);//矩形平面var geometry = new THREE.PlaneGeometry(100, 100);var material = new THREE.MeshPhongMaterial({map: texture, // 设置纹理贴图side:THREE.DoubleSide});// 创建一个矩形平面网模型,Canvas画布作为矩形网格模型的纹理贴图var mesh = new THREE.Mesh(geometry, material);scene.add(mesh);}//光源var point = new THREE.PointLight(0xffffff);point.position.set(400, 200, 300); //点光源位置scene.add(point); //点光源添加到场景中var point1 = new THREE.PointLight(0xffffff);point1.position.set(-400, -200, -300); //点光源位置scene.add(point1); //点光源添加到场景中//环境光var ambient = new THREE.AmbientLight(0x777777);scene.add(ambient);//相机var width = window.innerWidth; //窗口宽度var height = window.innerHeight; //窗口高度var k = width / height; //窗口宽高比var s = 200; //三维场景显示范围控制系数,系数越大,显示的范围越大//创建相机对象var camera = new THREE.OrthographicCamera(-s * k, s * k, s, -s, 1, 1000);camera.position.set(200, 200, 200); //设置相机位置camera.lookAt(scene.position); //设置相机方向(指向的场景对象)//创建渲染器对象var renderer = new THREE.WebGLRenderer();renderer.setSize(width, height);//设置渲染区域尺寸renderer.setClearColor(0x000000, 1); //设置背景颜色document.body.appendChild(renderer.domElement); //body元素中插入canvas对象// renderer.render(scene,camera);//执行渲染操作//鼠标操作function render() {renderer.render(scene,camera);//执行渲染操作// mesh.rotateY(0.01);//每次绕y轴旋转0.01弧度requestAnimationFrame(render);//请求再次执行渲染函数render}// 辅助坐标系  参数250表示坐标系大小,可以根据场景大小去设置var axisHelper = new THREE.AxisHelper(1000);scene.add(axisHelper);var controls = new THREE.OrbitControls(camera,renderer.domElement);//创建控件对象render();</script>
</body>
</html>

三、学习过程遇到的问题总结:

1.控制台报错 geometry.setFromPoints is not a function


three.js版本:http://www.yanhuangxueyuan.com/3D/example/three.js

查找百度等资料,应该是这个版本没有这个方法(不确定)。

2.The AudioContext was not allowed to start. It must be resumed (or created) after a user gesture on the page.

网上的解决办法:
地址栏输入:edge://flags/#autoplay-policy
将Show block option in autoplay settings下拉选项设为Enabled

不过设置了之后音频还是无法自动播放…

【学习记录】Three.js相关推荐

  1. 微信小程序学习记录2(js中数组和对象)

    1.数组 1.数组的创建: 推荐方式: var array =[] 2.js的数组可以装不同类型的变量 例如: array=['张三',123,aabb] 3.利用下标索引 4.数组的一些方法: .l ...

  2. vscode中装js解释器_h5学习记录(1)--vscode配置js开发环境

    文笔不是很好,第一次写东西,主要为了记录h5的学习过程.今天记录的是vscode配置js开发环境. 什么是VSCode Visual Studio Code (简称VS Code/VSC) 是一款于2 ...

  3. 小程序js+django+服务器后台搭建流程总结(第五周学习记录)

    学习记录 这周的工作依然是做一些服务器的调试工作,但是为了方便这周末的展示,我打算把这段时间的所有后台搭建工作和对所有服务器的操作流程做一个系统的总结和归纳,方便学习记录与交流 一.微信小程序js部分 ...

  4. ASP.NETCore学习记录(一)

    ASP.NETCore学习记录(一) asp.net core介绍  Startup.cs  ConfigureServices  Configure  0. ASP.NETCore 介绍 ASP.N ...

  5. Echarts学习记录——如何去掉网格线及网格区域颜色

    关键属性 splitLine和splitArea,可以设置相关的属性 示例代码 <!DOCTYPE html> <html lang="en"> <h ...

  6. 在浏览器中进行深度学习:TensorFlow.js (十二)异常检测算法

    2019独角兽企业重金招聘Python工程师标准>>> 异常检测是机器学习领域常见的应用场景,例如金融领域里的信用卡欺诈,企业安全领域里的非法入侵,IT运维里预测设备的维护时间点等. ...

  7. gradle 上传jar包_Gradle学习记录014 关于依赖的声明

    详细学习Gradle构建的依赖声明.该学习记录基于Gradle官方网站资料.本篇参考链接如下: https://docs.gradle.org/current/userguide/declaring_ ...

  8. Elasticseach 从零开始学习记录(二) - Head插件

    安装Head插件的原因: 可以提供友好的web界面,还可以实现基本信息的查看,rest请求的模拟,以及数据的基本检索. 1. 检查服务器是否已经安装node.js 如未安装,自行百度安装node 2. ...

  9. react基础学习记录一

    react 学习记录 自己学习,记录便于后面回顾 基础知识点的记忆: state与props state是组件自己的数据,而props是父组件通过属性赋值方式将其传送给组件:这样达到了,父子组件数据的 ...

最新文章

  1. 3dsmax biped 骨骼的创建和修改
  2. 【C++ 语言】 C 与 C++ 兼容 ( extern C )
  3. Person Re-Identification by Multi-Channel Parts-Based CNN with Improved Triplet Loss Function
  4. JAVA Web day02--- Android小白的第二天学习笔记
  5. 牛客网_PAT乙级_1019. 数字黑洞 (20)
  6. 同事都说有SQL注入风险,我非说没有
  7. 石油勘探是属于计算机应用中的,计算机在石油勘探开发中的应用论文
  8. 安卓系统上的远程 JS 调试 Remote JavaScript Debugging on Android
  9. 【每日SQL打卡】​​​​​​​​​​​​​​​DAY 23丨向CEO汇报工作的人【难度中等】​
  10. 安装fastDFS的依赖包fdfs_client报错解决方法
  11. 计算机学院三下乡,重庆理工大学计算机学院”三下乡“教师情牵故乡
  12. 小米8 Goole Play 商店登录问题 | 正确爬山方式
  13. 【WA】TBC功能WA串更新日志(更新至2022.06.02)
  14. Java时间 之 Instant
  15. 意大利奢侈品牌-Kiton 华丽进驻北京新光天地-时尚生活-泛高尔夫网
  16. iP138查询网,ip数据库
  17. python条形图参数_更改水平条形图大小matplotlib
  18. VS2022-更换背景壁纸
  19. 用matlab解决多重共线性问题,几种关于多重共线性回归问题的解决方法
  20. C语言——分支语句和循环语句(分支语句)

热门文章

  1. 论文《Embedding-based Retrieval in Facebook Search》
  2. Oracle merge into语法修改为MySQL语法解决方案
  3. linux下wget下载速度慢的解决方法wget => aria2
  4. 链表相关操作:创建链表、遍历链表、求链表长度、链表中删除一个节点、链表中插入一个节点、反转单链表...
  5. Revit 求质心(重心点)
  6. 【路径规划】基于节约算法实现CVRP问题
  7. stdafx.h的作用体会
  8. 取下zyduino uno上面的ATMEGA328芯片
  9. U-Boot 移植初探
  10. pytorch使用心得