mirror of
http://172.16.0.230/r/SIF/TowerOptoSifAndSpectral.git
synced 2025-10-18 19:39:43 +08:00
调试上传用
This commit is contained in:
96
source/Uploader/DataFileTransfer.cpp
Normal file
96
source/Uploader/DataFileTransfer.cpp
Normal file
@ -0,0 +1,96 @@
|
||||
#include "DataFileTransfer.h"
|
||||
ZZ_HttpTransfer::ZZ_HttpTransfer(QObject* parent /*= nullptr*/)
|
||||
{
|
||||
m_pNetworkManager = new QNetworkAccessManager();
|
||||
connect(m_pNetworkManager, SIGNAL(finished(QNetworkReply*)), this, SLOT(SlotReplyFinished(QNetworkReply*)));
|
||||
}
|
||||
|
||||
ZZ_HttpTransfer::~ZZ_HttpTransfer()
|
||||
{
|
||||
}
|
||||
|
||||
int ZZ_HttpTransfer::SendData()
|
||||
{
|
||||
QNetworkRequest qnRequest;
|
||||
qnRequest.setHeader(QNetworkRequest::ContentTypeHeader, QVariant("application/json"));
|
||||
qnRequest.setUrl(QUrl("http://172.16.0.234/fileup/Data_uper.php"));
|
||||
|
||||
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int ZZ_HttpTransfer::SendInfo()
|
||||
{
|
||||
QNetworkRequest qnRequest;
|
||||
qnRequest.setHeader(QNetworkRequest::ContentTypeHeader, QVariant("application/json"));
|
||||
qnRequest.setUrl(QUrl("http://172.16.0.234/fileup/Dev_info_uper.php"));
|
||||
|
||||
QString qstrSend;
|
||||
QString qstrWaveLength;
|
||||
for (int i = 0; i < m_struGrabberRTParams.fscParams.ucDeviceNumber; i++)
|
||||
{
|
||||
qstrSend = "Location:" + QString("%1").arg(m_struEC.qstrLocation) + "####";
|
||||
qstrSend += "DEV_SN:" + QString("%1").arg(m_struEC.qstrDEV_SN) + "####";
|
||||
qstrSend += "GPS_Longtitude:" + QString("%1").arg(m_struEC.qstrGPS_Longtitude) + "####";
|
||||
qstrSend += "GPS_Latitude:" + QString("%1").arg(m_struEC.qstrGPS_Latitude) + "####";
|
||||
qstrSend += "GPS_Altitude:" + QString("%1").arg(m_struEC.qstrGPS_Altitude) + "####";
|
||||
qstrSend += "GPS_North:" + QString("%1").arg(m_struEC.qstrGPS_North) + "####";
|
||||
qstrSend += "InstallationTime:" + QString("%1").arg(m_struMEC.qstrInstallationTime) + "####";
|
||||
qstrSend += "NameOfMaintenanceStaff:" + QString("%1").arg(m_struMEC.qstrNameOfMaintenanceStaff) + "####";
|
||||
qstrSend += "PhoneNumberOfMaintenanceStaff:" + QString("%1").arg(m_struMEC.qstrPhoneNumberOfMaintenanceStaff) + "####";
|
||||
qstrSend += "Bands:" + QString("%1").arg(m_struGrabberRTParams.fscParams.usPixels[i]) + "####";
|
||||
qstrSend += "WaveLength:";
|
||||
for (int j=0;j< m_struGrabberRTParams.fscParams.usPixels[i];j++)
|
||||
{
|
||||
qstrWaveLength = QString("%1").arg(m_struGrabberRTParams.fscParams.fWavelength[i][j]);
|
||||
qstrSend += qstrWaveLength;
|
||||
if (j == m_struGrabberRTParams.fscParams.usPixels[i]-1)
|
||||
{
|
||||
qstrSend += "####";
|
||||
}
|
||||
else
|
||||
{
|
||||
qstrSend += ",";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
qDebug() << qstrSend;
|
||||
return 0;
|
||||
}
|
||||
|
||||
int ZZ_HttpTransfer::SendErr()
|
||||
{
|
||||
QNetworkRequest qnRequest;
|
||||
qnRequest.setHeader(QNetworkRequest::ContentTypeHeader, QVariant("application/json"));
|
||||
qnRequest.setUrl(QUrl("http://172.16.0.234/fileup/Warning.php"));
|
||||
|
||||
QByteArray abTest;
|
||||
|
||||
m_pNetworkManager->post(qnRequest, abTest);
|
||||
return 0;
|
||||
}
|
||||
|
||||
void ZZ_HttpTransfer::SetContext(EContext struEC, MEContext struMEC)
|
||||
{
|
||||
m_struEC = struEC;
|
||||
m_struMEC = struMEC;
|
||||
}
|
||||
|
||||
void ZZ_HttpTransfer::SetDeviceInfo(RunTimeGrabberParams struGrabberRTParams)
|
||||
{
|
||||
m_struGrabberRTParams = struGrabberRTParams;
|
||||
}
|
||||
|
||||
void ZZ_HttpTransfer::SetCalData(vector<vector<CalDataFrame>> vecCalcedData)
|
||||
{
|
||||
m_vecCalcedData = vecCalcedData;
|
||||
}
|
||||
|
||||
int ZZ_HttpTransfer::SlotReplyFinished(QNetworkReply* qnReply)
|
||||
{
|
||||
QString qstrURL = qnReply->url().toString();
|
||||
QByteArray qbData = qnReply->readAll();
|
||||
return 0;
|
||||
}
|
37
source/Uploader/DataFileTransfer.h
Normal file
37
source/Uploader/DataFileTransfer.h
Normal file
@ -0,0 +1,37 @@
|
||||
#pragma once
|
||||
#include "pch.h"
|
||||
#include "ZZ_Types.h"
|
||||
//http://172.16.0.234/fileup/Data_uper.php
|
||||
//http://172.16.0.234/fileup/Dev_info_uper.php
|
||||
//http://172.16.0.234/fileup/Warning.php
|
||||
|
||||
using namespace std;
|
||||
using namespace ZZ_MISCDEF::ZZ_DATAFILE;
|
||||
using namespace ZZ_MISCDEF::ZZ_RUNPARAMS;
|
||||
using namespace ZZ_MISCDEF::IRIS::FS;
|
||||
|
||||
class ZZ_HttpTransfer :public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
ZZ_HttpTransfer(QObject* parent = nullptr);
|
||||
~ZZ_HttpTransfer();
|
||||
public:
|
||||
public:
|
||||
int SendData();
|
||||
int SendInfo();
|
||||
int SendErr();
|
||||
|
||||
void SetContext(EContext struEC, MEContext struMEC);
|
||||
void SetDeviceInfo(RunTimeGrabberParams struGrabberRTParams);
|
||||
void SetCalData(vector<vector<CalDataFrame>> vecCalcedData);
|
||||
private:
|
||||
QNetworkAccessManager *m_pNetworkManager;
|
||||
EContext m_struEC;
|
||||
MEContext m_struMEC;
|
||||
RunTimeGrabberParams m_struGrabberRTParams;
|
||||
vector<vector<CalDataFrame>> m_vecCalcedData;
|
||||
private:
|
||||
public slots:
|
||||
int SlotReplyFinished(QNetworkReply* qnReply);
|
||||
};
|
78
source/Uploader/MainDataUploader.cpp
Normal file
78
source/Uploader/MainDataUploader.cpp
Normal file
@ -0,0 +1,78 @@
|
||||
#include "MainDataUploader.h"
|
||||
|
||||
CMainDataUploader::CMainDataUploader(QObject* parent /*= nullptr*/)
|
||||
{
|
||||
m_pRadConverter = new RadConverter;
|
||||
m_pTransfer = new ZZ_HttpTransfer;
|
||||
}
|
||||
|
||||
CMainDataUploader::~CMainDataUploader()
|
||||
{
|
||||
if (m_pRadConverter)
|
||||
{
|
||||
delete m_pRadConverter;
|
||||
}
|
||||
if (m_pTransfer)
|
||||
{
|
||||
delete m_pTransfer;
|
||||
}
|
||||
}
|
||||
|
||||
void CMainDataUploader::SetData(vector<vector<DataFrame>> vecData)
|
||||
{
|
||||
m_vecData = vecData;
|
||||
}
|
||||
|
||||
void CMainDataUploader::SetRTGP(RunTimeGrabberParams struGrabberRTParams)
|
||||
{
|
||||
m_struGrabberRTParams = struGrabberRTParams;
|
||||
}
|
||||
|
||||
void CMainDataUploader::SetContext(EContext struEC, MEContext struMEC)
|
||||
{
|
||||
m_struEC = struEC;
|
||||
m_struMEC = struMEC;
|
||||
}
|
||||
|
||||
void CMainDataUploader::Calibration()
|
||||
{
|
||||
int iScanPoints = m_struGrabberRTParams.apsParams.iTotalPosition - 1;
|
||||
int iDevices = m_struGrabberRTParams.fscParams.ucDeviceNumber;
|
||||
for (int j = 0; j < iDevices; j++)
|
||||
{
|
||||
for (int i = 0; i < iScanPoints; i++)
|
||||
{
|
||||
for (int k=0;k< m_struGrabberRTParams.fscParams.usPixels[j];k++)
|
||||
{
|
||||
m_vecCalcedData[j][i].dData[k] = m_vecData[j][i].lData[k]* m_vecCalData[j][i].dCal_Gain[k];
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int CMainDataUploader::Upload()
|
||||
{
|
||||
m_pTransfer->SendInfo();
|
||||
return 0;
|
||||
}
|
||||
|
||||
int CMainDataUploader::Initialize()
|
||||
{
|
||||
m_pRadConverter->LoadCalibrationFrames(m_struGrabberRTParams,m_vecCalData);
|
||||
|
||||
m_pTransfer->SetContext(m_struEC, m_struMEC);
|
||||
m_pTransfer->SetDeviceInfo(m_struGrabberRTParams);
|
||||
return 0;
|
||||
}
|
||||
|
||||
// int CMainDataUploader::SlotPushOneDataFrame(vector<vector<DataFrame>> vecData)
|
||||
// {
|
||||
// return 0;
|
||||
// }
|
||||
|
||||
int CMainDataUploader::SlotPushOneDataFrame()
|
||||
{
|
||||
m_vecData.clear();
|
||||
return 0;
|
||||
}
|
47
source/Uploader/MainDataUploader.h
Normal file
47
source/Uploader/MainDataUploader.h
Normal file
@ -0,0 +1,47 @@
|
||||
#pragma once
|
||||
#include "pch.h"
|
||||
#include <vector>
|
||||
#include "ZZ_Types.h"
|
||||
#include "DataFileTransfer.h"
|
||||
#include "RadianceConverter.h"
|
||||
|
||||
using namespace std;
|
||||
using namespace ZZ_MISCDEF::ZZ_DATAFILE;
|
||||
using namespace ZZ_MISCDEF::ZZ_RUNPARAMS;
|
||||
using namespace ZZ_MISCDEF::IRIS::FS;
|
||||
|
||||
class CMainDataUploader :public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
CMainDataUploader(QObject* parent = nullptr);
|
||||
~CMainDataUploader();
|
||||
public:
|
||||
public:
|
||||
|
||||
//set attributes
|
||||
void SetData(vector<vector<DataFrame>> vecData);
|
||||
void SetRTGP(RunTimeGrabberParams struGrabberRTParams);
|
||||
void SetContext(EContext struEC, MEContext struMEC);
|
||||
|
||||
//load calibration file after set attributes
|
||||
int Initialize();
|
||||
|
||||
void Calibration();
|
||||
|
||||
int Upload();
|
||||
|
||||
private:
|
||||
RadConverter *m_pRadConverter = NULL;
|
||||
ZZ_HttpTransfer *m_pTransfer = NULL;
|
||||
private:
|
||||
EContext m_struEC;
|
||||
MEContext m_struMEC;
|
||||
RunTimeGrabberParams m_struGrabberRTParams;
|
||||
vector<vector<DataFrame>> m_vecData;
|
||||
vector<vector<CalFrame>> m_vecCalData;
|
||||
vector<vector<CalDataFrame>> m_vecCalcedData;
|
||||
public slots:
|
||||
//int SlotPushOneDataFrame(vector<vector<DataFrame>> vecData);
|
||||
int SlotPushOneDataFrame();
|
||||
};
|
71
source/Uploader/RadianceConverter.cpp
Normal file
71
source/Uploader/RadianceConverter.cpp
Normal file
@ -0,0 +1,71 @@
|
||||
#include "RadianceConverter.h"
|
||||
RadConverter::RadConverter(QObject* parent /*= nullptr*/)
|
||||
{
|
||||
#ifdef _DEBUG
|
||||
m_qstrCalFilePath = "E:/WorkSpace/TowerOptoSifAndSpectral/Cal";
|
||||
#else
|
||||
m_qstrCalFilePath = "/home/data/Cal";
|
||||
#endif // DEBUG
|
||||
}
|
||||
|
||||
RadConverter::~RadConverter()
|
||||
{
|
||||
}
|
||||
|
||||
int RadConverter::LoadCalibrationFrames(RunTimeGrabberParams struGrabberRTParams, vector<vector<CalFrame>> &struAllCalFrame)
|
||||
{
|
||||
/////param
|
||||
int iScanPoints = struGrabberRTParams.apsParams.iTotalPosition - 1;
|
||||
int iDevices = struGrabberRTParams.fscParams.ucDeviceNumber;
|
||||
/////check dir
|
||||
QDir qdirPath(m_qstrCalFilePath);
|
||||
if (!qdirPath.exists())
|
||||
{
|
||||
qDebug() << "Calibration File not exist";
|
||||
return -1;
|
||||
}
|
||||
/////check quantities
|
||||
QStringList qslFilter;
|
||||
qslFilter << "*.dat";
|
||||
qdirPath.setNameFilters(qslFilter);
|
||||
QFileInfoList qfiInfo = qdirPath.entryInfoList(qslFilter);
|
||||
if (qfiInfo.size()!= iScanPoints * iDevices)
|
||||
{
|
||||
qDebug() << "Calibration Files quantities not match";
|
||||
return -2;
|
||||
}
|
||||
|
||||
/////read file
|
||||
QString qstrFilePath;
|
||||
vector<CalFrame> vecOneDev;
|
||||
CalFrame OneFile;
|
||||
for (int j=0;j<iDevices;j++)
|
||||
{
|
||||
vecOneDev.clear();
|
||||
for (int i = 0; i < iScanPoints; i++)
|
||||
{
|
||||
qstrFilePath = m_qstrCalFilePath+QString("/FS%1_").arg(j + 1)+ QString("P%1").arg(i + 1)+".dat";
|
||||
QFile qfCalFile(qstrFilePath);
|
||||
bool bRes = qfCalFile.open(QFile::ReadOnly);
|
||||
|
||||
qfCalFile.read((char *)&OneFile.iExposureTimeInMS,sizeof(int));
|
||||
qfCalFile.read((char*)&OneFile.fTemperature, sizeof(float));
|
||||
qfCalFile.read((char*)&OneFile.iPixels,sizeof(int));
|
||||
qfCalFile.read((char*)OneFile.fWaveLength, sizeof(float)*OneFile.iPixels);
|
||||
qfCalFile.read((char*)OneFile.dCal_Gain, sizeof(double)*OneFile.iPixels);
|
||||
qfCalFile.read((char*)OneFile.dCal_Offset, sizeof(double)*OneFile.iPixels);
|
||||
|
||||
/////check attribute
|
||||
// if ()
|
||||
// {
|
||||
// }
|
||||
|
||||
vecOneDev.push_back(OneFile);
|
||||
}
|
||||
struAllCalFrame.push_back(vecOneDev);
|
||||
}
|
||||
|
||||
|
||||
|
||||
return 0;
|
||||
}
|
22
source/Uploader/RadianceConverter.h
Normal file
22
source/Uploader/RadianceConverter.h
Normal file
@ -0,0 +1,22 @@
|
||||
#pragma once
|
||||
#include "pch.h"
|
||||
#include "ZZ_Types.h"
|
||||
using namespace std;
|
||||
using namespace ZZ_MISCDEF::ZZ_DATAFILE;
|
||||
using namespace ZZ_MISCDEF::ZZ_RUNPARAMS;
|
||||
using namespace ZZ_MISCDEF::IRIS::FS;
|
||||
|
||||
class RadConverter :public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
RadConverter(QObject* parent = nullptr);
|
||||
~RadConverter();
|
||||
public:
|
||||
public:
|
||||
int LoadCalibrationFrames(RunTimeGrabberParams struGrabberRTParams, vector<vector<CalFrame>> &struAllCalFrame);
|
||||
private:
|
||||
QString m_qstrCalFilePath;
|
||||
private:
|
||||
public slots:
|
||||
};
|
Reference in New Issue
Block a user