geometry-processing-js 用于Web上几何处理的快速通用框架

网友投稿 591 2022-11-01 07:28:05

geometry-processing-js 用于Web上几何处理的快速通用框架

geometry-processing-js

geometry-processing-js is a fast and flexible framework for 3D geometry processing on the web! Easy integration with HTML/WebGL makes it particularly suitable for things like mobile apps, online demos, and course content. For many tasks, performance comes within striking distance of native (C++) code. Plus, since the framework is pure JavaScript, no compilation or installation is necessary: just copy the files and run from any web browser, on any platform (including mobile). Moreover, geometry processing algorithms can be edited in the browser (using for instance the JavaScript Console in Chrome). So open up one of the demos and start editing! geometry-processing-js is developed by and maintained by the Geometry Collective at Carnegie Mellon University.

At a high level, the framework is divided into three parts - a flexible a halfedge mesh data structure, an optimized linear algebra package (based on Eigen), and code for various geometry processing algorithms. Each algorithm comes with its own viewer for rendering.

Detailed documentation and unit tests for each of these parts can be found in the docs and tests directories of this repository.

We're just getting rolling here, so stay tuned for more! :-)

Code Snippet

Since geometry-processing-js already implements many of the fundamental operations needed for geometry processing, it's easy to get up and running very quickly. Here's a short snippet showing how to solve a Poisson equation on a mesh loaded by the GUI, which uses built-in routines for constructing the Laplace and mass matrices:

// assign an index to each vertex of the meshlet vertexIndex = indexElements(geometry.mesh.vertices);// build cotan-Laplace and mass matriceslet A = geometry.laplaceMatrix(vertexIndex);let M = geometry.massMatrix(vertexIndex);let rhs = M.timesDense(rho);// solve Poisson equation with a given right-hand side rhslet llt = A.chol();let phi = llt.solvePositiveDefinite(rhs);

Getting started

Clone the repository and change into the projects directory

git clone https://github.com/geometrycollective/geometry-processing-js.gitcd geometry-processing-js/projects

Open the index.html file in any of the sub directories in a browser of your choice (Chrome and Firefox usually provide better rendering performance than Safari).

Dependencies (all included)

Linear Algebra - A wrapper around the C++ library Eigen compiled to asm.js with emscripten. Future updates will compile the more optimized sparse matrix library Suitesparse to asm.js. (Note that this wrapper can also be used for other, non-geometric projects which seek to use Eigen on the web; you can find the standalone release here) Rendering - three.js Unit Tests - Mocha and Chai

About Javascript

The implementation of geometry-processing-js attempts to minimize the use of obscure Javascript language features. It should not be too difficult for anyone with experience in a dynamic language like Python or familiar with the principles of Object Oriented Programming to get a handle on Javascript syntax by reading through some of the code in this framework. The documentation contains examples specific to this framework which will also be of help. For a more formal introduction to Javascript, checkout this really nice tutorial.

Building the Documentation

See guide here.

Authors

Rohan Sawhney

Email: rohansawhney@cs.cmu.edu

Mark Gillespie

Email: mgillesp@cs.cmu.edu

Design inspiration: Nick Sharp, Keenan Crane

License

MIT

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Kaspresso是一个基于Espresso、UIAutomator和Kakao的强大UI测试框架
下一篇:Spring Security过滤器链体系的实例详解
相关文章