2.3.1 • Published 4 months ago

physx-js-webidl v2.3.1

Weekly downloads
53
License
MIT License
Repository
github
Last release
4 months ago

physx-js-webidl

Javascript/WASM bindings for Nvidia PhysX 5.3.1.

Looking for pre-built binaries / build instructions? See below

Library coverage

The bindings include most major parts of the PhysX SDK (excluding CUDA stuff, which is not possible with WASM):

  • Basics
    • Static and dynamic actors
    • All geometry types (box, capsule, sphere, plane, convex mesh, triangle mesh and height field)
  • All joint types (revolute, spherical, prismatic, fixed, distance and D6)
  • Articulations
  • Vehicles
  • Character controllers
  • Scene serialization

Getting started

There is a basic hello world example: 10 boxes falling on the ground (drawn as wireframe on a plain canvas).

Documentation

The API is very close to the original PhysX C++ API, so you can simply use the official PhysX API documentation

However, in order to make the bindings work with emscripten a few additional wrappers are needed here and there. So it might make sense to also take a look into the PhysXJs.idl interface definiton file.

Update as of v2.2.0: Thanks to Shannon Poole, PhysX enums can now be accessed by their qualified names (e.g. PhysX.PxIDENTITYEnum.PxIdentity, see also the hello world demo mentioned above).

Demos

I use this library in my engine kool and have a few demos in place:

  • Vehicle: Basic vehicle demo with a few obstacles.
  • Character: 3rd person character demo on an island.
  • Ragdolls: A simple ragdoll demo.
  • Joints: A chain running over two gears.
  • Collision: The obligatory box (and other shapes) collision physics demo.

However, the demos are written in kotlin, not javascript.

Pre-built binaries

This library is published as a npm package:

npm i physx-js-webidl

Alternatively you can grab the pre-built binaries (.wasm + support .js) from the latest Release.

Building

In order to build the library you need a recent version of the emscripten SDK - I'm using version 3.1.51. Alternatively, you can use docker as described below. After successful build, the binaries (.wasm + support .js) will appear in the dist directory.

# Clone this repo
git clone https://github.com/fabmax/physx-js-webidl

# Enter that directory
cd physx-js-webidl

# Download submodule containing the PhysX code
git submodule update --init

# Generate build-scripts
./generate.sh

# Build
./make.sh

To add bindings to additional PhysX interfaces you only have to edit the PhysXJs.idl file located in PhysX/physx/source/webidlbindings/src/wasm/ and recompile the library.

Build with Docker

# Build the image
docker compose up

# Build Release
docker compose run --rm builder ./make.sh

# Build Profile
docker compose run --rm builder ./make-profile.sh

# Build Debug
docker compose run --rm builder ./make-debug.sh

Build Types

It is also possible to generate Typescript bindings out of the idl file (apparently broken on recent node version):

npx @milkshakeio/webidl2ts -e -d -n PhysX -i PhysX/physx/source/webidlbindings/src/wasm/PhysXWasm.idl -o dist/physx-js-webidl.wasm.d.ts
2.3.1

4 months ago

2.3.0

7 months ago

2.2.0

10 months ago

2.1.1

10 months ago

2.1.0

11 months ago

2.0.5

1 year ago

2.0.4

1 year ago

2.0.0

1 year ago

1.1.0

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago

0.4.18

2 years ago

0.4.16

2 years ago

0.4.15

3 years ago

0.4.14

3 years ago

0.4.11

3 years ago

0.4.10

3 years ago

0.4.9

3 years ago

0.4.8

3 years ago

0.4.7

3 years ago

0.4.6

3 years ago

0.4.5

3 years ago

0.4.4

3 years ago

0.4.3

3 years ago

0.4.2

3 years ago

0.4.1

3 years ago

0.3.2

3 years ago