123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148 |
- using System.Collections;
- using System.Collections.Generic;
- using UnityEngine;
- using sl;
- public class DetectionFrame
- {
- private ObjectsFrameSDK objectsFrame;
-
-
-
-
- public ObjectsFrameSDK rawObjectsFrame
- {
- get
- {
- return objectsFrame;
- }
- }
-
-
-
- public ulong timestamp
- {
- get
- {
- return objectsFrame.timestamp;
- }
- }
- private int frameDetected = -1;
-
-
-
-
- public int frameCountAtDetection
- {
- get
- {
- return frameDetected;
- }
- }
-
-
-
-
- public int objectCount
- {
- get
- {
- return objectsFrame.numObject;
- }
- }
-
-
-
- public ZEDManager detectingZEDManager;
- private List<DetectedObject> detObjects = new List<DetectedObject>();
-
-
-
- public List<DetectedObject> detectedObjects
- {
- get
- {
- return detObjects;
- }
- }
-
-
-
-
-
- public DetectionFrame(ObjectsFrameSDK oframe, ZEDManager detectingmanager)
- {
- objectsFrame = oframe;
- detectingZEDManager = detectingmanager;
- frameDetected = Time.frameCount;
- Vector3 campos = detectingmanager.GetLeftCameraTransform().position;
- Quaternion camrot = detectingmanager.GetLeftCameraTransform().rotation;
- for (int i = 0; i < oframe.numObject; i++)
- {
- DetectedObject dobj = new DetectedObject(oframe.objectData[i], detectingmanager, campos, camrot);
- detObjects.Add(dobj);
- }
- }
-
-
-
-
-
-
-
-
-
-
- public List<DetectedObject> GetFilteredObjectList(bool tracking_ok, bool tracking_searching, bool tracking_off, float confidencemin = 0)
- {
- List<DetectedObject> filteredobjects = new List<DetectedObject>();
- foreach(DetectedObject dobj in detObjects)
- {
- if (dobj.confidence < confidencemin && dobj.confidence != -1) continue;
- switch (dobj.trackingState)
- {
- case OBJECT_TRACK_STATE.OK:
- if (tracking_ok) filteredobjects.Add(dobj);
- break;
- case OBJECT_TRACK_STATE.SEARCHING:
- if (tracking_searching) filteredobjects.Add(dobj);
- break;
- case OBJECT_TRACK_STATE.OFF:
- if (tracking_off) filteredobjects.Add(dobj);
- break;
- }
- }
- return filteredobjects;
- }
-
-
-
-
- public void CleanUpAllObjects()
- {
- foreach(DetectedObject dobj in detObjects)
- {
- dobj.CleanUpTextures();
- }
- }
- }
|