@react-three/drei
Version:
useful add-ons for react-three-fiber
50 lines (46 loc) • 1.77 kB
JavaScript
import * as React from 'react';
import { forwardRef, useEffect, useImperativeHandle, useContext, createContext } from 'react';
import { suspend, clear } from 'suspend-react';
/* eslint react-hooks/exhaustive-deps: 1 */
const FaceLandmarkerContext = /* @__PURE__ */createContext({});
const FaceLandmarkerDefaults = {
basePath: 'https://cdn.jsdelivr.net/npm/@mediapipe/tasks-vision@0.10.17/wasm',
options: {
baseOptions: {
modelAssetPath: 'https://storage.googleapis.com/mediapipe-models/face_landmarker/face_landmarker/float16/1/face_landmarker.task',
delegate: 'GPU'
},
runningMode: 'VIDEO',
outputFaceBlendshapes: true,
outputFacialTransformationMatrixes: true
}
};
const FaceLandmarker = /*#__PURE__*/forwardRef(({
basePath = FaceLandmarkerDefaults.basePath,
options = FaceLandmarkerDefaults.options,
children
}, fref) => {
const opts = JSON.stringify(options);
const faceLandmarker = suspend(async () => {
const {
FilesetResolver,
FaceLandmarker
} = await import('@mediapipe/tasks-vision');
const vision = await FilesetResolver.forVisionTasks(basePath);
return FaceLandmarker.createFromOptions(vision, options);
}, [basePath, opts]);
useEffect(() => {
return () => {
faceLandmarker == null || faceLandmarker.close();
clear([basePath, opts]);
};
}, [faceLandmarker, basePath, opts]);
useImperativeHandle(fref, () => faceLandmarker, [faceLandmarker]); // expose faceLandmarker through ref
return /*#__PURE__*/React.createElement(FaceLandmarkerContext.Provider, {
value: faceLandmarker
}, children);
});
function useFaceLandmarker() {
return useContext(FaceLandmarkerContext);
}
export { FaceLandmarker, FaceLandmarkerDefaults, useFaceLandmarker };