manually grab from cameras
This commit is contained in:
parent
e9b195674c
commit
aa265565f2
@ -1,10 +1,12 @@
|
||||
#include "dualcamgrabber.h"
|
||||
#include <iostream>
|
||||
#include <pylon/PylonIncludes.h>
|
||||
#include <stitchimage.h>
|
||||
|
||||
void DualcamGrabber::run() {
|
||||
stop_request = false;
|
||||
size_t framecount = 0;
|
||||
size_t counter = 0;
|
||||
|
||||
if (wrapper->isOpen()) {
|
||||
Pylon::CInstantCameraArray &cameras = wrapper->getCameraArray();
|
||||
wrapper->frameRate(static_cast<uint>(framerate));
|
||||
@ -12,17 +14,29 @@ void DualcamGrabber::run() {
|
||||
wrapper->gain(gain);
|
||||
cameras.StartGrabbing();
|
||||
Pylon::CGrabResultPtr frame0, frame1;
|
||||
Pylon::CPylonImage leftImage;
|
||||
Pylon::CPylonImage rightImage;
|
||||
Pylon::CPylonImage stitchedImage;
|
||||
std::string errorMessage = "";
|
||||
|
||||
while (cameras.IsGrabbing() && !stop_request) {
|
||||
MyImage *img = new MyImage();
|
||||
cameras.RetrieveResult( 5000, framecount % 2 == 0 ? frame0 : frame1, Pylon::TimeoutHandling_ThrowException );
|
||||
img->setFrame(framecount % 2 == 0 ? frame0 : frame1);
|
||||
if (framecount % 2 == 0) {
|
||||
buffer0->push(img);
|
||||
} else {
|
||||
buffer1->push(img);
|
||||
cameras[0].RetrieveResult( 5000, frame0, Pylon::TimeoutHandling_ThrowException );
|
||||
cameras[1].RetrieveResult( 5000, frame1, Pylon::TimeoutHandling_ThrowException );
|
||||
|
||||
leftImage.AttachGrabResultBuffer( frame0 );
|
||||
rightImage.AttachGrabResultBuffer( frame1 );
|
||||
|
||||
if (leftImage.IsValid() && rightImage.IsValid()) {
|
||||
try {
|
||||
StitchImage::StitchToRight(leftImage, rightImage, &stitchedImage, errorMessage);
|
||||
img->setFrame(stitchedImage);
|
||||
buffer->push(img);
|
||||
} catch(const std::exception& e) {
|
||||
std::cerr << e.what() << '\n';
|
||||
}
|
||||
}
|
||||
framecount += 1;
|
||||
counter += 1;
|
||||
}
|
||||
cameras.StopGrabbing();
|
||||
}
|
||||
|
@ -10,8 +10,8 @@ class DualcamGrabber : public QThread
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
DualcamGrabber(DualcamWrapper *wrapper, ImageBuffer *buffer0, ImageBuffer * buffer1, int framerate, QObject *parent = nullptr) :
|
||||
QThread(parent), wrapper(wrapper), buffer0(buffer0), buffer1(buffer1), framerate(framerate) {}
|
||||
DualcamGrabber(DualcamWrapper *wrapper, ImageBuffer *buffer, int framerate, QObject *parent = nullptr) :
|
||||
QThread(parent), wrapper(wrapper), buffer(buffer), framerate(framerate) {}
|
||||
|
||||
void run() override;
|
||||
void stop();
|
||||
@ -30,7 +30,7 @@ public:
|
||||
private:
|
||||
bool stop_request = false;
|
||||
DualcamWrapper *wrapper;
|
||||
ImageBuffer *buffer0, *buffer1;
|
||||
ImageBuffer *buffer;
|
||||
int framerate;
|
||||
double exposure, gain;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user