陀螺识别方式改变,参数更新。

This commit is contained in:
xinyang
2019-07-29 16:26:29 +08:00
parent 550d51049d
commit 2d399cc567
18 changed files with 17906 additions and 17919 deletions

View File

@@ -1,7 +1,7 @@
//
// Created by zhikun on 18-11-7.
//
#include <iostream>
#include <camera/camera_wrapper.h>
#include <log.h>
#include <additions/additions.h>
@@ -9,9 +9,6 @@
#include <config/setconfig.h>
using namespace std;
using std::cout;
using std::endl;
using namespace cv;
CameraWrapper::CameraWrapper(int gain, int camera_mode, const std::string &n) :
@@ -23,10 +20,7 @@ CameraWrapper::CameraWrapper(int gain, int camera_mode, const std::string &n) :
iplImage(nullptr),
rgb_buffer(nullptr),
channel(3),
gain(gain),
qhead(0),
qtail(0),
readThread(nullptr){
gain(gain){
}
void cameraCallback(CameraHandle hCamera, BYTE *pFrameBuffer, tSdkFrameHead* pFrameHead,PVOID pContext){
@@ -34,14 +28,7 @@ void cameraCallback(CameraHandle hCamera, BYTE *pFrameBuffer, tSdkFrameHead* pFr
CameraImageProcess(hCamera, pFrameBuffer, c->rgb_buffer, pFrameHead);
auto iplImage = cvCreateImageHeader(cvSize(pFrameHead->iWidth, pFrameHead->iHeight), IPL_DEPTH_8U, c->channel);
cvSetData(iplImage, c->rgb_buffer, pFrameHead->iWidth * c->channel); //此处只是设置指针,无图像块数据拷贝,不需担心转换效率
c->src_queue[c->qhead] = cv::cvarrToMat(iplImage).clone();
if((c->qhead+1)%2 == c->qtail){
c->qhead = (c->qhead+1)%2;
c->qtail = (c->qtail+1)%2;
} else {
c->qhead = (c->qhead+1)%2;
}
// LOGM("Get image, [%d %d]", c->qhead, c->qtail);
c->src_queue.push(cv::cvarrToMat(iplImage).clone());
}
bool CameraWrapper::init() {
@@ -162,17 +149,11 @@ bool CameraWrapper::init() {
return true;
}
bool CameraWrapper::changeBrightness(int brightness) {
CameraUnInit(h_camera);
CameraSetAnalogGain(h_camera, brightness);
}
bool CameraWrapper::read(cv::Mat &src) {
if(init_done) {
if (mode == 0)return readProcessed(src);
if (mode == 1)return readRaw(src);
if (mode == 2)return readCallback(src);
if (mode == 3)return readWithThread(src);
} else {
return false;
}
@@ -225,44 +206,13 @@ bool CameraWrapper::readProcessed(cv::Mat &src) {
bool CameraWrapper::readCallback(cv::Mat &src) {
timeval ts, te;
gettimeofday(&ts, NULL);
while(qtail==qhead){
while(src_queue.empty()){
gettimeofday(&te, NULL);
if(getTimeIntervalms(te, ts) > 500){
return false;
}
}
src = src_queue[qtail];
// cout << src.size << endl;
qtail = (qtail+1)%2;
return true;
}
bool CameraWrapper::readWithThread(cv::Mat &src){
if(readThread != nullptr){
readThread->join();
src = src_queue[qtail];
qtail = (qtail+1)%2;
delete readThread;
readThread = new std::thread([&](){
readProcessed(src_queue[qhead]);
qhead = (qhead+1)%2;
});
}else{
readThread = new std::thread([&](){
readProcessed(src_queue[qhead]);
qhead = (qhead+1)%2;
});
readThread->join();
src = src_queue[qtail];
qtail = (qtail+1)%2;
delete readThread;
readThread = new std::thread([&](){
readProcessed(src_queue[qhead]);
qhead = (qhead+1)%2;
});
}
return true;
return src_queue.pop(src);
}
CameraWrapper::~CameraWrapper() {
@@ -270,8 +220,4 @@ CameraWrapper::~CameraWrapper() {
//注意先反初始化后再free
if (rgb_buffer != nullptr)
free(rgb_buffer);
if(readThread != nullptr){
readThread->detach();
delete readThread;
}
}