This session will show the most basic aspects of A-Frame.
We will start with the canonical basic HTML A-Frame scene:
At this point, it is convenient that you also read the first part of Building a Basic Scene.
To work comfortably, we will use some tools:
- VSCode, or the free version VSCodium (we will refer to it as VSC from now on). You can also use VSCode as a web app for any GitHub repository (see below), but in that case you cannot run the LiveServer extension. Some other IDEs, such as Eclipse or JetBrains will also work.
- The LiveServer extension for VSCode or VSCodium
- Launch it as an HTTPS server. For that, you need to configure a certificate. You can use these self-signed certificates that we produced for the BabiaXR project: babia_cert.pem, babia_key.pem. For that, download the two files somewhere in your filesystem, and configure LiveServer to use them.
- GitHub or GitLab, and GitHub Pages or GitLab Pages.
- Create an account and log in
- Create a repository
- If you know how to use git, use it (you can use it from VSC)
- If not, upload / download files to the repository using the web interface.
- You can also use VSCode as a web app for any GitHub repo, just type "." (the dot) when in the repository. There, you can upload files maybe more easily.
- Activate GitHub Pages (while in the repository, go to Settings | Pages)
The usual workflow will be as follows:
- Create a repository in GitHub or GitLab
- Using git, clone it locally, and open it as a project with VSC, or clone it directly from within VSC.
- Create / modify HTML files, and other files used as assets.
- View the results locally using LiveServer for serving the project via HTTPS. That can be done with a local browser, but also with the browser of a XR device in the same WiFi.
- When done, commit and push to GitHub or GitLab, either using git or from VSC, so that the changes can be seen from GitHub or GitLab Pages.
While checking the XR scenes in the desktop browser, we can also use the A-Frame Inspector and/or, if you know how to use them, the Developer Tools of your browser.
In general, everything in this seminar works with Firefox and Chromium in desktop, with Chromium in Android phones and tablets, and with Chromium (the standard web browser) in Quest, Pico and other XR devices. It will likely also work with Wolvik in Quest, Pico and other XR devices.
Let's add movement in the scene, using the available controllers in each device: arrow keys or wasd keys in desktop, touching the screen with a finger in mobile, gamepad controls in XR devices. For that, we need to use a third party module, aframe-extras, which is imported in the header, right after the A-Frame module:
<script src="https://cdn.jsdelivr.net/gh/c-frame/[email protected]/dist/aframe-extras.min.js"></script>
And then, we need a camera, and a camera rig:
<a-entity movement-controls="fly: true">
<a-entity camera look-controls wasd-controls position="0 1.6 0"></a-entity>
</a-entity>
See the complete scene, based on the basic example: