Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/retchut/aframe-mesh-ui-components
A simple port of felixmariotto's three-mesh-ui package for use in A-Frame's environment
https://github.com/retchut/aframe-mesh-ui-components
aframe aframe-component threejs vr webxr
Last synced: 3 months ago
JSON representation
A simple port of felixmariotto's three-mesh-ui package for use in A-Frame's environment
- Host: GitHub
- URL: https://github.com/retchut/aframe-mesh-ui-components
- Owner: Retchut
- License: mit
- Created: 2023-08-05T09:22:38.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-03T09:15:08.000Z (9 months ago)
- Last Synced: 2024-10-10T01:02:37.319Z (3 months ago)
- Topics: aframe, aframe-component, threejs, vr, webxr
- Language: JavaScript
- Homepage: https://www.npmjs.com/package/aframe-mesh-ui-components
- Size: 701 KB
- Stars: 2
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# aframe-mesh-ui-components
**aframe-mesh-ui-components** is a set of A-Frame components which aid in creating VR UIs for building VR user interfaces.
These components utilize [Felix Mariotto](https://github.com/felixmariotto/)'s [three-mesh-ui](https://github.com/felixmariotto/three-mesh-ui) library under the hood, adapting it to components fit for use with A-Frame.
# Import
## Module
You can install the module by installing its corresponding npm package:
`npm install aframe-mesh-ui-components`
You can then import it as an ES6 module or CommonJS:
```javascript
// ES6
import ThreeMeshUI from "aframe-mesh-ui-components";// CommonJS
const ThreeMeshUI = require("aframe-mesh-ui-components");
```## HTML <script> tag
Alternatively, you can include a minified or development version of the package via a `` tag in your html:
```html
<!-- Make sure to also include a-frame's latest build ! -->
<script src="https://aframe.io/releases/1.4.0/aframe.min.js">```
# Usage
## Font files
In order to display text from within the mesh-text component, a parent component must provide a fontFamily file and a fontTexture file.
The two font files used in the examples were taken from Felix Mariotto's [example assets](https://github.com/felixmariotto/three-mesh-ui/tree/master/examples/assets), and you can find their tutorial on how to create new fonts [here](https://github.com/felixmariotto/three-mesh-ui/wiki/Creating-your-own-fonts)
## Simple use case
What follows is a very rudimentary and simple use case. More examples can be found inside the [examples folder](https://github.com/Retchut/aframe-mesh-ui-components/tree/main/examples).
You can run these by cloning the repository and running the local development server.
### Code
```html
```
#### End result
![Basic example](./examples/images/basic.png)
### Components
#### mesh-container
The parent of a UI element must contain both a `mesh-container` and a `mesh-block` component.
The `mesh-container` component handles the recursive loading of all the `mesh-block` and `mesh-text` components contained in its entity, and all of its children.
#### mesh-block
A `mesh-block` component is equivalent to a `ThreeMeshUI.Block` object.
It receives the exact same properties a ThreeMeshUI Block would.
#### mesh-text
A `mesh-text` component is equivalent to a `ThreeMeshUI.Text` object.
It receives the exact same properties a ThreeMeshUI Text would.
# Scripts
## Development server
You can run a local development server by running the `npm start` command in the root of this project.
## Build generation
`npm run dist:min` - generates a minified build and its corresponding source map
`npm run dist:max` - generates a development build and its corresponding source map
`npm run dist` - generates both a minified and a development build and their corresponding source maps
# TODO
There are still some components which are missing implementation:
- Image blocks
- Buttons (also including keyboard utilities)
- Runtime UI modification utilities