rle-mesh

0.0.9 • Public • Published

rle-mesh

Mesh and surface extraction routines for narrow band level sets. It is part of the rle family of modules.

Installation

Via npm:

npm install rle-mesh

Example

Here is how you can create a mesh for a solid object:

var volume = require("rle-sample").solid.dense([-6,-6,-6], [7,7,7], function(x) {
  return Math.sqrt(x[0]*x[0]+x[1]*x[1]+x[2]*x[2]) - 5.0;
});
var mesh = require("rle-mesh")(volume);

This creates a mesh that looks like this:

You can also view the demo in your browser here

rle-mesh can also handle multiphase level sets too. Here is a more complicated example:

function sphere_dist(x) {
  return Math.sqrt(x[0]*x[0]+x[1]*x[1]+x[2]*x[2]) - 5.0;
}
var volume = require("rle-sample").dense([-6,-6,-6], [7,7,7], function(x) {
  if(sphere_dist(x) < 0) {
    if(x[0] < 0) {
      return 1;
    }
    return 2;
  }
  return 0;
}, sphere_dist);
var mesh = require("rle-mesh")(volume);

This creates a sphere with two distinct phases:

Again, you can also look at the result in 3D using your web browser.

require("rle-mesh")(volume[, lo, hi, solid_func])

The main meshing method takes the following parameters:

  • volume: An RLE volume
  • lo: (Optional) Lower bounds on the volume to extract
  • hi: (Optional) Upper bounds on the volume to extract
  • solid_func: (Optional) A predicate that determines whether or not to display a voxel phase

Returns: An object with the following properties

  • positions: An array of length 3 arrays representing the position of each vertex.
  • faces: An array of length 3 arrays representing the indexed faces of the mesh
  • phases: An array of length 2 arrays the same length as faces that has the phase on the front and back of each face.

Credits

(c) 2013 Mikola Lysenko

Readme

Keywords

none

Package Sidebar

Install

npm i rle-mesh

Weekly Downloads

7

Version

0.0.9

License

BSD

Last publish

Collaborators

  • mikolalysenko