New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

aframe-mapbox-component

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

aframe-mapbox-component

A map component using Mapbox for A-Frame.

latest
Source
npmnpm
Version
4.0.1
Version published
Weekly downloads
10
150%
Maintainers
1
Weekly downloads
 
Created
Source

aframe-mapbox-component

A 3D street map entity & component for A-Frame. Uses Mapbox version 1.13.0 3-Clause BSD.

The component and idea was originally thankfully developed by jesstelford. I forked and renamed the project accordingly and will continue to develop this component.

Installation

Browser

Use directly from the unpkg CDN:

<head>
  <script src="https://aframe.io/releases/1.0.4/aframe.min.js"></script>
  <script src="https://unpkg.com/aframe-mapbox-component/dist/aframe-mapbox-component.min.js"></script>
</head>

<body>
  <a-scene>
    <a-mapbox position="0 0 -5"></a-map>
    <a-camera></a-camera>
  </a-scene>
</body>

npm

Install via npm:

npm install aframe-mapbox-component

Then register and use.

import 'aframe';
import 'aframe-mapbox-component';

mapbox component

Schema

attributetypedefaultdescription
pxToWorldRationumber100The number of pixels per world unit to render the map on the plane. ie; when set to 100, will display 100 pixels per 1 meter in world space. (see a note on fidelity). However the resulting ratio is calculated from the widht and height of the material, which always needs to be in power of two.
accesstokenstringAn optional access token if using Mapbox's style. Not needed if you use your own styling
stylestring''Either a standard Mapbox URL (like mapbox://styles/mapbox/satellite-v8) or a your custom style url created with Mapbox Studio
...All other options are passed directly to Mapbox GL
A note on fidelity

The higher pxToWorldRatio, the more map area will be displayed per world unit. That canvas has to be translated into a plane in world space. This is combined with the width and height in world space (from geometry.width and geometry.height on the entity) to set up the plane for rendering in 3D.

The map is rendered as a texture on a 3D plane. For best performance, texture sizes should be kept to powers of 2. Keeping this in mind, you should work to ensure width * pxToWorldRatio and height * pxToWorldRatio are powers of 2.

Events

event namedatadescription
mapbox-load(none)Fired before the first render of the map component
mapbox-loaded(none)Fired on the first render of the map component
mapbox-moveend(none)Fired when zoom, center, bearing, or pitch are changed after the initial render

Keywords

mapbox

FAQs

Package last updated on 08 Feb 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts