UNPKG

@vladmandic/human

Version:

Human: AI-powered 3D Face Detection & Rotation Tracking, Face Description & Recognition, Body Pose Tracking, 3D Hand & Finger Tracking, Iris Analysis, Age & Gender & Emotion Prediction, Gesture Recognition

52 lines (50 loc) 2.5 kB
import { mergeDeep } from '../util/util'; import { getCanvasContext, rect, point, curves, colorDepth, replace, labels } from './primitives'; import { options } from './options'; import type { BodyResult } from '../result'; import type { AnyCanvas, DrawOptions } from '../exports'; /** draw detected bodies */ export function body(inCanvas: AnyCanvas, result: BodyResult[], drawOptions?: Partial<DrawOptions>) { const localOptions: DrawOptions = mergeDeep(options, drawOptions); if (!result || !inCanvas) return; const ctx = getCanvasContext(inCanvas) as CanvasRenderingContext2D; if (!ctx) return; ctx.lineJoin = 'round'; for (let i = 0; i < result.length; i++) { ctx.strokeStyle = localOptions.color; ctx.fillStyle = localOptions.color; ctx.lineWidth = localOptions.lineWidth; ctx.font = localOptions.font; if (localOptions.drawBoxes && result[i].box && result[i].box.length === 4) { rect(ctx, result[i].box[0], result[i].box[1], result[i].box[2], result[i].box[3], localOptions); if (localOptions.drawLabels && (localOptions.bodyLabels?.length > 0)) { let l = localOptions.bodyLabels.slice(); l = replace(l, '[id]', result[i].id.toFixed(0)); l = replace(l, '[score]', 100 * result[i].score); labels(ctx, l, result[i].box[0], result[i].box[1], localOptions); } } if (localOptions.drawPoints && result[i].keypoints) { for (let pt = 0; pt < result[i].keypoints.length; pt++) { if (!result[i].keypoints[pt].score || (result[i].keypoints[pt].score === 0)) continue; ctx.fillStyle = colorDepth(result[i].keypoints[pt].position[2], localOptions); point(ctx, result[i].keypoints[pt].position[0], result[i].keypoints[pt].position[1], 0, localOptions); } } if (localOptions.drawLabels && (localOptions.bodyPartLabels?.length > 0) && result[i].keypoints) { ctx.font = localOptions.font; for (const pt of result[i].keypoints) { if (!pt.score || (pt.score === 0)) continue; let l = localOptions.bodyPartLabels.slice(); l = replace(l, '[label]', pt.part); l = replace(l, '[score]', 100 * pt.score); labels(ctx, l, pt.position[0], pt.position[1], localOptions); } } if (localOptions.drawPolygons && result[i].keypoints && result[i].annotations) { for (const part of Object.values(result[i].annotations)) { for (const connected of part) curves(ctx, connected, localOptions); } } } }