diff --git a/public/index.html b/public/index.html index 6bcedf148c094a516dbc77f4d56c6e8f1e5f766b..3b58ef6cea83455e69439a53865c45ac942e4e3d 100644 --- a/public/index.html +++ b/public/index.html @@ -2,7 +2,7 @@ <head> <title>A-Frame Social VR Demo</title> - <script src="https://aframe.io/releases/0.7.0/aframe.min.js"></script> + <script src="https://aframe.io/releases/0.7.0/aframe.js"></script> <script src="./app.bundle.js"></script> </head> @@ -58,7 +58,7 @@ <a-entity id="nametag" networked="template:#nametag-template;showLocalTemplate:false;"></a-entity> - <a-entity id="left-hand" hand-controls="left" axis-dpad="centerZone: 1" teleport-controls="cameraRig: #player-rig; teleportOrigin: #head; button: action_teleport_" + <a-entity id="left-hand" hand-controls="left" visible="false" hand-controls-child-visibility axis-dpad="centerZone: 1" teleport-controls="cameraRig: #player-rig; teleportOrigin: #head; button: action_teleport_" networked="template:#hand-template;showLocalTemplate:false;"> <a-entity id="watch" gltf-model="assets/hud/watch.gltf" position="0 0.0015 0.147" rotation="3.5 0 0"> <a-circle mute-state-indicator scale-audio-feedback="analyserSrc: #head; minScale: 0.035; maxScale: 0.08;" position="0 0.023 0" @@ -67,7 +67,7 @@ </a-entity> </a-entity> - <a-entity id="right-hand" hand-controls="right" axis-dpad teleport-controls="cameraRig: #player-rig; teleportOrigin: #head; hitEntity: #telepor-indicator; button: action_teleport_;" + <a-entity id="right-hand" hand-controls="right" visible="false" hand-controls-child-visibility axis-dpad teleport-controls="cameraRig: #player-rig; teleportOrigin: #head; hitEntity: #telepor-indicator; button: action_teleport_;" networked="template:#hand-template;showLocalTemplate:false;"></a-entity> </a-entity> diff --git a/src/components/hand-controls-child-visibility.js b/src/components/hand-controls-child-visibility.js new file mode 100644 index 0000000000000000000000000000000000000000..75b79bb210636577a2b345b6ca0b1eb8f837d0d6 --- /dev/null +++ b/src/components/hand-controls-child-visibility.js @@ -0,0 +1,21 @@ +AFRAME.registerComponent("hand-controls-child-visibility", { + init() { + this.onControllerConnected = this.onControllerConnected.bind(this); + this.onControllerDisconnected = this.onControllerDisconnected.bind(this); + this.el.addEventListener("controllerconnected", this.onControllerConnected); + this.el.addEventListener( + "controllerdisconnected", + this.onControllerDisconnected + ); + + this.el.setAttribute("visible", false); + }, + + onControllerConnected() { + this.el.setAttribute("visible", true); + }, + + onControllerDisconnected() { + this.el.setAttribute("visible", false); + } +}); diff --git a/src/index.js b/src/index.js index fabb513a4751cda114a9ed2d5d30d8c6403f42d6..d230f3e3e5d399035242f547b3e1886770eefa37 100644 --- a/src/index.js +++ b/src/index.js @@ -10,6 +10,7 @@ import "./components/audio-feedback"; import "./components/nametag-transform"; import "./components/avatar-customization"; import "./components/mute-state-indicator"; +import "./components/hand-controls-child-visibility"; import { generateName } from "./utils"; @@ -24,6 +25,11 @@ NAF.schemas.add({ ] }); +NAF.schemas.add({ + template: "#hand-template", + components: ["position", "rotation", "visible"] +}); + AFRAME.registerInputMappings({ default: { common: {