1.2.0 • Published 6 years ago

aframe-spherical-controls-component v1.2.0

Weekly downloads
9
License
MIT
Repository
github
Last release
6 years ago

aframe-spherical-controls-component

Version License

This component orbits an entity at a fixed point on a constant radius. It is not a universial control, because it is mostly designed for mobile devices using the tilting of the head to control the orbital track. You can therefor not set it directly on the camera entity, but it needs to be set as a rig around the camera (aka camera rig pattern).

It differs from the Orbit Controls component in that way that it does not substitute look-controls component, but uses it rather for determing the movement direction.

For A-Frame.

API

The component sets the matrix of the entity directly. Use the position and rotation properties from the object to obtain positional and rotational data.

PropertyDescriptionDefault Value
radiusThe radius of the spherical movement1
minRadiusThe minimum offset from the radius for of the spherical movement0
maxRadiusThe maximum offset from the radius of the spherical movement0
speedMovement speed1
latSets the spherical position according to the planar latitude (between -90 and 90) coordinate in degrees0
lngSets the spherical position according to the planar longitude (between -180 and 180) coordinate in degrees0
upVectorSets the up vector like in the lookAt function of Three.JS. Hardly ever needed to set manually0 1 0
vrModeWhether the controls are only enabled when in mobile VR modefalse
tiltTilt of camera in degrees0
enabledWhether the controls are enabledtrue

Methods

PropertyDescriptionDefault Value
getLatLngAzimuthReturns the current latitude and longitude coordinates and looking direction azimuth in degrees{lat: 0, lng: 0, azimuth: 0}

Usage

Do not set the position or rotation directly on this component because the get overriden. Always create a surrounding entity for relative moving.

The current implementation does not work with together with the other movement controls like wasd-controls on the camera entity.

Installation

Browser

Install and use by directly including the browser files:

<head>
  <title>My A-Frame Scene</title>
  <script src="https://aframe.io/releases/0.8.0/aframe.min.js"></script>
  <script src="https://unpkg.com/aframe-spherical-controls-component/dist/aframe-spherical-controls-component.min.js"></script>
</head>

<body>
  <a-scene>
    <a-entity spherical-controls="foo: bar"></a-entity>
  </a-scene>
</body>

npm

Install via npm:

npm install aframe-spherical-controls-component

Then require and use.

require('aframe');
require('aframe-spherical-controls-component');
1.2.0

6 years ago

1.1.1

6 years ago

1.1.0

6 years ago

1.0.2

6 years ago

1.0.1

6 years ago

1.0.0

6 years ago

0.9.5

6 years ago

0.9.4

6 years ago

0.9.3

6 years ago

0.9.2

6 years ago

0.9.1

6 years ago

0.9.0

6 years ago