Threejs使用Shapes实现不规则几何体,自定义绘图

简介: Threejs使用Shapes实现不规则几何体,自定义绘图

1,介绍


该示例使用的是 r95版本Three.js库。

主要实现功能:使用Shapes实现不同规则几何体。效果图如下:



2,实现说明


形状(Shape)使用路径以及可选的孔洞来定义一个二维形状平面。 它可以和ExtrudeGeometry、ShapeGeometry一起使用,获取点,或者获取三角面;Shape – three.js中文文档 (yanhuangxueyuan.com)


three.js examples案例库 (yanhuangxueyuan.com)

这里延伸一下,假如有个需求需要在墙上挖孔或者两面墙合并在一起应该怎么做呢?因为Three.js没有提供用于几何体运算的构造函数,需要借助ThreeBSP.js库实现。


有兴趣可以查看这位博主关于ThreeBSP.js扩展库的介绍:ThreeBSP布尔运算_three.js教程_郭隆邦技术博客 (yanhuangxueyuan.com)


帽子形状,曲线SplineCurve查看文档SplineCurve – three.js中文文档 (yanhuangxueyuan.com)

// 根据集合点,创建一条平滑的二维曲线
let curve = new THREE.SplineCurve([
  new THREE.Vector2(-20, 80),
  new THREE.Vector2(-20, 150),
  new THREE.Vector2(-100, 150),
  new THREE.Vector2(-100, 80),
]);
// 样条曲线均匀分割100分,返回51个顶点坐标
let points = curve.getPoints(10);
let randomShape = new THREE.Shape(points);
let randomMesh = new THREE.Mesh(new THREE.ShapeGeometry(randomShape), new THREE.MeshPhongMaterial({
  side: THREE.DoubleSide,
  color: 0xafc0ca
}));
scene.add(randomMesh);
// 返回多边形均匀分布点
let spacedPoints = randomShape.getSpacedPoints(50);
// 返回多边形顶点
// let spacedPoints = randomShape.getPoints();
let geometrySpacedPoints = new THREE.BufferGeometry().setFromPoints(spacedPoints);
let particles = new THREE.Points(geometrySpacedPoints, new THREE.PointsMaterial({
  color: "#ff5500",
  size: 4
}));
particles.position.z = 25;
scene.add(particles);


五边形状,构造函数Shape查看文档Shape – three.js中文文档 (yanhuangxueyuan.com)


let splinepts = [];
splinepts.push(new THREE.Vector2(170, 100));
splinepts.push(new THREE.Vector2(150, 150));
splinepts.push(new THREE.Vector2(80, 170));
splinepts.push(new THREE.Vector2(50, 100));
splinepts.push(new THREE.Vector2(90, 120));
let splineShape = new THREE.Shape(splinepts);
let geometry = new THREE.ShapeGeometry(splineShape);
let mesh = new THREE.Mesh(geometry, new THREE.MeshPhongMaterial({
  side: THREE.DoubleSide,
  color: 0xafc0ca
}));
scene.add(mesh);


挖孔圆,方法absarc查看文档Path – three.js中文文档 (yanhuangxueyuan.com)

let arcShape = new THREE.Shape();
arcShape.absarc(-50, -30, 40, 0, Math.PI * 2, false);
let holePath = new THREE.Path();
holePath.absarc(-50, -30, 10, 0, Math.PI * 2, true);
arcShape.holes.push(holePath);
let arcMesh = new THREE.Mesh(new THREE.ShapeGeometry(arcShape), new THREE.MeshPhongMaterial({
  side: THREE.DoubleSide,
  color: 0xafc0ca
}));
scene.add(arcMesh);


心形状,方法bezierCurveTo查看文档Path – three.js中文文档 (yanhuangxueyuan.com)

var x = 120,
  y = -90;
let heartShape = new THREE.Shape();
heartShape.moveTo(x + 25, y + 25)
heartShape.bezierCurveTo(x + 25, y + 25, x + 20, y, x, y)
heartShape.bezierCurveTo(x - 30, y, x - 30, y + 35, x - 30, y + 35)
heartShape.bezierCurveTo(x - 30, y + 55, x - 10, y + 77, x + 25, y + 95)
heartShape.bezierCurveTo(x + 60, y + 77, x + 80, y + 55, x + 80, y + 35)
heartShape.bezierCurveTo(x + 80, y + 35, x + 80, y, x + 50, y)
heartShape.bezierCurveTo(x + 35, y, x + 25, y + 25, x + 25, y + 25);
let heartMesh = new THREE.Mesh(new THREE.ShapeGeometry(heartShape), new THREE.MeshPhongMaterial({
  side: THREE.DoubleSide,
  color: 0xafc0ca
}));
scene.add(heartMesh);


绘制地图,首先获取geojson地图数据,然后使用Shape绘制地图形状,可参考如下文章


threejs快速生成地图的方式以及代码_搬砖小田的博客-CSDN博客_threejs 地图

ThreeJS读取GeoJson文件,绘制地图板 - 昜木辰deブログ - 博客园 (cnblogs.com)

目录
相关文章
|
2月前
ThreeJs绘制圆柱体
这篇文章介绍了在Three.js中绘制圆柱体的方法,包括创建圆柱体几何体、设置材质以及将其正确放置在三维场景中的技巧。
57 0
ThreeJs绘制圆柱体
|
2月前
Threejs绘制方形管道
这篇文章讲解了如何在Three.js中创建和渲染方形管道,包括建立几何体、应用材质以及进行场景中的定位和渲染等步骤。
49 0
Threejs绘制方形管道
|
5月前
|
机器学习/深度学习 前端开发 算法
canvas系列教程03 —— 线的样式、绘制文本、操作图片(图片的渲染、缩放、裁剪、切割、平铺、特效)、变换元素(平移、缩放、旋转)(二)
canvas系列教程03 —— 线的样式、绘制文本、操作图片(图片的渲染、缩放、裁剪、切割、平铺、特效)、变换元素(平移、缩放、旋转)(二)
101 0
|
5月前
|
存储 前端开发 JavaScript
canvas系列教程03 —— 线的样式、绘制文本、操作图片(图片的渲染、缩放、裁剪、切割、平铺、特效)、变换元素(平移、缩放、旋转)(一)
canvas系列教程03 —— 线的样式、绘制文本、操作图片(图片的渲染、缩放、裁剪、切割、平铺、特效)、变换元素(平移、缩放、旋转)(一)
525 0
|
前端开发
用CSS绘制最常见的40种形状和图形(一)
用CSS绘制最常见的40种形状和图形(一)
91 0
|
7月前
|
移动开发 前端开发 JavaScript
html5 Canvas 绘制基本图形 从直线图形到使用路径 - 直线、矩形、路径、多边形、复杂组合图形
html5 Canvas 绘制基本图形 从直线图形到使用路径 - 直线、矩形、路径、多边形、复杂组合图形
231 0
html5 Canvas 绘制基本图形 从直线图形到使用路径 - 直线、矩形、路径、多边形、复杂组合图形
|
7月前
|
监控 API 计算机视觉
OpenCV这么简单为啥不学——1.4、基础标识绘制(绘制线line函数、rectangle函数绘制四边形、circle函数绘制圆形、putText函数绘制文字、putText绘制中文文字)
OpenCV这么简单为啥不学——1.4、基础标识绘制(绘制线line函数、rectangle函数绘制四边形、circle函数绘制圆形、putText函数绘制文字、putText绘制中文文字)
76 0
|
7月前
|
计算机视觉
OpenCV(十三):图像中绘制直线、圆形、椭圆形、矩形、多边形和文字
OpenCV(十三):图像中绘制直线、圆形、椭圆形、矩形、多边形和文字
97 0
|
前端开发
用CSS绘制最常见的40种形状和图形(二)
用CSS绘制最常见的40种形状和图形(二)
107 0
|
定位技术
Cesium系列:加载不规则形状出图
Cesium加载不规则形状出图
487 0

热门文章

最新文章