DEPRECATED! This repo has been replaced by AltspaceVR/AltspaceSDK
When it comes to building something quick in AltspaceVR, it’s hard to beat A-Frame. It has a simple HTML-based syntax, so anyone acquainted with web development will pick it up in no time. On the other hand, if you don’t know what an HTML tag is, or how to add an image to a page, you should go through MDN’s terrific Introduction to HTML before you continue.
The world is full of web developers though, so if you feel comfortable experimenting on your own, you should jump right in with the A-Frame Documentation. You just need to add the altspace
component to your <a-scene>
tag. Keep in mind though that development in AltspaceVR has a few caveats.
In either case, you should join the AltspaceVR SDK Slack channel (register here)! We love to see what you’re working on, and are always happy to answer questions. In addition, there are special activities available only for developers that may be better for apps. Just request developer status on Slack, and we’ll hook you up!
- API Documentation for A-Frame
- API Documentation for Three.js
- A-Frame Overview
- AltspaceVR Developer Portal
- Building Your First A-Frame App
- Examples
- Native Components FAQ
This is a fully functional example of what A-Frame code looks like. Live Demo
<!DOCTYPE html>
<html><head>
<script src="https://aframe.io/releases/0.3.0/aframe.min.js"></script>
<script src="https://cdn.rawgit.com/AltspaceVR/aframe-altspace-component/v1.4.0/dist/aframe-altspace-component.min.js"></script>
<script>
// an example custom component, that will change the color when clicked
AFRAME.registerComponent('color-cycle', {
schema: {},
init: function(){
var self = this;
self.el.object3D.addEventListener('cursorup', function(){
var rgb = [
Math.floor(Math.random()*256),
Math.floor(Math.random()*256),
Math.floor(Math.random()*256)
];
self.el.setAttribute('color', 'rgb('+rgb.join(',')+')');
});
}
});
</script>
</head>
<body>
<!-- set up the scene -->
<a-scene altspace='vertical-align: bottom;'>
<a-box position='0 1 0' color-cycle></a-box>
</a-scene>
</body></html>
In addition to the normal power of A-Frame that AltspaceVR developers are used to, we now support attaching native AltspaceVR assets to entities via special A-Frame components. So you can spawn physical objects that you can stand on, interactables that users can pick up and throw, and much more! See the native component documentation and the native component FAQ for the details.
One of the biggest challenges in creating VR applications is gathering and optimizing art and sound content. We've gone ahead and built a bunch of resources to get you started! They can be invoked via the n-object
, n-sound
, and n-spawner
native components and are automatically optimized for the individual platform your user happens to be on. See the resource list for the complete list of resources available.