Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/AdaRoseCannon/aframe-xr-boilerplate

Get started quickly with VR and AR using AFrame
https://github.com/AdaRoseCannon/aframe-xr-boilerplate

aframe augmented-reality vr webxr webxr-boilerplate

Last synced: 2 months ago
JSON representation

Get started quickly with VR and AR using AFrame

Awesome Lists containing this project

README

        

xr-starter-kit
=============

A boiler plate project for getting started with VR and AR with AFrame

This site tries to demonstrate many of the WebXR features to work with VR or AR.

## Components

These are some provided components to aid with the endeavour:

### ar-cursor.js

This file provides the `ar-cursor` component for `clicking` on objects in AR using any
XR input such as tapping on the screen or using an external controller.

Add it to the `` element along with a raycaster and it will use the raycaster to
determine which objects are selected and fire `"click"` events on them.

```html

```

### ar-shadow-helper.js

This file provides the `ar-shadow-helper` component which lets a plane track a particular object
so that it recieves an optimal amount of shadow from a directional light.

This should have an object which can receive a shadow and works well for augmented reality with the
`shader:shadow` material

It also includes `auto-shadow-cam` which controls the orthogonal shadow camera of a directional light
so that the camera covers the minimal area required to fully light an object.

```html

```

### model-utils.js

This file provides utilities for modifying 3D models and how they are displayed.

* `exposure="0.5"`, add this to `` to change the exposure of the scene to make it brighter or darker
* `no-tonemapping`, this opts an object out of tone mapping which is useful for using flat materials to look like light sources
* `lightmap="src:#bake;intensity: 10; filter:Window,Ceiling,floor;"`, this lets you use a lightmap on a gltf model, to use it provide the lightmap and optionally constrain the lightmap to certain elements
* `depthwrite`, this lets you overwrite a materials depthwrite property useful in case of weird depth issues on materials with transparency
* `hideparts`, this lets you make certain elements of a gltf object invisible, the better thing to do is to edit the object to remove those parts

### simple-navmesh-constraint.js

This provides `simple-navmesh-constraint` which allows you to constrain an object to another object,
if you set the `fall` property the object won't fall unless the floor underneath it is within that distance.

This component works by comparing the objects position between frames. Ideally this would run after any movement happen but before it is rendered.
To enable this you should place this component after any components which move the object such as `wasd-controls`.

If the object needs to float off the floor (like the camera) then set the height property and it will stay that far from the ground.

```html

```

If you're using `blink-controls` and `movement-controls` components that are using a camera rig, you want to set `height:0` and set the camera position instead like this:

```html

```

You can't use `wasd-controls` if you're using `movement-controls`. `movement-controls` includes the `keyboard` controls that is moving the camera rig position. The `blink-controls` component is also moving the camera rig position. The `wasd-controls` component needs to be on the same entity than the `look-controls` for it to work properly, so that's not compatible with using `movement-controls` and `blink-controls`.

The `exclude:.navmesh-hole` option allows you to have a navmesh that excludes some other geometries, like a plane that has the `navmesh-hole` class.
Here is an example of how it works, with a navmesh from a green plane and exclude of a small red plane:

```html

```