From eef774d71cbe3b8d365c68f9dbdae0f05a7b4c63 Mon Sep 17 00:00:00 2001 From: Alezia Kurdis <60075796+AleziaKurdis@users.noreply.github.com> Date: Thu, 21 Dec 2023 23:00:53 -0500 Subject: [PATCH] Add "Room Scale Marker" app Room Scale Marker Designed for enthusiasts of 'Full Body Tracking,' this application prioritizes safety and performance precision by generating a central marker (local entity). Unlike the standard chaperone system in VR, which tends to signal boundaries reactively, this central marker enhances real-world reference awareness, enabling users to plan their moves more effectively to never reach those boundaries. Perfect for dancing. This marker self-delete as soon it stop matching the reality. --- applications/metadata.js | 9 + .../roomScaleMarker/app-roomScaleMarker.js | 104 ++++++++++ applications/roomScaleMarker/icon_active.png | Bin 0 -> 1331 bytes .../roomScaleMarker/icon_inactive.png | Bin 0 -> 1344 bytes applications/roomScaleMarker/marker.svg | 181 ++++++++++++++++++ 5 files changed, 294 insertions(+) create mode 100644 applications/roomScaleMarker/app-roomScaleMarker.js create mode 100644 applications/roomScaleMarker/icon_active.png create mode 100644 applications/roomScaleMarker/icon_inactive.png create mode 100644 applications/roomScaleMarker/marker.svg diff --git a/applications/metadata.js b/applications/metadata.js index e8f6f7b..5318914 100644 --- a/applications/metadata.js +++ b/applications/metadata.js @@ -269,6 +269,15 @@ var metadata = { "applications": "jsfile": "inventory-app/dist/inventory.js", "icon": "inventory-app/dist/inventory-i.svg", "caption": "INVENTORY" + }, + { + "isActive": true, + "directory": "roomScaleMarker", + "name": "Room Scale Marker", + "description": "Designed for enthusiasts of 'Full Body Tracking,' this application prioritizes safety and performance precision by generating a central marker (local entity). Unlike the standard chaperone system in VR, which tends to signal boundaries reactively, this central marker enhances real-world reference awareness, enabling users to plan their moves more effectively to never reach those boundaries. Perfect for dancing. This marker self-delete as soon it stop matching the reality.", + "jsfile": "roomScaleMarker/app-roomScaleMarker.js", + "icon": "roomScaleMarker/icon_inactive.png", + "caption": "RS-MARKER" } ] }; \ No newline at end of file diff --git a/applications/roomScaleMarker/app-roomScaleMarker.js b/applications/roomScaleMarker/app-roomScaleMarker.js new file mode 100644 index 0000000..041b844 --- /dev/null +++ b/applications/roomScaleMarker/app-roomScaleMarker.js @@ -0,0 +1,104 @@ +// +// app-roomScaleMarker.js +// +// Created by Alezia Kurdis, December 18th 2023. +// Copyright 2023 Overte e.V. +// +// Put a Marker on the floor to indicate the center of the room as you are doing full body tracking. +// +// Distributed under the Apache License, Version 2.0. +// See the accompanying file LICENSE or http://www.apache.org/licenses/LICENSE-2.0.html +// +(function() { + var jsMainFileName = "app-roomScaleMarker.js"; + var ROOT = Script.resolvePath('').split(jsMainFileName)[0]; + + var APP_NAME = "RS-MARKER"; + var ICON_CAPTION_COLOR = "#FFFFFF"; + var APP_ICON_INACTIVE = ROOT + "icon_inactive.png"; + var APP_ICON_ACTIVE = ROOT + "icon_active.png"; + var appStatus = false; + var channel = "overte.application.ak.roomScaleMarker"; + var markerID = Uuid.NULL; + + var tablet = Tablet.getTablet("com.highfidelity.interface.tablet.system"); + + var button = tablet.addButton({ + "text": APP_NAME, + "icon": APP_ICON_INACTIVE, + "activeIcon": APP_ICON_ACTIVE, + "sortOrder": 4, + "captionColor": ICON_CAPTION_COLOR + }); + + function clicked(){ + var colorCaption; + if (appStatus === true) { + clearMarker(); + colorCaption = ICON_CAPTION_COLOR; + appStatus = false; + }else{ + drawMarker(); + colorCaption = "#000000"; + appStatus = true; + } + + button.editProperties({ + "isActive": appStatus, + "captionColor": colorCaption + }); + } + + button.clicked.connect(clicked); + + function drawMarker() { + if (markerID !== Uuid.NULL) { + clearMarker(); + } + markerID = Entities.addEntity({ + "name": "ROOM SCALE MARKER", + "type": "Image", + "dimensions": {"x": 2, "y": 2, "z": 0.01}, + "position": Vec3.sum(MyAvatar.feetPosition,{"x": 0, "y": 0.01, "z": 0}), + "rotation": Quat.multiply(MyAvatar.orientation, Quat.fromVec3Degrees({"x": -90, "y": 0, "z": 0})), + "imageURL": ROOT + "marker.svg", + "emissive": true, + "keepAspectRatio": false, + "canCastShadow": false, + "isVisibleInSecondaryCamera": false, + "grab": { + "grabbable": false + } + },"local"); + Controller.actionEvent.connect(onActionEvent); + } + + //all except 23 24 + function onActionEvent(action, value) { + if (action !== 23 && action !== 24) { + appStatus = true; + clicked(); + } + } + + function clearMarker() { + if (markerID !== Uuid.NULL) { + Entities.deleteEntity(markerID); + markerID = Uuid.NULL; + } + Controller.actionEvent.disconnect(onActionEvent); + } + + function cleanup() { + + if (appStatus) { + clearMarker(); + colorCaption = ICON_CAPTION_COLOR; + appStatus = false; + } + + tablet.removeButton(button); + } + + Script.scriptEnding.connect(cleanup); +}()); diff --git a/applications/roomScaleMarker/icon_active.png b/applications/roomScaleMarker/icon_active.png new file mode 100644 index 0000000000000000000000000000000000000000..f3f15d5fcab0d1277aeba61a7802cd1c7e5902bd GIT binary patch literal 1331 zcmX9;Yfuvh82m1Ggv2~J-VY&0LWEKxB!U7W91uuCL}P|(cyxr=YUor&B!HCBLqHD@ z0c}y4RtWMGtYE2DTa-#bbQ}eY7F#=Nz*dy1NNj0E(?NgipWWG={jsxUsx>ms0*?g% zz){GhY5 zs{kABnr09nCSNinEl8G)Sw^JAD9@o7zDjFEs85T=Dr##1!&gPTT$o^OY!(6{wX2#d z9kuE*nFNfC3Ob1ZhVim0G7zso#J-{cl);a;ux|_v$;)=75mR*IMWWNr=&us5*BvOd zF}o6lJn9@e&GoCFy3R!bk)BesCdOj;7ZFK4#(pWa!AJF62D~bFxzbcs;k(hGj?4aAKlB>RESjN7!Qyz6i|jDi5Dr7S&4348}$j zY>%07Rqzl7KReBvpTaeKUrX1=N0ya&;Kq%@7xKX4M{2Q&lYk8Z~y-rR}caz>?(%Rj>ZB0x>4aMVs+-x>*{6s^uwU_;pl4*ul`jdH7+>sLqh z`Af8Yc|BYg@dK>3Z=$~y;ggy!>O6FF95#Y-5zSQ6COg^7)a#=O$GYh<AzO8-0mXKszjJS{0Hj0|U)Rv=6wsTEc88=$eyVf{XXk5WHYw&J zk3(C^a+>hk!d+ZyfR1fwcy#q7wn;o)}s97_@6O{1@bv3 zyfs?p^iRx{BJ21IDYUmU`J|tFW>RUbpUE?`u-tS*a8&?^baL#pTMn27rMy{NFUu|8 zf$UH6Pz?V*emq)#ErI`5vCo$qJL5cAxx(ii?;Fc0`T?a*6RFoPb(>iC8(t0M@N=)M z8?BkLC!z6n=hBruYl3Xe1FE%Om)==%ayXLv=$kLzd0CYnyBmD|W|U`KrJLAM2_4V8 z2^iTV`I6IqKXDo0gvG+J6^RfAzaW2t7M$#LV*W*pp=q^Y2sYf6oP^>;|DXU6I^2B_ U>&04%HUa=B;?_vNjY;48KclPnga7~l literal 0 HcmV?d00001 diff --git a/applications/roomScaleMarker/icon_inactive.png b/applications/roomScaleMarker/icon_inactive.png new file mode 100644 index 0000000000000000000000000000000000000000..14ef122cf141fe0956592958cbfbafdf7a83bc9e GIT binary patch literal 1344 zcmW-he=wAJ9LGP;{<7>Xj}&&XzS*&^V}&HSI*+x>N`78BsuPczR(DO&R???S^<4if@q>$0ig8hX-stk0x#-wf zV9>RqOg0&ToQvNa)TVw$ug=aC5D=K$Asc0otI&Hkc^IW=%Z#$DQD6KfSf+^U9`pfX zW-*fj5)KyH9p}+J?ev`^_d0p#AB>DyHw-vYlMjmx`FR zRzMS0mZV9*;9S}ZZ~ zQ`%I=@_NqsS$n@+ zr4@k5FGgzyrYEU9=L+EogKI}&cR`4z4j8m+B_-6HRgph8)Hkr9yO$jts6e%y=WG#0 zTg~C;Bg`XSgEF%7K&!oT;0UX>bF}LmhN#pQx&w^-MOz`(lQAf7w%Ny||DMoM5_}at z?)cWrr6!?QJMCXRv=OEAUjPelYkO#e#ylBJpPTwAJ^`8KdWmWoJGR+y<%v)#cpAm? z;H)t=GNjh0U`_M#SXSu0wVr8tq|$@}7m>dnNkVhFhw9@>+10c4w8SnfKH}=+a{Teg zeI`zrw(U<$J`{!cPMd{}JoUiz5$?WHj6s*0Tj_N7iK+m)Q;EhinPIBgN2v@aHn4Ex z5=%<(4ZqfiXdX2$xa z_SGP(fN(E5vr$7=MJ)^}cvg`zt0e^Zte>EJ4Y%hWRlUeKef%*8!rG9znZIWJ{=eumzU}m$J3}O<6^fId{68Udcj~S)kB! zESp0)=sjj!fnPzjteCEz4Z;EKN1M z*LG8lF6ebOs%Ksjw>DU|gl_6fN}MX?04DEIHhzJ7Hoj55_!{jO|F#w|`S?(?tJ*v! zE)q@Kc)Y#u^GFJq{L(;P97?w}h4;KRWvXtRHuC|KznXE3MD{kMCrY7?6&Vc=c;O9- znGn@iLq~%zC_;dXqJ)<;870nr)x=4rDX@PoQlxer7pU)*>;y!mss>*(i#~`y-(Os& zt$QAw{oq>`7v--nzOwY)wQLSB=z7s}!x?YD + + + + marker + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + marker + + + +