forked from Github/frigate
Motion review playback optimizations (#10659)
* handle motion timestamps with ranges * check for overlaps when checking segment for events * rename motion color vars to significant_motion for consistency * safelist significant_motion * rename vars for clarity and use timeout instead of interval
This commit is contained in:
@@ -4,8 +4,6 @@ import {
|
||||
useMotionActivity,
|
||||
} from "@/api/ws";
|
||||
import { CameraConfig } from "@/types/frigateConfig";
|
||||
import { MotionData, ReviewSegment } from "@/types/review";
|
||||
import { TimeRange } from "@/types/timeline";
|
||||
import { useEffect, useMemo, useState } from "react";
|
||||
|
||||
type useCameraActivityReturn = {
|
||||
@@ -68,57 +66,3 @@ export function useCameraActivity(
|
||||
: false,
|
||||
};
|
||||
}
|
||||
|
||||
export function useCameraMotionTimestamps(
|
||||
timeRange: TimeRange,
|
||||
motionOnly: boolean,
|
||||
events: ReviewSegment[],
|
||||
motion: MotionData[],
|
||||
) {
|
||||
const timestamps = useMemo(() => {
|
||||
const seekableTimestamps = [];
|
||||
let lastEventIdx = 0;
|
||||
let lastMotionIdx = 0;
|
||||
|
||||
for (let i = timeRange.after; i <= timeRange.before; i += 0.5) {
|
||||
if (!motionOnly) {
|
||||
seekableTimestamps.push(i);
|
||||
} else {
|
||||
const relevantEventIdx = events.findIndex((seg, segIdx) => {
|
||||
if (segIdx < lastEventIdx) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return seg.start_time <= i && seg.end_time >= i;
|
||||
});
|
||||
|
||||
if (relevantEventIdx != -1) {
|
||||
lastEventIdx = relevantEventIdx;
|
||||
continue;
|
||||
}
|
||||
|
||||
const relevantMotionIdx = motion.findIndex((mot, motIdx) => {
|
||||
if (motIdx < lastMotionIdx) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return mot.start_time <= i && mot.start_time + 15 >= i;
|
||||
});
|
||||
|
||||
if (relevantMotionIdx == -1 || motion[relevantMotionIdx].motion == 0) {
|
||||
if (relevantMotionIdx != -1) {
|
||||
lastMotionIdx = relevantMotionIdx;
|
||||
}
|
||||
|
||||
continue;
|
||||
}
|
||||
|
||||
seekableTimestamps.push(i);
|
||||
}
|
||||
}
|
||||
|
||||
return seekableTimestamps;
|
||||
}, [timeRange, motionOnly, events, motion]);
|
||||
|
||||
return timestamps;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user