Three.js - 使用 ThreeBSP 对模型进行布尔运算

ThreeBSP.jsthree.js 的一个扩展库,可以实现对模型的数学布尔运算,实际上就是个个点的重新组合和拆分,来重新生成 几何体对象和网格模型。
本实示例浏览地址:https://ithanmang.gitee.io/threejs/home/201806/20180626/01-threeBSPdemo.html

ThreeBSP构造函数
function ThreeBSP(treeIsh, matrix) {
   
  this.matrix = matrix;
  // 求两个几何体的重合部分
  this.intersect = __bind(this.intersect, this);
  // 两个几何体联合成的部分
  this.union = __bind(this.union, this);
  // 一个几何体中移除另一个几何的剩余部分
  this.subtract = __bind(this.subtract, this);
  // 将BSP对象转换成几何对象
  this.toGeometry = __bind(this.toGeometry, this);
  // 将BSP对象转换成网格模型
  this.toMesh = __bind(this.toMesh, this);
  // 将BSP对象
  this.toTree = __bind(this.toTree, this);
  if (this.matrix == null) {
   
    this.matrix = new THREE.Matrix4();
  }
  this.tree = this.toTree(treeIsh);
}
常用方法
方法 描述
intersect(交集) 使用这个方法可以从获取两个几何体的共同部分
union (并集) 使用这个方法、可以把两个几何体联合在一起
subtract (差集) 使用这个方法可以从一个几何体中移除另一个几何体与这个几何体的重复部分
示例
创建两个几何体

圆柱和立方体

// 创建几何体
var cylinderGeometry = new THREE.CylinderGeometry(100,100,20,100,20);
var boxGeometry = new THREE.BoxGeometry(100,100,100,50,50);

// 创建材质
var materials = new THREE.MeshNormalMaterial({
   wireframe:true});

// 创建Mesh
var cylinder = new THREE.Mesh(cylinderGeometry,materials);
var box = new THREE.Mesh(boxGeometry, materials);

并且这两个模型交织在一起
这里写图片描述

将这两个Mesh对象转换成 BSP 对象
// 将网格模型对象包装成可以进行buer运算的对象(BSP对象)
var cylinderBSP = new ThreeBSP(cylinder);
var boxBSP = new ThreeBSP(</
  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值