<!DOCTYPE html> <html> <title>SpaSca : Spatial Scaffolding</title> <head> <!-- Suggestions? https://git.benetou.fr/utopiah/text-code-xr-engine/issues/ --> <script src='dependencies/aframe.offline.min.js'></script> <script src="dependencies/a-console.js"></script> <script src='dependencies/aframe-troika-text.min.js'></script> <script src="dependencies/shiki0.14.1.js"></script> <!-- bit demanding but it IS about code too, so arguably important enough --> <script src='jxr.js'></script> </head> <body> <script> // goal : being able to modify the bindings in XR, hence the manager part const gestures = []; // start with : left pinch, right pinch, right index tap var gesturesTargets = [] // start with target (updated by target component) and selectors e.g #box (maybe semantically clarified, i.e follow wrist) var boundGestures = []; // start with // left pinch ON [target] (correct selector) // right pinch ON [target] // right index tap ON #box FRAME.registerComponent('empty', { init: function(){ console.log('empty component example') } }) function listBoundGestures(){ console.log('could start with : left pinch, right pinch, box tap') console.log(boundGestures, gestures, gesturesTargets) } </script> <a-scene startfunctions> <a-entity id="rig"> <a-entity id="player" hud camera look-controls wasd-controls waistattach="target: .movebypinch" position="0 1.6 0"></a-entity> <a-entity id="rightHand" pinchprimary hand-tracking-controls="hand: right;"></a-entity> <a-entity id="leftHand" pinchsecondary wristattachsecondary="target: #box" hand-tracking-controls="hand: left;"></a-entity> </a-entity> <a-box pressable start-on-press id="box" scale="0.05 0.05 0.05" color="pink"></a-box> <!-- could attach functions here... BUT then they have to be activable with the other hand! --> <!-- visual reminders of shortcuts, a poster on the far left/right of keyboard shortcuts --> <a-troika-text value="SpaSca : Spatial Scaffolding" anchor="left" outline-width="5%" font="../content/ChakraPetch-Regular.ttf" position="-5.26197 6.54224 -1.81284" scale="4 4 5" rotation="90 0 0" troika-text="outlineWidth: 0.01; strokeColor: #ffffff" material="flatShading: true; blending: additive; emissive: #c061cb"></a-troika-text> <a-sky hide-on-enter-ar color="lightgray"></a-sky> <a-troika-text anchor=left target value="instructions : \n--right pinch to move\n--left pinch to execute" position="0 0.65 -0.2" scale="0.1 0.1 0.1"></a-troika-text> <a-console position="2 2 0" rotation="0 -45 0" font-size="34" height=1 skip-intro=true></a-console> <a-troika-text anchor=left target id="listboundgestures" value="jxr listBoundGestures()" position="0 1.40 -0.1" scale="0.1 0.1 0.1"></a-troika-text> <a-troika-text anchor=left target id="locationreload" value="jxr location.reload()" position="0 1.20 -0.1" scale="0.1 0.1 0.1"></a-troika-text> <a-troika-text anchor=left target id="makeAnchorsVisibleOnTargets" value="jxr makeAnchorsVisibleOnTargets()" position="0 1.05 -0.1" scale="0.1 0.1 0.1"></a-troika-text> </a-scene> </body> </script> </html>