bind shortcut to wrist

warmup
Fabien Benetou 2 years ago
parent dfecb768cb
commit 565e74c7be
  1. 46
      index.html

@ -77,6 +77,18 @@ setTimeout( _ =>
// could add a dedicated MakeyMakey mode with a fixed camera, e.g bird eye view, and an action based on some physical input that others, thanks to NAF, could see or even use. // could add a dedicated MakeyMakey mode with a fixed camera, e.g bird eye view, and an action based on some physical input that others, thanks to NAF, could see or even use.
// ?inputmode=makeymakey // ?inputmode=makeymakey
AFRAME.registerComponent('enable-components-via-url', {
init: function () {
var src = AFRAME.utils.getUrlParameter('enable-components-via-url')
if (src && src != "") {
src.split(",").map( c => {
this.el.setAttribute(c, "")
})
}
}
})
AFRAME.registerComponent('disable-components-via-url', { AFRAME.registerComponent('disable-components-via-url', {
init: function () { init: function () {
var src = AFRAME.utils.getUrlParameter('disable-components-via-url') var src = AFRAME.utils.getUrlParameter('disable-components-via-url')
@ -795,6 +807,7 @@ AFRAME.registerComponent('wristattachsecondary',{
} }
}); });
var primaryPinchStarted = false
AFRAME.registerComponent('pinchprimary', { // currently only 1 hand, the right one AFRAME.registerComponent('pinchprimary', { // currently only 1 hand, the right one
// consider instead https://github.com/AdaRoseCannon/handy-work/blob/main/README-AFRAME.md for specific poses // consider instead https://github.com/AdaRoseCannon/handy-work/blob/main/README-AFRAME.md for specific poses
@ -807,6 +820,12 @@ AFRAME.registerComponent('pinchprimary', { // currently only 1 hand, the right o
// see own trigger-box component. Could use dedicated threejs helpers instead. // see own trigger-box component. Could use dedicated threejs helpers instead.
// https://github.com/Utopiah/aframe-triggerbox-component/blob/master/aframe-triggerbox-component.js#L66 // https://github.com/Utopiah/aframe-triggerbox-component/blob/master/aframe-triggerbox-component.js#L66
// could make trigger zones visible as debug mode // could make trigger zones visible as debug mode
var dist = event.detail.position.distanceTo( document.querySelector("#box").object3D.position )
if (dist < .1){
setHUD("close enough, replaced shortcut with "+ selectedElement.getAttribute("value") )
wristShortcut = selectedElement.getAttribute("value")
setTimeout( _ => setHUD(""), 2000)
}
// unselect current target if any // unselect current target if any
selectedElement = null; selectedElement = null;
save() save()
@ -825,6 +844,7 @@ AFRAME.registerComponent('pinchprimary', { // currently only 1 hand, the right o
bbox.min.copy( zeroVector3 ) bbox.min.copy( zeroVector3 )
bbox.man.copy( zeroVector3 ) bbox.man.copy( zeroVector3 )
*/ */
setTimeout( _ => primaryPinchStarted = false, 200) // delay otherwise still activate on release
}); });
this.el.addEventListener('pinchmoved', function (event) { this.el.addEventListener('pinchmoved', function (event) {
// move current target if any // move current target if any
@ -840,6 +860,7 @@ AFRAME.registerComponent('pinchprimary', { // currently only 1 hand, the right o
} }
}); });
this.el.addEventListener('pinchstarted', function (event) { this.el.addEventListener('pinchstarted', function (event) {
primaryPinchStarted = true
if (!selectionPinchMode) bbox.max.copy( zeroVector3 ) if (!selectionPinchMode) bbox.max.copy( zeroVector3 )
//var clone = getClosestTargetElement( event.detail.position ).cloneNode() //var clone = getClosestTargetElement( event.detail.position ).cloneNode()
@ -856,7 +877,7 @@ AFRAME.registerComponent('pinchprimary', { // currently only 1 hand, the right o
// testing on desktop // testing on desktop
var visible = true var visible = true
function tst(){ function switchToWireframe(){
visible = !visible visible = !visible
targets.map( e => { targets.map( e => {
scale = 50// should be a variable instead scale = 50// should be a variable instead
@ -878,7 +899,7 @@ function tst(){
// add (JXR) shortcuts as PIM function from e.g https://observablehq.com/@utopiah/from-pim-to-2d-to-3d-to-xr-explorations // add (JXR) shortcuts as PIM function from e.g https://observablehq.com/@utopiah/from-pim-to-2d-to-3d-to-xr-explorations
// allowing to search within PIM then show manipulable pages as preview. // allowing to search within PIM then show manipulable pages as preview.
// note that can be tested in VR also as jxr tst() // note that can be tested in VR also as jxr switchToWireframe()
// could make for nice in VR testing setup as eved notes // could make for nice in VR testing setup as eved notes
var setupMode = false var setupMode = false
@ -889,11 +910,13 @@ function enterSetupMode(){
setupMode = true setupMode = true
} }
AFRAME.registerComponent('changecoloronpress', { var wristShortcut = "jxr switchToWireframe()"
AFRAME.registerComponent('start-on-press', {
// should become a property of the component instead to be more flexible.
init: function(){ init: function(){
var el = this.el var el = this.el
this.el.addEventListener('pressedended', function (event) { this.el.addEventListener('pressedended', function (event) {
tst() if (!primaryPinchStarted && wristShortcut.match(/^jxr /)) interpretJXR(wristShortcut)
// other action could possibly based on position relative to zones instead, i.e a list of bbox/functions pairs // other action could possibly based on position relative to zones instead, i.e a list of bbox/functions pairs
}) })
} }
@ -1002,6 +1025,7 @@ AFRAME.registerComponent('hud', {
init: function(){ init: function(){
var el = this.el var el = this.el
var e = document.createElement("a-text") //could be hardcoded instead... arguable. var e = document.createElement("a-text") //could be hardcoded instead... arguable.
// should also be troika
e.setAttribute("value", startingText) e.setAttribute("value", startingText)
//e.setAttribute("font", "sw-test/Roboto-msdf.json") //e.setAttribute("font", "sw-test/Roboto-msdf.json")
e.setAttribute("position", "-0.05 0 -0.2") e.setAttribute("position", "-0.05 0 -0.2")
@ -1176,28 +1200,25 @@ function interpretJXR( code ){
// opt re-run it by moving the corresponding text in target volume // opt re-run it by moving the corresponding text in target volume
} }
AFRAME.registerComponent('toolbox', { AFRAME.registerComponent('toolbox', { // ununsed
init: function(){ init: function(){
var el = this.el var el = this.el
var e = document.createElement("a-sphere") var e = document.createElement("a-sphere")
e.setAttribute("scale", "0.1 0.1 0.1") e.setAttribute("scale", "0.1 0.1 0.1")
e.setAttribute("color", "lightblue") e.setAttribute("color", "lightblue")
e.setAttribute("pressable") e.setAttribute("pressable")
e.setAttribute("changecoloronpress")
e.id = "toolboxsphere" e.id = "toolboxsphere"
el.appendChild( e ) el.appendChild( e )
var e = document.createElement("a-cylinder") var e = document.createElement("a-cylinder")
e.setAttribute("scale", "0.1 0.1 0.1") e.setAttribute("scale", "0.1 0.1 0.1")
e.setAttribute("color", "darkred") e.setAttribute("color", "darkred")
e.setAttribute("pressable") e.setAttribute("pressable")
e.setAttribute("changecoloronpress")
e.id = "toolboxcylinder" e.id = "toolboxcylinder"
el.appendChild( e ) el.appendChild( e )
var e = document.createElement("a-box") var e = document.createElement("a-box")
e.setAttribute("scale", "0.1 0.1 0.1") e.setAttribute("scale", "0.1 0.1 0.1")
e.setAttribute("color", "pink") e.setAttribute("color", "pink")
e.setAttribute("pressable") e.setAttribute("pressable")
e.setAttribute("changecoloronpress")
e.id = "toolbox" e.id = "toolbox"
el.appendChild( e ) el.appendChild( e )
}, },
@ -1274,6 +1295,7 @@ AFRAME.registerComponent('fot', {
init:function(){ init:function(){
let generatorName = this.attrName let generatorName = this.attrName
setInterval( _ => fetch("https://fabien.benetou.fr/PIMVRdata/FoT?action=source#" + Date.now()).then(res => res.text() ).then(res => { setInterval( _ => fetch("https://fabien.benetou.fr/PIMVRdata/FoT?action=source#" + Date.now()).then(res => res.text() ).then(res => {
// consider tick() instead
res.split("\n").slice(0,maxItemsFromSources).map( (n,i) => { res.split("\n").slice(0,maxItemsFromSources).map( (n,i) => {
found = added.find((str) => str === n) found = added.find((str) => str === n)
if (typeof found === 'undefined'){ if (typeof found === 'undefined'){
@ -1450,9 +1472,9 @@ var generators = "line-link-entities link screenstack dynamic-view selectionboxo
<div id="observablehq-result_as_html-ab4c1560"></div> <div id="observablehq-result_as_html-ab4c1560"></div>
</div> </div>
<a-scene cursor="rayOrigin: mouse" raycaster="objects: [html]; interval:100;" <a-scene cursor="rayOrigin: mouse" raycaster="objects: [html]; interval:100;"
screenstack dynamic-view selectionboxonpinches keyboard commands-from-external-json glossary capturegesture toolbox disable-components-via-url enable-components-via-url commands-from-external-json
timeline issues fot disable-components-via-url networked-scene="serverURL: https://naf.benetou.fr/; adapter: easyrtc; audio: true;">
capturegesture toolbox networked-scene="serverURL: https://naf.benetou.fr/; adapter: easyrtc; audio: true;"> <!-- screenstack dynamic-view selectionboxonpinches keyboard glossary timeline issues fot -->
<a-assets> <a-assets>
<template id="avatar-template"> <a-cylinder opacity=.3 scale=".2 1.2 .2" networked-audio-source></a-cylinder> </template> <template id="avatar-template"> <a-cylinder opacity=.3 scale=".2 1.2 .2" networked-audio-source></a-cylinder> </template>
<template id="text-template"> <a-text></a-text> </template> <template id="text-template"> <a-text></a-text> </template>
@ -1481,7 +1503,7 @@ var generators = "line-link-entities link screenstack dynamic-view selectionboxo
<a-entity pinchprimary id="rightHand" hand-tracking-controls="hand: right;"></a-entity> <a-entity pinchprimary id="rightHand" hand-tracking-controls="hand: right;"></a-entity>
<a-entity wristattachsecondary="target: #box" NOpinchletterpick pinchsecondary id="leftHand" hand-tracking-controls="hand: left;"></a-entity> <a-entity wristattachsecondary="target: #box" NOpinchletterpick pinchsecondary id="leftHand" hand-tracking-controls="hand: left;"></a-entity>
<a-box pressable changecoloronpress id="box" scale="0.05 0.05 0.05" color="pink"></a-box> <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! --> <!-- could attach functions here... BUT then they have to be activable with the other hand! -->
<a-entity id="scaledworld" class="hidableassets" scale=".05 .05 .05" position="0 .85 0"><!-- can't be used for interactions otherwise becomes indirect--> <a-entity id="scaledworld" class="hidableassets" scale=".05 .05 .05" position="0 .85 0"><!-- can't be used for interactions otherwise becomes indirect-->
<a-box position="-0.1 1.2 -0.3" scale="0.5 0.5 0.5" rotation="0 45 0" color="#4CC3D9"></a-box> <a-box position="-0.1 1.2 -0.3" scale="0.5 0.5 0.5" rotation="0 45 0" color="#4CC3D9"></a-box>

Loading…
Cancel
Save