add(face-landmarks): max faces detected config and default value (#11625)

* fix(face-landmarks): set max detected faces up to 4

* add(face-landmarks): config for max faces detected

* fix(config.js): default value for capture interval face-landmarks

* add missing coma
This commit is contained in:
Gabriel Borlea 2022-06-08 20:28:41 +03:00 committed by GitHub
parent 13194ddfba
commit 38011e537a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 21 additions and 9 deletions

View File

@ -779,7 +779,7 @@ var config = {
// enableEmailInStats: false, // enableEmailInStats: false,
// faceLandmarks: { // faceLandmarks: {
// // Enables sharing your face cordinates. Used for centering faces within a video. // // Enables sharing your face coordinates. Used for centering faces within a video.
// enableFaceCentering: false, // enableFaceCentering: false,
// // Enables detecting face expressions and sharing data with other participants // // Enables detecting face expressions and sharing data with other participants
@ -791,8 +791,11 @@ var config = {
// // Minimum required face movement percentage threshold for sending new face centering coordinates data. // // Minimum required face movement percentage threshold for sending new face centering coordinates data.
// faceCenteringThreshold: 10, // faceCenteringThreshold: 10,
// // Miliseconds for processing a new image capture in order to detect face coordinates if they exist. // // Milliseconds for processing a new image capture in order to detect face coordinates if they exist.
// captureInterval: 100 // captureInterval: 1000,
// // Maximum number of faces that can be detected from a video track.
// maxFacesDetected: 4
// }, // },
// Controls the percentage of automatic feedback shown to participants when callstats is enabled. // Controls the percentage of automatic feedback shown to participants when callstats is enabled.

View File

@ -21,7 +21,8 @@ type FaceBox = {
type InitInput = { type InitInput = {
baseUrl: string, baseUrl: string,
detectionTypes: string[] detectionTypes: string[],
maxFacesDetected?: number
} }
type DetectOutput = { type DetectOutput = {
@ -44,6 +45,7 @@ export class HumanHelper implements FaceLandmarksHelper {
protected human: Human | undefined; protected human: Human | undefined;
protected faceDetectionTypes: string[]; protected faceDetectionTypes: string[];
protected baseUrl: string; protected baseUrl: string;
protected maxFacesDetected?: number;
private detectionInProgress = false; private detectionInProgress = false;
private lastValidFaceBox: FaceBox | undefined; private lastValidFaceBox: FaceBox | undefined;
/** /**
@ -59,11 +61,12 @@ export class HumanHelper implements FaceLandmarksHelper {
deallocate: true, deallocate: true,
filter: { enabled: false }, filter: { enabled: false },
face: { face: {
enabled: true, enabled: false,
detector: { detector: {
enabled: false, enabled: false,
rotation: false, rotation: false,
modelPath: 'blazeface-front.json' modelPath: 'blazeface-front.json',
maxDetected: 4
}, },
mesh: { enabled: false }, mesh: { enabled: false },
iris: { enabled: false }, iris: { enabled: false },
@ -79,9 +82,10 @@ export class HumanHelper implements FaceLandmarksHelper {
segmentation: { enabled: false } segmentation: { enabled: false }
}; };
constructor({ baseUrl, detectionTypes }: InitInput) { constructor({ baseUrl, detectionTypes, maxFacesDetected }: InitInput) {
this.faceDetectionTypes = detectionTypes; this.faceDetectionTypes = detectionTypes;
this.baseUrl = baseUrl; this.baseUrl = baseUrl;
this.maxFacesDetected = maxFacesDetected;
this.init(); this.init();
} }
@ -97,7 +101,11 @@ export class HumanHelper implements FaceLandmarksHelper {
if (this.faceDetectionTypes.length > 0 && this.config.face) { if (this.faceDetectionTypes.length > 0 && this.config.face) {
this.config.face.enabled = true this.config.face.enabled = true
} }
if (this.maxFacesDetected && this.config.face?.detector) {
this.config.face.detector.maxDetected = this.maxFacesDetected;
}
if (this.faceDetectionTypes.includes(DETECTION_TYPES.FACE_BOX) && this.config.face?.detector) { if (this.faceDetectionTypes.includes(DETECTION_TYPES.FACE_BOX) && this.config.face?.detector) {
this.config.face.detector.enabled = true; this.config.face.detector.enabled = true;

View File

@ -140,7 +140,8 @@ export function loadWorker() {
worker.postMessage({ worker.postMessage({
type: INIT_WORKER, type: INIT_WORKER,
baseUrl, baseUrl,
detectionTypes detectionTypes,
maxFacesDetected: faceLandmarks?.maxFacesDetected
}); });
dispatch(startFaceLandmarksDetection()); dispatch(startFaceLandmarksDetection());