{"version":3,"sources":["resources/cirlce.png","resources/gold.png","resources/silver.png","resources/gem.png","resources/band.png","Scoller.js","resources/white-gold.png","resources/rose-gold.png","resources/platinum.png","resources/logo.png","ring.js","RingFinger.js","TryOnCanvas.js","App.js","index.js","HandSkeleton.js"],"names":["PINK_GOLD","assetId","WHITE_GOLD","YELLOW_GOLD","PLATINUM","RUBY_COLOR","SAPPHIRE","EMERALD","DIAMOND","TEST_COLOR","Scroller","setGemColor","setBandColor","useState","swiperIndex","setSwiperIndex","swiper","setSwiper","gemSwiper","setGemSwiper","bandSwiper","setBandSwiper","gemIndex","setGemIndex","bandIndex","setBandIndex","useEffect","className","spaceBetween","centeredSlides","slidesPerView","onSlideChange","activeIndex","handleSlideChange","onSwiper","slideTo","initSwiper","onClick","id","style","transform","src","iconSix","iconSeven","bottom","circle","iconTwo","iconOne","Ring","position","rotation","scale","proximalBoneLength","handModel","gemColor","bandColor","env","org","token","fallback","configuration","CameraController","useThree","camera","gl","controls","OrbitControls","domElement","minDistance","maxDistance","dispose","ResizeHandler","aspect","left","right","top","updateProjectionMatrix","DefaultCamera","set","Math","PI","zoom","RingFinger","width","height","prediction","updateDisplay","leftHandSkeleton","useMemo","HandSkeleton","Handedness","Left","useFrame","bone","undefined","image","update","getFeatureBone","getFeatureKey","Bone","Vector3","Quaternion","matrixWorld","decompose","y","rotationEuler","Euler","setFromQuaternion","multiHandLandmarks","length","TryOnCanvas","forwardRef","ref","onImageReady","videoWidth","videoHeight","isMirrored","webcamRef","useRef","offScreenCanvasRef","displayCanvasRef","croppedCanvasRef","videoAspect","videoConstraints","facingMode","useImperativeHandle","sendNextImage","offscreenCanvas","current","displayCtx","getContext","drawImage","video","offScreenCtx","croppedCanvas","croppedCanvasCtx","zIndex","onUserMedia","display","App","splashScreen","setSplashScreen","setPrediction","tryOnCanvasRef","URLSearchParams","window","location","search","get","hands","MediaPipeHands","locateFile","file","setOptions","minDetectionConfidence","minTrackingConfidence","onResults","setTimeout","logo","alt","send","marginLeft","innerHeight","onCreated","lookAt","orthographic","near","far","Environment","background","files","path","console","log","render","document","getElementById","Object","defineProperty","exports","value","convertPoseArrayToWorldFeatures","featureIndexToKey","fromPoseToWorldSpace","test","FeatureLength","FeatureNames","FingerNames","THREE","require","three_1","getZAxis","xAxis","yAxis","result","copy","cross","normalize","getXAxis","zAxis","equals","Error","featureName","jointIndex","featureKey","posePosition","viewWidth","viewHeight","x","z","array","worldFeatures","forEach","index","concat","handedness","_this","this","root","Group","debugAxes","debugSpheres","debugSkeleton","debugRadius","featureKeyToBoneMap","fingerCurl","palmFlatness","handMargin","numberOfHands","rightHandedness","name","urlParams","palmBaseBone","add","fingerName","fingerIndex","jointParentBone","jointBone","bones","traverse","object","type","matrixAutoUpdate","axesHelper","AxesHelper","push","skeletonHelper","SkeletonHelper","skeleton","Skeleton","prototype","results","found","multiHandedness","handednessLabel","Right","getHandednessFromLabel","label","updateBonesFromWorldPositions","visible","getGuidanceText","feedback","join","worldPositions","palmYForward","indexFinger0","clone","sub","palmBase","palmXIndexToRingAcross","ringFinger0","negate","palmZUp","maxCurvature","minCurvature","curvatureSum","finger0","finger1","finger2","finger3","delta01","delta12","delta23","curvature012","dot","curvature123","min","max","avgCurvature","bbox","Box3","expandByPoint","getWorldPosition","abs","worldToPalmBasis","Matrix4","makeBasis","worldToPalmRotation","setFromRotationMatrix","palmToWorldBasis","invert","makeRotationFromQuaternion","extractBasis","quaternion","worldJointPositions","j","parentToWorldBasis","boneYDirection","boneXAcross","prevBoneYDirection","multiplyScalar","boneZUp","worldToBoneBasis","parentToBoneBasis","multiplyMatrices","updateBonesFromWorldPositionsOld"],"mappings":"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","file":"static/js/main.c2dc177f.chunk.js","sourcesContent":["export default \"\"","export default __webpack_public_path__ + \"static/media/gold.6a97cbf3.png\";","export default __webpack_public_path__ + \"static/media/silver.73184856.png\";","export default __webpack_public_path__ + \"static/media/gem.5b1f1ec2.png\";","export default __webpack_public_path__ + \"static/media/band.02e48296.png\";","import circle from \"./resources/cirlce.png\";\n\nimport { useState, useEffect } from \"react\";\nimport { Swiper, SwiperSlide } from \"swiper/react\";\nimport \"swiper/swiper-bundle.min.css\";\nimport \"swiper/swiper.min.css\";\n\nimport iconOne from \"./resources/gold.png\";\nimport iconTwo from \"./resources/silver.png\";\nimport iconRoseGold from \"./resources/rose-gold.png\";\nimport iconWhiteGold from \"./resources/white-gold.png\";\nimport iconPlatinum from \"./resources/platinum.png\";\nimport iconSix from \"./resources/gem.png\";\nimport iconSeven from \"./resources/band.png\";\n\n// Band colors\nconst PINK_GOLD = { assetId: \"17254639-0f89-4146-b8d4-c51aaf0d8170\" };\nconst WHITE_GOLD = { assetId: \"59849d0f-aeb6-45d9-92ec-6fed6daf052f\" };\nconst YELLOW_GOLD = { assetId: \"f31255b1-7f2e-4bf1-985b-eb424b4e843d\" };\nconst PLATINUM = { assetId: \"17bda33e-57e1-457c-95a0-d5b1b39f72ce\" };\nconst SAPPHIRE_COLOR = \"0c3ba6\";\n// Gemstone Colors\nconst RUBY_COLOR = { assetId: \"68f93597-e9d1-4c7a-bb5c-a2c13fcd6da9\" };\nconst SAPPHIRE = { assetId: \"1b57b15c-6e7f-4ac4-a6a6-8d05fefc0f31\" };\nconst EMERALD = { assetId: \"31f582d6-8ee8-4c0a-bd36-c0fcd48ee8cc\" };\nconst DIAMOND = { assetId: \"85e8e466-929b-4e6d-8b1a-f0bb2b25336b\" };\nconst TEST_COLOR = { assetId: \"28c7b63d-9608-41c1-9d68-1f4429706214\" };\n\n// const RUBY_COLOR = { assetId: \"28c7b63d-9608-41c1-9d68-1f4429706214\" };\n// const SAPPHIRE = { assetId: \"28c7b63d-9608-41c1-9d68-1f4429706214\" };\n// const EMERALD = { assetId: \"28c7b63d-9608-41c1-9d68-1f4429706214\" };\n// const DIAMOND = { assetId: \"28c7b63d-9608-41c1-9d68-1f4429706214\" };\n\n// export default function Scroller ({ setGemColor, setBandColor }) {\n// const [swiperIndex, setSwiperIndex] = useState(1);\n// const [swiper, setSwiper] = useState();\n\n// function handleSlideChange (swiper) {\n// setSwiperIndex(swiper.activeIndex);\n// }\n\n// useEffect(() => {\n// if (swiperIndex === 0) {\n// setBandColor(PINK_GOLD);\n// } else if (swiperIndex === 1) {\n// setBandColor(WHITE_GOLD);\n// } else if (swiperIndex === 2) {\n// setBandColor(YELLOW_GOLD);\n// } else if (swiperIndex === 3) {\n// setBandColor(PLATINUM);\n// }\n// }, [swiperIndex]);\n\n// function initSwiper (swiper) {\n// swiper.slideTo(1, 0);\n// }\n// return (\n//
\n// handleSlideChange(swiper)}\n// onSwiper={swiper => {\n// initSwiper(swiper);\n// setSwiper(swiper);\n// }}>\n// {/* Gem */}\n// swiper.slideTo(0, 300)} id={0}>\n// \n// \n// {/* Band */}\n// swiper.slideTo(1, 300)} id={1}>\n// \n// \n// \n// handleSlideChange(swiper)}\n// onSwiper={swiper => {\n// initSwiper(swiper);\n// setSwiper(swiper);\n// }}>\n// swiper.slideTo(0, 300)} id={0}>\n// \n// \n// swiper.slideTo(1, 300)} id={1}>\n// \n// \n// swiper.slideTo(2, 300)} id={2}>\n// \n// {\" \"}\n// swiper.slideTo(3, 300)} id={3}>\n// \n// \n// \n// \n//
\n// );\n// }\n\nexport default function Scroller ({ setGemColor, setBandColor }) {\n const [swiperIndex, setSwiperIndex] = useState(0);\n const [swiper, setSwiper] = useState();\n const [gemSwiper, setGemSwiper] = useState();\n const [bandSwiper, setBandSwiper] = useState();\n const [gemIndex, setGemIndex] = useState(1);\n const [bandIndex, setBandIndex] = useState(0);\n\n function handleSlideChange (swiper) {\n setSwiperIndex(swiper.activeIndex);\n }\n\n function initSwiper (swiper) {\n swiper.slideTo(0, 0);\n }\n\n useEffect(() => {\n if (gemIndex === 0) {\n setGemColor(DIAMOND);\n } else if (gemIndex === 1) {\n setGemColor(RUBY_COLOR);\n } else if (gemIndex === 2) {\n setGemColor(SAPPHIRE);\n } else if (gemIndex === 3) {\n setGemColor(EMERALD);\n } else if (gemIndex === 4) {\n setGemColor(TEST_COLOR);\n }\n }, [gemIndex]);\n\n useEffect(() => {\n if (bandIndex === 0) {\n setBandColor(WHITE_GOLD);\n } else if (bandIndex === 1) {\n setBandColor(PINK_GOLD);\n } else if (bandIndex === 2) {\n setBandColor(YELLOW_GOLD);\n } else if (bandIndex === 3) {\n setBandColor(PLATINUM);\n }\n }, [bandIndex]);\n\n return (\n
\n handleSlideChange(swiper)}\n onSwiper={swiper => {\n initSwiper(swiper);\n setSwiper(swiper);\n }}>\n swiper.slideTo(0, 300)} id={0}>\n \n \n\n swiper.slideTo(1, 300)} id={1}>\n \n \n \n\n \n \n\n {swiperIndex === 0 && (\n setGemIndex(swiper.activeIndex)}\n onSwiper={swiper => {\n swiper.slideTo(gemIndex, 0);\n setGemSwiper(swiper);\n }}>\n {/* Diamond */}\n gemSwiper.slideTo(0, 300)} id={1}>\n \n \n {/* Ruby */}\n gemSwiper.slideTo(1, 300)} id={1}>\n \n \n {/* Sapphire */}\n gemSwiper.slideTo(2, 300)} id={1}>\n \n \n {/* Emerald */}\n gemSwiper.slideTo(2, 300)} id={1}>\n \n \n {/* Test */}\n gemSwiper.slideTo(2, 300)} id={1}>\n \n \n \n )}\n\n {swiperIndex === 1 && (\n setBandIndex(swiper.activeIndex)}\n onSwiper={swiper => {\n swiper.slideTo(bandIndex, 0);\n setBandSwiper(swiper);\n }}>\n {/* White Gold */}\n bandSwiper.slideTo(0, 300)} id={1}>\n \n \n {/* Pink Gold`` */}\n bandSwiper.slideTo(1, 300)} id={1}>\n \n \n {/* Yellow Gold */}\n bandSwiper.slideTo(1, 300)} id={1}>\n \n \n {/* Platinum */}\n bandSwiper.slideTo(1, 300)} id={1}>\n \n \n \n )}\n
\n );\n}\n","export default \"\"","export default \"\"","export default \"\"","export default __webpack_public_path__ + \"static/media/logo.c48f9f36.png\";","import { Suspense } from \"react\";\nimport { Asset, ThreekitSource } from \"@threekit/lignin\";\n\nconst RING_POSITION = 0.2;\nconst RING_SCALE = 0.1;\n\nexport default function Ring ({ position, rotation, scale, proximalBoneLength, handModel, gemColor, bandColor }) {\n return (\n \n \n \n \n \n\n {/* {handModel && (\n \n \n \n \n )} */}\n \n \n \n \n );\n}\n","import { useEffect } from \"react\";\nimport { Vector3, Euler, Quaternion, Bone } from \"three\";\nimport { useMemo } from \"react\";\nimport Ring from \"./ring.js\";\nimport { HandSkeleton, Handedness, getFeatureKey } from \"./HandSkeleton.js\";\nimport { OrbitControls } from \"three/examples/jsm/controls/OrbitControls\";\nimport { useThree } from \"@react-three/fiber\";\nimport { useFrame } from '@react-three/fiber'\n\nconst CameraController = () => {\n const { camera, gl } = useThree();\n useEffect(\n () => {\n const controls = new OrbitControls(camera, gl.domElement);\n controls.minDistance = 3;\n controls.maxDistance = 20;\n return () => {\n controls.dispose();\n };\n },\n [camera, gl]\n );\n return null;\n};\n\nconst ResizeHandler = ({ aspect }) => {\n const { camera } = useThree();\n camera.left = -0.5 * aspect;\n camera.right = 0.5 * aspect;\n camera.top = 0.5;\n camera.bottom = -0.5;\n camera.updateProjectionMatrix(); \n\n return null;\n}\n\nfunction DefaultCamera(){\n const { camera } = useThree();\n\n useEffect(\n () => {\n camera.position.set( 0, 0, -0.5 );\n camera.rotation.set( Math.PI, 0, Math.PI );\n camera.zoom = 1;\n camera.updateProjectionMatrix(); \n },\n [camera]\n );\n return null;\n} \n\n\nexport default function RingFinger({ width, height, prediction, aspect, bandColor, gemColor, updateDisplay}) {\n let leftHandSkeleton = useMemo(() => {\n return new HandSkeleton(Handedness.Left, width, height);\n }, [width, height]);\n useFrame(() => {\n \n })\n\n const bone = useMemo(() => {\n if (prediction.image !== undefined) {\n leftHandSkeleton.update(prediction);\n updateDisplay();\n return leftHandSkeleton.getFeatureBone(getFeatureKey(\"ringFinger\", 1));\n }\n return new Bone();\n }, [prediction]);\n \n let position = new Vector3();\n let rotation = new Quaternion();\n let scale = new Vector3();\n\n let matrixWorld = bone.matrixWorld;\n matrixWorld.decompose(position, rotation, scale);\n\n const ringMediaBone = leftHandSkeleton.getFeatureBone(getFeatureKey(\"ringFinger\", 1))\n let proximalBoneLength = ringMediaBone.position.y;\n\n let rotationEuler = new Euler().setFromQuaternion(rotation);\n\n if (prediction.image && prediction.multiHandLandmarks.length) {\n return (\n \n \n \n \n \n );\n }\n else{\n return(\n \n \n \n \n \n );\n }\n\n}\n","import { forwardRef, useRef, useImperativeHandle, useEffect } from \"react\";\nimport Webcam from \"react-webcam\";\n\nconst TryOnCanvas = forwardRef(({ onImageReady, videoWidth, videoHeight, prediction, isMirrored }, ref) => {\n const webcamRef = useRef();\n const offScreenCanvasRef = useRef();\n const displayCanvasRef = useRef();\n const croppedCanvasRef = useRef();\n const videoAspect = videoWidth / videoHeight;\n\n const videoConstraints = {\n width: videoWidth,\n height: videoHeight,\n facingMode: \"user\",\n };\n\n useImperativeHandle(ref, () => ({\n sendNextImage: () => {\n sendNextImage();\n },\n updateDisplay: () => {\n updateDisplay();\n },\n }));\n\n const updateDisplay = () => {\n if (prediction.image !== undefined) {\n const offscreenCanvas = offScreenCanvasRef.current;\n const displayCtx = displayCanvasRef.current.getContext(\"2d\");\n if (offscreenCanvas.height !== 0) {\n displayCtx.drawImage(offscreenCanvas, 0, 0, videoWidth, videoHeight);\n }\n }\n };\n\n const sendNextImage = () => {\n let video = webcamRef.current.video;\n\n const offscreenCanvas = offScreenCanvasRef.current;\n const offScreenCtx = offscreenCanvas.getContext(\"2d\");\n\n const croppedCanvas = croppedCanvasRef.current;\n const croppedCanvasCtx = croppedCanvas.getContext(\"2d\");\n\n const width = croppedCanvas.height * videoAspect;\n\n const left = (croppedCanvas.width - width) * 0.5;\n const top = 0;\n const height = croppedCanvas.height;\n croppedCanvasCtx.drawImage(video, left, top, width, height);\n\n offScreenCtx.drawImage(video, 0, 0);\n onImageReady(croppedCanvas);\n };\n\n return (\n
\n {\n sendNextImage();\n }}\n videoConstraints={videoConstraints}\n />\n
\n \n
\n
\n \n
\n
\n \n
\n
\n );\n});\n\nexport default TryOnCanvas;\n","import { useState, useEffect, useRef, Suspense, useMemo } from \"react\";\nimport \"./styles.css\";\nimport Scroller from \"./Scoller.js\";\n\nimport \"@mediapipe/hands\";\nimport logo from \"./resources/logo.png\";\nimport * as MediaPipeHands from \"@mediapipe/hands\";\nimport RingFinger from \"./RingFinger\";\nimport TryOnCanvas from \"./TryOnCanvas\";\n\nimport { Canvas } from \"@react-three/fiber\";\nimport { Environment } from \"@react-three/drei\";\n\nconsole.log( \"build 2022-05-16 - 1\");\n\nexport default function App() {\n const [splashScreen, setSplashScreen] = useState(true);\n const [prediction, setPrediction] = useState({});\n const [gemColor, setGemColor] = useState(\"00ff00\");\n const [bandColor, setBandColor] = useState({assetId: '17254639-0f89-4146-b8d4-c51aaf0d8170'});\n const tryOnCanvasRef = useRef();\n\n let videoWidth = 1280,\n videoHeight = 720;\n const videoAspect = videoWidth / videoHeight;\n let isMirrored = true;\n const urlParams = new URLSearchParams(window.location.search);\n\n if (urlParams.get(\"mirror\") === \"false\") {\n isMirrored = false;\n }\n\n let hands = useMemo(() => {\n const hands = new MediaPipeHands.Hands({\n locateFile: (file) => `https://cdn.jsdelivr.net/npm/@mediapipe/hands@0.3.1632795355/${file}`,\n });\n hands.setOptions({ minDetectionConfidence: 0.7, minTrackingConfidence: 0.7 });\n hands.onResults(setPrediction);\n return hands;\n }, [\"hands\"]);\n\n function onImageReady(croppedCanvas) {\n hands.send({ image: croppedCanvas });\n }\n\n useEffect(() => {\n\n if (prediction.image !== undefined) {\n if (splashScreen) {\n setSplashScreen(false);\n }\n setTimeout(() => {\n tryOnCanvasRef.current.sendNextImage();\n }, 10);\n }\n }, [prediction]);\n\n return (\n
\n {splashScreen && (\n
\n \"\"\n
\n )}\n {!splashScreen && }\n \n\n
\n \n {\n camera.left = -0.5 * videoAspect * (isMirrored ? -1 : 1);\n camera.right = 0.5 * videoAspect * (isMirrored ? -1 : 1);\n camera.top = 0.5;\n camera.bottom = -0.5;\n camera.lookAt(0, 0, 1);\n camera.updateProjectionMatrix();\n }}\n orthographic\n camera={{\n near: -300,\n far: 300,\n position: [0, 0, -0.5],\n }}>\n \n {/* */}\n \n\n {/* */}\n {!splashScreen && (\n tryOnCanvasRef.current.updateDisplay()}\n gemColor={gemColor}\n bandColor={bandColor}\n prediction={prediction}\n aspect={(isMirrored ? -1 : 1) * videoAspect}\n width={videoWidth}\n height={videoHeight}\n />\n )}\n \n \n
\n
\n \n );\n}\n","import { render } from \"react-dom\"\nimport React from \"react\"\nimport App from \"./App\"\nimport \"./styles.css\"\n\nrender(, document.getElementById(\"root\"))\n","\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.HandSkeleton = exports.Handedness = exports.convertPoseArrayToWorldFeatures = exports.featureIndexToKey = exports.fromPoseToWorldSpace = exports.getFeatureKey = exports.test = exports.FeatureLength = exports.FeatureNames = exports.FingerNames = void 0;\nvar THREE = require(\"three\");\nvar three_1 = require(\"three\");\nexports.FingerNames = ['thumb', 'indexFinger', 'middleFinger', 'ringFinger', 'pinky'];\nexports.FeatureNames = ['palmBase'].concat(exports.FingerNames);\nexports.FeatureLength = {\n 'palmBase': 1,\n 'thumb': 4,\n 'indexFinger': 4,\n 'middleFinger': 4,\n 'fingFinger': 4,\n 'pinky': 4\n};\nfunction getZAxis(xAxis, yAxis, result) {\n if (result === void 0) { result = new THREE.Vector3(); }\n return result.copy(xAxis).cross(yAxis).normalize();\n}\nfunction getXAxis(yAxis, zAxis, result) {\n if (result === void 0) { result = new THREE.Vector3(); }\n return result.copy(yAxis).cross(zAxis).normalize();\n}\nfunction test() {\n var xAxis = new THREE.Vector3(1, 0, 0);\n var yAxis = new THREE.Vector3(0, 1, 0);\n var zAxis = new THREE.Vector3(0, 0, 1);\n if (!getZAxis(xAxis, yAxis).equals(zAxis))\n throw new Error(\"bad zAxis\");\n if (!getXAxis(yAxis, zAxis).equals(xAxis))\n throw new Error(\"bad xAxis\");\n}\nexports.test = test;\nfunction getFeatureKey(featureName, jointIndex) {\n if (jointIndex === void 0) { jointIndex = undefined; }\n var featureKey = featureName;\n if (jointIndex !== undefined) {\n featureKey += jointIndex;\n }\n return featureKey;\n}\nexports.getFeatureKey = getFeatureKey;\nfunction fromPoseToWorldSpace(posePosition, viewWidth, viewHeight) {\n return new THREE.Vector3(-(posePosition.x - 1 / 2), -(posePosition.y - 1 / 2), posePosition.z * 0.5);\n}\nexports.fromPoseToWorldSpace = fromPoseToWorldSpace;\nexports.featureIndexToKey = {\n 0: 'palmBase',\n 1: 'thumb0',\n 2: 'thumb1',\n 3: 'thumb2',\n 4: 'thumb3',\n 5: 'indexFinger0',\n 6: 'indexFinger1',\n 7: 'indexFinger2',\n 8: 'indexFinger3',\n 9: 'middleFinger0',\n 10: 'middleFinger1',\n 11: 'middleFinger2',\n 12: 'middleFinger3',\n 13: 'ringFinger0',\n 14: 'ringFinger1',\n 15: 'ringFinger2',\n 16: 'ringFinger3',\n 17: 'pinky0',\n 18: 'pinky1',\n 19: 'pinky2',\n 20: 'pinky3'\n};\nfunction convertPoseArrayToWorldFeatures(array, viewWidth, viewHeight) {\n var worldFeatures = {};\n array.forEach(function (value, index) {\n var featureKey = exports.featureIndexToKey[index];\n worldFeatures[featureKey] = fromPoseToWorldSpace(value, viewWidth, viewHeight);\n });\n return worldFeatures;\n}\nexports.convertPoseArrayToWorldFeatures = convertPoseArrayToWorldFeatures;\nvar Handedness;\n(function (Handedness) {\n Handedness[Handedness[\"Left\"] = 0] = \"Left\";\n Handedness[Handedness[\"Right\"] = 1] = \"Right\";\n})(Handedness = exports.Handedness || (exports.Handedness = {}));\n;\nfunction getHandednessFromLabel(handednessLabel) {\n switch (handednessLabel) {\n case 'Right': return Handedness.Right;\n case 'Left': return Handedness.Left;\n default: throw new Error(\"Bad label \".concat(handednessLabel));\n }\n}\nvar HandSkeleton = /** @class */ (function () {\n function HandSkeleton(handedness, viewWidth, viewHeight) {\n var _this = this;\n this.handedness = handedness;\n this.viewWidth = viewWidth;\n this.viewHeight = viewHeight;\n this.root = new THREE.Group();\n this.debugAxes = false;\n this.debugSpheres = true;\n this.debugSkeleton = false;\n this.debugRadius = 0.1;\n this.featureKeyToBoneMap = {}; // incrementally cache bones by bone names.\n this.fingerCurl = 0;\n this.palmFlatness = 1;\n this.handMargin = 0.5;\n this.numberOfHands = 0;\n this.rightHandedness = false;\n this.root.name = \"root\";\n test();\n var urlParams = new URLSearchParams(window.location.search);\n if (urlParams.get('axes')) {\n this.debugAxes = true;\n }\n if (urlParams.get('skeleton')) {\n this.debugSkeleton = true;\n }\n var palmBaseBone = new THREE.Bone();\n palmBaseBone.name = getFeatureKey('palmBase');\n this.root.add(palmBaseBone);\n exports.FingerNames.forEach(function (fingerName, fingerIndex) {\n var jointParentBone = palmBaseBone;\n for (var jointIndex = 0; jointIndex < 4; jointIndex++) {\n var jointBone = new THREE.Bone();\n jointBone.name = getFeatureKey(fingerName, jointIndex);\n jointParentBone.add(jointBone);\n jointParentBone = jointBone;\n }\n });\n // collect bones, create lookup map and set common options\n var bones = [];\n this.root.traverse(function (object) {\n if (object.type !== 'Bone')\n return; // ignore non-bones.\n var bone = object;\n bone.matrixAutoUpdate = true;\n if (_this.debugAxes) {\n //if( bone.name == \"palmBase\") {\n var axesHelper = new THREE.AxesHelper(_this.debugRadius);\n bone.add(axesHelper);\n //}\n }\n bones.push(bone);\n _this.featureKeyToBoneMap[bone.name] = bone;\n });\n if (this.debugSkeleton) {\n var skeletonHelper = new THREE.SkeletonHelper(palmBaseBone);\n this.root.add(skeletonHelper);\n }\n this.skeleton = new THREE.Skeleton(bones);\n }\n HandSkeleton.prototype.getFeatureBone = function (featureKey) {\n return this.featureKeyToBoneMap[featureKey];\n };\n HandSkeleton.prototype.update = function (results) {\n var _this = this;\n var found = false;\n this.numberOfHands = 0;\n if (results.multiHandedness !== undefined) {\n this.numberOfHands = results.multiHandedness.length;\n results.multiHandedness.forEach(function (multiHandedness, index) {\n // if( this.handedness === getHandednessFromLabel( multiHandedness.label ) ) {\n if (!found) {\n // console.log('results.multiHandedness', results.multiHandedness);\n //console.log(results);\n var multiHandLandmarks = results.multiHandLandmarks[index];\n // console.log('multiHandLandmarks', multiHandLandmarks);\n var worldFeatures = convertPoseArrayToWorldFeatures(multiHandLandmarks, _this.viewWidth, _this.viewHeight);\n _this.handedness = getHandednessFromLabel(results.multiHandedness[index].label);\n // console.log(\"this.handedness\", _this.handedness);\n _this.updateBonesFromWorldPositions(worldFeatures);\n found = true;\n }\n // }\n });\n }\n this.root.visible = found;\n };\n HandSkeleton.prototype.getGuidanceText = function () {\n var feedback = [];\n // most important last, least important first.\n if (this.fingerCurl > 0.25) {\n feedback = [\"Uncurl Fingers\"]; // (curl=${this.fingerCurl.toFixed(2)})`];\n }\n if (this.palmFlatness < 0.6) {\n feedback = [\"Flatten Palm\"]; // (flatness=${this.palmFlatness.toFixed(2)})`];\n }\n if (this.handMargin <= 0.12) {\n feedback = [\"Fit Hand in View\"]; // (margin=${this.handMargin.toFixed(2)})`];\n }\n if (this.numberOfHands === 0) {\n feedback = ['No Hand Found'];\n }\n if (this.numberOfHands === 2) {\n feedback = ['Too Many Hands'];\n }\n //if( this.handedness === Handedness.Right ) {\n // feedback = ['Use Left Hand'];\n //}\n return feedback.join(', ');\n };\n HandSkeleton.prototype.updateBonesFromWorldPositions = function (worldPositions) {\n var _this = this;\n var palmToIndexFinger0 = worldPositions.indexFinger0.clone().sub(worldPositions.palmBase);\n var palmYForward = palmToIndexFinger0.clone().normalize();\n var palmXIndexToRingAcross = worldPositions.indexFinger0.clone().sub(worldPositions.ringFinger0).normalize();\n if (this.handedness === Handedness.Left) {\n palmXIndexToRingAcross.negate();\n }\n var palmZUp = palmYForward.clone().cross(palmXIndexToRingAcross);\n getZAxis(palmXIndexToRingAcross, palmYForward, palmZUp);\n // if right hand, this needs to be negated.\n var maxCurvature = 0, minCurvature = 0, curvatureSum = 0;\n exports.FingerNames.forEach(function (fingerName, fingerIndex) {\n // 4 joint positions\n var finger0 = worldPositions[getFeatureKey(fingerName, 0)];\n var finger1 = worldPositions[getFeatureKey(fingerName, 1)];\n var finger2 = worldPositions[getFeatureKey(fingerName, 2)];\n var finger3 = worldPositions[getFeatureKey(fingerName, 3)];\n // 3 digit segments\n var delta01 = finger1.clone().sub(finger0).normalize();\n var delta12 = finger2.clone().sub(finger1).normalize();\n var delta23 = finger3.clone().sub(finger2).normalize();\n // 2 joint curvatures\n var curvature012 = delta01.clone().cross(delta12).dot(palmXIndexToRingAcross);\n var curvature123 = delta12.clone().cross(delta23).dot(palmXIndexToRingAcross);\n minCurvature = Math.min(minCurvature, curvature012, curvature123);\n maxCurvature = Math.max(maxCurvature, curvature012, curvature123);\n curvatureSum += curvature012 + curvature123;\n });\n var avgCurvature = curvatureSum / 8;\n // negative curl means it is right hand.\n // if (avgCurvature > 0.0) {\n // palmXRightAcross.negate();\n // }\n // const palmZUp = new THREE.Vector3();\n // getZAxis(palmXRightAcross, palmYForward, palmZUp);\n // ensure orthogonal\n getXAxis(palmYForward, palmZUp, palmXIndexToRingAcross);\n var bbox = new THREE.Box3();\n var bones = [];\n this.root.traverse(function (object) {\n if (object.type !== 'Bone')\n return; // ignore non-bones.\n bbox.expandByPoint(object.getWorldPosition(new THREE.Vector3(0, 0, 0)));\n });\n this.handMargin = 0.5 - Math.max(Math.abs(bbox.min.x), Math.abs(bbox.max.x), Math.abs(bbox.min.y), Math.abs(bbox.max.y));\n this.fingerCurl = Math.abs(avgCurvature);\n this.palmFlatness = Math.abs(palmZUp.z);\n // determine palm orientation\n var worldToPalmBasis = new THREE.Matrix4().makeBasis(palmXIndexToRingAcross, palmYForward, palmZUp);\n // console.log( 'worldToPalmBasis', worldToPalmBasis );\n var worldToPalmRotation = new THREE.Quaternion().setFromRotationMatrix(worldToPalmBasis);\n worldToPalmRotation.normalize();\n var palmToWorldBasis = worldToPalmBasis.clone().invert();\n worldToPalmBasis.makeRotationFromQuaternion(worldToPalmRotation);\n worldToPalmBasis.extractBasis(palmXIndexToRingAcross, palmYForward, palmZUp);\n // console.log( 'worldToPalmBasis basics', palmXAcross, palmYForward, palmZUp );\n var palmBase = this.getFeatureBone('palmBase');\n palmBase.quaternion.copy(worldToPalmRotation);\n palmBase.position.copy(worldPositions.palmBase);\n exports.FingerNames.forEach(function (fingerName, fingerIndex) {\n var worldJointPositions = [worldPositions.palmBase];\n for (var j = 0; j < 4; j++) {\n worldJointPositions.push(worldPositions[getFeatureKey(fingerName, j)]);\n }\n var parentToWorldBasis = palmToWorldBasis.clone();\n for (var j = 0; j < worldJointPositions.length - 1; j++) {\n var bone = _this.getFeatureBone(getFeatureKey(fingerName, j));\n if (j - 1 >= 0) {\n bone.position.y = worldJointPositions[j].clone().sub(worldJointPositions[j - 1]).length();\n }\n else {\n bone.position.y = 0;\n }\n var boneYDirection = new THREE.Vector3(0, 1, 0);\n if ((j + 1) < worldJointPositions.length) {\n boneYDirection.copy(worldJointPositions[j + 1]).sub(worldJointPositions[j]).normalize();\n }\n var boneXAcross = palmXIndexToRingAcross;\n if (j > 1 && (j + 1) < worldJointPositions.length) {\n var prevBoneYDirection = new three_1.Vector3();\n prevBoneYDirection.copy(worldJointPositions[j]).sub(worldJointPositions[j - 1]).normalize();\n boneXAcross = boneYDirection.clone().cross(prevBoneYDirection).normalize();\n if (boneXAcross.dot(palmXIndexToRingAcross) < 0) {\n boneXAcross.multiplyScalar(-1);\n }\n }\n //const boneXAcross = palmXAcross;\n var boneZUp = new THREE.Vector3();\n getZAxis(boneXAcross, boneYDirection, boneZUp);\n getXAxis(boneYDirection, boneZUp, boneXAcross); // ensure orthogonality\n var worldToBoneBasis = new THREE.Matrix4().makeBasis(boneXAcross, boneYDirection, boneZUp);\n var parentToBoneBasis = new THREE.Matrix4().multiplyMatrices(parentToWorldBasis, worldToBoneBasis);\n parentToWorldBasis.copy(worldToBoneBasis).invert();\n bone.quaternion.setFromRotationMatrix(parentToBoneBasis);\n }\n });\n };\n HandSkeleton.prototype.updateBonesFromWorldPositionsOld = function (worldPositions) {\n var _this = this;\n var palmToIndexFinger0 = worldPositions.indexFinger0.clone().sub(worldPositions.palmBase);\n var palmYForward = palmToIndexFinger0.clone().normalize();\n var palmXIndexToRingAcross = worldPositions.indexFinger0.clone().sub(worldPositions.ringFinger0).normalize();\n if (this.handedness === Handedness.Right) {\n palmXIndexToRingAcross.negate();\n }\n var palmZUp = palmYForward.clone().cross(palmXIndexToRingAcross);\n getZAxis(palmXIndexToRingAcross, palmYForward, palmZUp);\n // if right hand, this needs to be negated.\n var maxCurvature = 0, minCurvature = 0, curvatureSum = 0;\n exports.FingerNames.forEach(function (fingerName, fingerIndex) {\n // 4 joint positions\n var finger0 = worldPositions[getFeatureKey(fingerName, 0)];\n var finger1 = worldPositions[getFeatureKey(fingerName, 1)];\n var finger2 = worldPositions[getFeatureKey(fingerName, 2)];\n var finger3 = worldPositions[getFeatureKey(fingerName, 3)];\n // 3 digit segments\n var delta01 = finger1.clone().sub(finger0).normalize();\n var delta12 = finger2.clone().sub(finger1).normalize();\n var delta23 = finger3.clone().sub(finger2).normalize();\n // 2 joint curvatures\n var curvature012 = delta01.clone().cross(delta12).dot(palmXIndexToRingAcross);\n var curvature123 = delta12.clone().cross(delta23).dot(palmXIndexToRingAcross);\n minCurvature = Math.min(minCurvature, curvature012, curvature123);\n maxCurvature = Math.max(maxCurvature, curvature012, curvature123);\n curvatureSum += curvature012 + curvature123;\n });\n var avgCurvature = curvatureSum / 8;\n // negative curl means it is right hand.\n // if (avgCurvature > 0.0) {\n // palmXRightAcross.negate();\n // }\n // const palmZUp = new THREE.Vector3();\n // getZAxis(palmXRightAcross, palmYForward, palmZUp);\n // ensure orthogonal\n getXAxis(palmYForward, palmZUp, palmXIndexToRingAcross);\n var bbox = new THREE.Box3();\n var bones = [];\n this.root.traverse(function (object) {\n if (object.type !== 'Bone')\n return; // ignore non-bones.\n bbox.expandByPoint(object.getWorldPosition(new THREE.Vector3(0, 0, 0)));\n });\n this.handMargin = 0.5 - Math.max(Math.abs(bbox.min.x), Math.abs(bbox.max.x), Math.abs(bbox.min.y), Math.abs(bbox.max.y));\n this.fingerCurl = Math.abs(avgCurvature);\n this.palmFlatness = Math.abs(palmZUp.z);\n // determine palm orientation\n var worldToPalmBasis = new THREE.Matrix4().makeBasis(palmXIndexToRingAcross, palmYForward, palmZUp);\n // console.log( 'worldToPalmBasis', worldToPalmBasis );\n var worldToPalmRotation = new THREE.Quaternion().setFromRotationMatrix(worldToPalmBasis);\n worldToPalmRotation.normalize();\n var palmToWorldBasis = worldToPalmBasis.clone().invert();\n worldToPalmBasis.makeRotationFromQuaternion(worldToPalmRotation);\n worldToPalmBasis.extractBasis(palmXIndexToRingAcross, palmYForward, palmZUp);\n // console.log( 'worldToPalmBasis basics', palmXAcross, palmYForward, palmZUp );\n var palmBase = this.getFeatureBone('palmBase');\n palmBase.quaternion.copy(worldToPalmRotation);\n palmBase.position.copy(worldPositions.palmBase);\n exports.FingerNames.forEach(function (fingerName, fingerIndex) {\n var worldJointPositions = [worldPositions.palmBase];\n for (var j = 0; j < 4; j++) {\n worldJointPositions.push(worldPositions[getFeatureKey(fingerName, j)]);\n }\n var parentToWorldBasis = palmToWorldBasis.clone();\n for (var j = 0; j < worldJointPositions.length - 1; j++) {\n var bone = _this.getFeatureBone(getFeatureKey(fingerName, j));\n if (j - 1 >= 0) {\n bone.position.y = worldJointPositions[j].clone().sub(worldJointPositions[j - 1]).length();\n }\n else {\n bone.position.y = 0;\n }\n var boneYDirection = new THREE.Vector3(0, 1, 0);\n if ((j + 1) < worldJointPositions.length) {\n boneYDirection.copy(worldJointPositions[j + 1]).sub(worldJointPositions[j]).normalize();\n }\n var boneXAcross = palmXIndexToRingAcross;\n if (j > 1 && (j + 1) < worldJointPositions.length) {\n var prevBoneYDirection = new three_1.Vector3();\n prevBoneYDirection.copy(worldJointPositions[j]).sub(worldJointPositions[j - 1]).normalize();\n boneXAcross = boneYDirection.clone().cross(prevBoneYDirection).normalize();\n if (boneXAcross.dot(palmXIndexToRingAcross) < 0) {\n boneXAcross.multiplyScalar(-1);\n }\n }\n //const boneXAcross = palmXAcross;\n var boneZUp = new THREE.Vector3();\n getZAxis(boneXAcross, boneYDirection, boneZUp);\n getXAxis(boneYDirection, boneZUp, boneXAcross); // ensure orthogonality\n var worldToBoneBasis = new THREE.Matrix4().makeBasis(boneXAcross, boneYDirection, boneZUp);\n var parentToBoneBasis = new THREE.Matrix4().multiplyMatrices(parentToWorldBasis, worldToBoneBasis);\n parentToWorldBasis.copy(worldToBoneBasis).invert();\n bone.quaternion.setFromRotationMatrix(parentToBoneBasis);\n }\n });\n };\n return HandSkeleton;\n}());\nexports.HandSkeleton = HandSkeleton;\n"],"sourceRoot":""}