Skip to content

Commit

Permalink
[RSDK-9538] - Throttle frame fetches by configured framerate (#30)
Browse files Browse the repository at this point in the history
* Throttle frame fetches by configured framerate

* Update comment
  • Loading branch information
seanavery authored Dec 16, 2024
1 parent e892656 commit b06d495
Showing 1 changed file with 19 additions and 17 deletions.
36 changes: 19 additions & 17 deletions cam/cam.go
Original file line number Diff line number Diff line change
Expand Up @@ -333,29 +333,31 @@ func (vs *videostore) Properties(_ context.Context) (camera.Properties, error) {
return camera.Properties{}, nil
}

// fetchFrames reads frames from the camera and stores the decoded image
// in the latestFrame atomic pointer. This routine runs as fast as possible
// to keep the latest frame up to date.
// fetchFrames reads frames from the camera at the framerate interval
// and stores the decoded image in the latestFrame atomic pointer.
func (vs *videostore) fetchFrames(ctx context.Context) {
frameInterval := time.Second / time.Duration(vs.conf.Properties.Framerate)
ticker := time.NewTicker(frameInterval)
defer ticker.Stop()
for {
select {
case <-ctx.Done():
return
default:
}
frame, err := camera.DecodeImageFromCamera(ctx, rutils.MimeTypeJPEG, nil, vs.cam)
if err != nil {
vs.logger.Warn("failed to get frame from camera", err)
time.Sleep(retryInterval * time.Second)
continue
}
lazyImage, ok := frame.(*rimage.LazyEncodedImage)
if !ok {
vs.logger.Error("frame is not of type *rimage.LazyEncodedImage")
return
case <-ticker.C:
frame, err := camera.DecodeImageFromCamera(ctx, rutils.MimeTypeJPEG, nil, vs.cam)
if err != nil {
vs.logger.Warn("failed to get frame from camera", err)
time.Sleep(retryInterval * time.Second)
continue
}
lazyImage, ok := frame.(*rimage.LazyEncodedImage)
if !ok {
vs.logger.Error("frame is not of type *rimage.LazyEncodedImage")
return
}
decodedImage := lazyImage.DecodedImage()
vs.latestFrame.Store(&decodedImage)
}
decodedImage := lazyImage.DecodedImage()
vs.latestFrame.Store(&decodedImage)
}
}

Expand Down

0 comments on commit b06d495

Please sign in to comment.