diff --git a/src/components/in-world-hud.js b/src/components/in-world-hud.js index ef28c02366f0c0f9d1c74a1a608885010af7072c..b3bf2418f788b996e765a5b13d61aa1fc13f2309 100644 --- a/src/components/in-world-hud.js +++ b/src/components/in-world-hud.js @@ -1,4 +1,7 @@ AFRAME.registerComponent("in-world-hud", { + schema: { + haptic: { type: "selector" } + }, init() { this.bg = this.el.querySelector(".bg"); this.mic = this.el.querySelector(".mic"); @@ -18,12 +21,14 @@ AFRAME.registerComponent("in-world-hud", { this.onNametagHovered = () => { this.nametag.setAttribute("color", "cyan"); + this.data.haptic.emit("haptic_pulse", { intensity: "low" }); }; this.onNametagUnhovered = () => { this.nametag.setAttribute("color", "white"); }; this.onAvatarHovered = () => { this.avatar.setAttribute("scale", flipXAvatarScale); + this.data.haptic.emit("haptic_pulse", { intensity: "low" }); }; this.onAvatarUnhovered = () => { this.avatar.setAttribute("scale", avatarScale); @@ -32,6 +37,7 @@ AFRAME.registerComponent("in-world-hud", { this.hoveredOnMic = true; const muted = scene.is("muted"); this.mic.setAttribute("src", muted ? "#unmuted" : "#muted"); + this.data.haptic.emit("haptic_pulse", { intensity: "low" }); }; this.showCorrectMuteState = () => { @@ -52,6 +58,7 @@ AFRAME.registerComponent("in-world-hud", { this.onSelect = evt => { if (this.hoveredOnMic) { this.el.emit("action_mute"); + this.data.haptic.emit("haptic_pulse", { intensity: "low" }); } }; diff --git a/src/room.html b/src/room.html index cb539a638d5c5b73adeb125e6b793d3d9eb13dac..435e8f553f53b4ec29d73c6dd2fba42ecd10c683 100644 --- a/src/room.html +++ b/src/room.html @@ -105,7 +105,7 @@ ik-root > <a-entity id="player-hud"> - <a-entity in-world-hud rotation="-39.01000608674482 0 0"> + <a-entity in-world-hud="haptic:#player-right-controller" rotation="-39.01000608674482 0 0"> <a-box geometry="height:0.13;width:0.6;depth:0.001" material="depthTest:false; color:#000000;opacity:0.35" class="hud bg"></a-box> <a-image src="#unmuted" scale="-0.1 0.1 0.1" position="-0.2 0 0.001" class="hud mic" material="alphaTest:0.1;depthTest:false;" geometry=""></a-image> <a-text scale="0.3 0.3 0.3" position="-0.12 0 0.001" class="hud nametag" text="width:6;alphaTest:0.1"></a-text>