Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/whitestormjs/physics-module-ammonext
Physics module for Whitestorm.js [Beta]
https://github.com/whitestormjs/physics-module-ammonext
3d ammo physics physics-module whitestormjs
Last synced: about 2 months ago
JSON representation
Physics module for Whitestorm.js [Beta]
- Host: GitHub
- URL: https://github.com/whitestormjs/physics-module-ammonext
- Owner: WhitestormJS
- Created: 2016-12-14T09:17:45.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2018-06-06T18:56:12.000Z (over 6 years ago)
- Last Synced: 2024-11-09T10:48:31.618Z (about 2 months ago)
- Topics: 3d, ammo, physics, physics-module, whitestormjs
- Language: JavaScript
- Homepage: https://whsjs.readme.io/docs
- Size: 7.51 MB
- Stars: 38
- Watchers: 22
- Forks: 13
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# physics-module-ammonext [![NPM Version](https://img.shields.io/npm/v/physics-module-ammonext.svg?style=flat-square)](https://www.npmjs.com/package/physics-module-ammonext)
Physics module for Whitestorm.js [Beta]> Go to [WhitestormJS/whitestorm.js](https://github.com/WhitestormJS/whitestorm.js)
![physics module](http://i.imgur.com/ZdMhDwb.png)
# Modules list
## `new PHYSICS.WorldModule()`
```javascript
const app = new WHS.App([
// ...
new PHYSICS.WorldModule({
gravity: new THREE.Vector3(0, -10, 0),
ammo: 'path/to/ammo.js'
})
]);app.start();
```## `new PHYSICS.BoxModule()`
```javascript
const box = new WHS.Box({
geometry: {
width: 2,
height: 2,
depth: 4
},
modules: [
new PHYSICS.BoxModule({
mass: 10
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});box.addTo(app);
```![](http://i.imgur.com/v7hzbeS.png)
## `new PHYSICS.SphereModule()`
```javascript
const sphere = new WHS.Box({
geometry: {
radius: 3
},
modules: [
new PHYSICS.SphereModule({
mass: 10
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});sphere.addTo(app);
```![](http://i.imgur.com/GgqDeuX.png)
## `new PHYSICS.PlaneModule()`
```javascript
const plane = new WHS.Plane({
geometry: {
width: 100,
height: 100
},
modules: [
new PHYSICS.PlaneModule({
mass: 5
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});plane.addTo(app);
```## `new PHYSICS.CapsuleModule()`
No example yet.## `new PHYSICS.ConeModule()`
```javascript
const sphere = new WHS.Cylinder({
geometry: {
radiusTop: 0,
radiusBottom: 3,
height: 4
},
modules: [
new PHYSICS.ConeModule({
mass: 2
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});box.addTo(app);
```
## `new PHYSICS.ConvexModule()`
```javascript
const teapot = new WHS.Model({
geometry: {
path: 'path/to/teapot.json'
},
modules: [
new PHYSICS.ConvexModule({
mass: 2,
path: 'path/to/simplified/teapot.json'
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});teapot.addTo(app);
```
## `new PHYSICS.CylinderModule()`
```javascript
const sphere = new WHS.Cylinder({
geometry: {
radiusTop: 3,
radiusBottom: 3,
height: 4
},
modules: [
new PHYSICS.CylinderModule({
mass: 2
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});box.addTo(app);
```![](http://i.imgur.com/WohSp97.png)
## `new PHYSICS.HeightfieldModule()`
```javascript
const terrain = new WHS.Parametric({
geometry: {
func: myFunction
},
modules: [
new PHYSICS.HeightfieldModule({
mass: 5,
size: new THREE.Vector2(100, 100),
autoAlign: true // center physics object automatically.
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});terrain.addTo(app);
```![](http://i.imgur.com/h6Z8IIq.png)
## `new PHYSICS.CompoundModule()`
This module should be used only if you want to create a copmound physics object without shape and then add needed objects. `CompoundModule` is selected by default if you add object to another object.## `new PHYSICS.ConcaveModule()`
```javascript
const teapot = new WHS.Model({
geometry: {
path: 'path/to/teapot.json'
},
modules: [
new PHYSICS.ConcaveModule({
mass: 2,
path: 'path/to/simplified/teapot.json'
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});teapot.addTo(app);
```![](http://i.imgur.com/aoJ7fgv.jpg)
## `new PHYSICS.SoftbodyModule()`
```javascript
const sphere = new WHS.Icosahedron({
geometry: {
radius: 3,
detial: 2
},
modules: [
new PHYSICS.SoftbodyModule({
mass: 5,
pressure: 500
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});sphere.addTo(app);
```
## `new PHYSICS.ClothModule()`> Used only with `WHS.Plane`
```javascript
const cloth = new WHS.Plane({
geometry: {
width: 100,
height: 50
},
modules: [
new PHYSICS.ClothModule({
mass: 5
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});cloth.addTo(app);
```## `new PHYSICS.RopeModule()`
```javascript
const rope = new WHS.Line({
geometry: {
curve: new THREE.LineCurve3(new THREE.Vector3(0, 10, 0), new THREE.Vector3(0, 20, 0))
},
modules: [
new PHYSICS.RopeModule({
mass: 5
})
],
material: new THREE.MeshBasicMaterial({color: 0xff0000})
});rope.addTo(app);
```# Additional available physics parameters
## RigidBody```javascript
{
restitution: 0.3,
friction: 0.8,
damping: 0,
margin: 0
}
```## SoftBody (`SoftModule`, `ClothModule`, `RopeModule`)
```javascript
{
friction: 0.8,
damping: 0,
margin: 0,
klst: 0.9,
kvst: 0.9,
kast: 0.9,
piterations: 1,
viterations: 0,
diterations: 0,
citerations: 4,
anchorHardness: 0.7,
rigidHardness: 1
}
```# Events
## `collision`
[Example](https://github.com/WhitestormJS/physics-module-ammonext/blob/master/src/modules/controls/FirstPersonModule.js#L39)```javascript
player.on('collision', (otherObject, v, r, contactNormal) => {
if (contactNormal.y < 0.5) // Use a "good" threshold value between 0 and 1 here!
canJump = true;
});
```## FAQ
**Q: My `ClothModule` doesn't work properly, what to do?**A: In 90% cases it is because you have set `pressure` parameter. You shouldn't set it for `ClothModule`.