| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | #include "AbstractFSController.h"
 | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | #include "ZZ_Math_HDRONLY.h"
 | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | CAbstractFSController::CAbstractFSController(QObject* parent /*= nullptr*/) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | 	m_pFSCtrl = NULL; | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 	m_iThreadID = -1; | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 	m_vecDataFrameDark.clear(); | 
					
						
							|  |  |  | 	m_vecDataFrameSignal.clear(); | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CAbstractFSController::~CAbstractFSController() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | 	if (m_pFSCtrl!= 0 ) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		delete m_pFSCtrl; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | int CAbstractFSController::SetRunParas(int iThreadID, FSInfo fsInfo) | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	m_iThreadID = iThreadID; | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | 	m_fsInfo = fsInfo; | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int CAbstractFSController::InitializeFSControl() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | 	using namespace ZZ_MISCDEF::IRIS; | 
					
						
							|  |  |  | 	if (m_iThreadID == -1/*|| m_iDeviceType == -1*/) | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		qDebug() << "Params Err. Call SetRunParas first"; | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | 	switch (m_fsInfo.ucDeviceModel) | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 	case DeviceModel::OSIFAlpha:   | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 		m_pFSCtrl = new OceanOptics_lib; | 
					
						
							| 
									
										
										
										
											2021-12-13 17:18:24 +08:00
										 |  |  | 		if (m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, m_fsInfo.strSN) != 0) | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "OSIFAlpha Not Opened"; | 
					
						
							|  |  |  | 			return 2; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case DeviceModel::OSIFBeta: | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 		m_pFSCtrl = new OceanOptics_lib; | 
					
						
							| 
									
										
										
										
											2021-12-13 17:18:24 +08:00
										 |  |  |  		if (m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, m_fsInfo.strSN) !=0) | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  |  		{ | 
					
						
							|  |  |  |  			qDebug() << "OSIFBeta Not Opened"; | 
					
						
							|  |  |  |  			return 2; | 
					
						
							|  |  |  |  		} | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case DeviceModel::ISIF:  | 
					
						
							|  |  |  | 		m_pFSCtrl = new ZZ_ATPControl_Serial_Qt; | 
					
						
							| 
									
										
										
										
											2021-12-13 17:18:24 +08:00
										 |  |  | 		m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, NULL); | 
					
						
							|  |  |  | 		if (m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, m_fsInfo.strSN) != 0) | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "ISIF Not Opened"; | 
					
						
							|  |  |  | 			return 3; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case DeviceModel::IS1: | 
					
						
							|  |  |  | 		m_pFSCtrl = new ZZ_ATPControl_Serial_Qt; | 
					
						
							| 
									
										
										
										
											2021-12-13 17:18:24 +08:00
										 |  |  | 		m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, NULL); | 
					
						
							|  |  |  | 		if (m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, m_fsInfo.strSN) != 0) | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "IS1 Not Opened"; | 
					
						
							|  |  |  | 			return 3; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	case DeviceModel::IS2: | 
					
						
							|  |  |  | 		m_pFSCtrl = new ZZ_ATPControl_Serial_Qt; | 
					
						
							| 
									
										
										
										
											2021-12-13 17:18:24 +08:00
										 |  |  | 		m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, NULL); | 
					
						
							|  |  |  | 		if (m_pFSCtrl->Initialize(false, m_fsInfo.strInterface, m_fsInfo.strSN) != 0) | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "IS2 Not Opened"; | 
					
						
							|  |  |  | 			return 3; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	default:  | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	int iRes = m_pFSCtrl->GetDeviceAttribute(m_daDeviceAttr); | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 	if (iRes != 0) | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 		qDebug() << "GetDeviceAttribute Failed" << iRes; | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 		return 4; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | int CAbstractFSController::GetDeviceAttr(DeviceAttribute &daAttr) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	daAttr = m_daDeviceAttr; | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | int CAbstractFSController::PerformAutoExposure() | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 	qDebug() << "--------------------------Starting PerformAutoExposure" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	using namespace ZZ_MATH; | 
					
						
							|  |  |  | 	float fPredictedExposureTime; | 
					
						
							|  |  |  | 	int iDeviceDepth = (int)m_fsInfo.lDepth; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bool bFlagIsOverTrying = false; | 
					
						
							|  |  |  | 	bool bFlagIsLowerMinExposureTime = false; | 
					
						
							|  |  |  | 	bool bFlagIsOverMaxExposureTime = false; | 
					
						
							|  |  |  | 	bool bFlagIsAutoExposureOK = false; | 
					
						
							|  |  |  | 	bool bFlagIsAutoExposureFailed = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bool bIsValueOverflow = false; | 
					
						
							|  |  |  | 	bool bIsLastValueOverflow = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int  iExposureTime = 0; | 
					
						
							|  |  |  | 	float  fTempExposureTime = 0; | 
					
						
							|  |  |  | 	double fLastExposureTime = 0.1; | 
					
						
							|  |  |  | 	int    iRepeatCount = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	//int iRes = m_pFSCtrl->SetExposureTime(1000);//need change to load from files
 | 
					
						
							|  |  |  | 	int iRes = 0; | 
					
						
							|  |  |  | 	if (iRes != 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		qDebug() << "Err:PerformAutoExposure Failed.Exit Code:1"; | 
					
						
							|  |  |  | 		return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while (!bFlagIsAutoExposureOK && !bFlagIsAutoExposureFailed) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		DataFrame dfTemp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (iRepeatCount++ > 30) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bFlagIsAutoExposureFailed = true; | 
					
						
							|  |  |  | 			bFlagIsOverTrying = true; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		//m_pFSCtrl->SetExposureTime(5000);
 | 
					
						
							|  |  |  | 		m_pFSCtrl->GetExposureTime(iExposureTime); | 
					
						
							|  |  |  | 		//m_pFSCtrl->SetExposureTime(2500);
 | 
					
						
							|  |  |  | 		//fExposureTime = (float)m_daDeviceAttr.iMinIntegrationTimeInMS;
 | 
					
						
							|  |  |  | 		fTempExposureTime = iExposureTime; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		iRes = m_pFSCtrl->SingleShot(dfTemp); | 
					
						
							|  |  |  | 		//iRes = m_pFSCtrl->SingleShot(dfTemp);
 | 
					
						
							|  |  |  | 		if (iRes != 0) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "Err:PerformAutoExposure Failed.Exit Code:2"; | 
					
						
							|  |  |  | 			return 2; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 		HeapSort(dfTemp.lData, m_daDeviceAttr.iPixels); | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		double dSum = 0; | 
					
						
							|  |  |  | 		int iCount = m_daDeviceAttr.iPixels / 100; | 
					
						
							|  |  |  | 		for (int i = 0; i < iCount; i++) | 
					
						
							|  |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 			dSum += dfTemp.lData[i]; | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		double dTemp = dSum / iCount; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (dTemp >= iDeviceDepth * 0.99) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bIsValueOverflow = true; | 
					
						
							|  |  |  | 			if (!bIsLastValueOverflow) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				iExposureTime = (float)(fLastExposureTime + iExposureTime) / 2; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				iExposureTime = iExposureTime / 2; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		else if (iDeviceDepth * m_fsInfo.fMaxFactor >= dTemp && dTemp >= iDeviceDepth * m_fsInfo.fMinFactor) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bFlagIsAutoExposureOK = 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (dTemp > iDeviceDepth * m_fsInfo.fMaxFactor) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bIsValueOverflow = true; | 
					
						
							|  |  |  | 			if (!bIsLastValueOverflow) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				iExposureTime = (float)(fLastExposureTime + iExposureTime) / 2; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				iExposureTime = iExposureTime * 3 / 4; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (dTemp < iDeviceDepth * m_fsInfo.fMinFactor) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bIsValueOverflow = false; | 
					
						
							|  |  |  | 			if (bIsLastValueOverflow) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				iExposureTime = (float)(fLastExposureTime + iExposureTime) / 2; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				double dFactor; | 
					
						
							|  |  |  | 				dFactor = dTemp / (iDeviceDepth * m_fsInfo.fMaxFactor); | 
					
						
							|  |  |  | 				iExposureTime = (float)(iExposureTime / dFactor); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			if (/*fExposureTime > 100 || */iExposureTime < 10) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				bFlagIsAutoExposureOK = false; | 
					
						
							|  |  |  | 				bFlagIsAutoExposureFailed = true; | 
					
						
							|  |  |  | 				bFlagIsLowerMinExposureTime = true; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		bIsLastValueOverflow = bIsValueOverflow; | 
					
						
							|  |  |  | 		fLastExposureTime = fTempExposureTime; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (iExposureTime > 30000) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			bFlagIsAutoExposureOK = false; | 
					
						
							|  |  |  | 			bFlagIsAutoExposureFailed = true; | 
					
						
							|  |  |  | 			float fPredictedExposureTime = 30000; | 
					
						
							|  |  |  | 			iRes = m_pFSCtrl->SetExposureTime(30000); | 
					
						
							|  |  |  | 			if (iRes != 0) | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				qDebug() << "Err:PerformAutoExposure Failed.Exit Code:3"; | 
					
						
							|  |  |  | 				return 3; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 			else | 
					
						
							|  |  |  | 			{ | 
					
						
							|  |  |  | 				qDebug() << "Warning:PerformAutoExposure exceed max integration time.Will be limited to 30sec"; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 			bFlagIsOverMaxExposureTime = true; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		iRes = m_pFSCtrl->SetExposureTime((int)iExposureTime); | 
					
						
							|  |  |  | 		if (iRes != 0) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "Err:PerformAutoExposure Failed.Exit Code:4"; | 
					
						
							|  |  |  | 			return 3; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			qDebug() << "Success:PerformAutoExposure. Value"<< iExposureTime; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	fPredictedExposureTime = iExposureTime; | 
					
						
							|  |  |  | 	qDebug() << "--------------------------Stop PerformAutoExposure" << " Thread ID:" << m_iThreadID; | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 	//emit SignalAcqFinished(m_iThreadID, 1);
 | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int CAbstractFSController::TakeDarkFrame() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	qDebug() << "Starting TakeDarkFrame" << " Thread ID:" << m_iThreadID; | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	m_vecDataFrameDark.push_back(TakeOneFrame()); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 	qDebug() << "Stop TakeDarkFrame" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	//emit SignalAcqFinished(m_iThreadID, 1);
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | int CAbstractFSController::TakeSignalFrame() | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | { | 
					
						
							|  |  |  | 	qDebug() << "Starting TakeSignal" << " Thread ID:" << m_iThreadID; | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	m_vecDataFrameSignal.push_back(TakeOneFrame()); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 	qDebug() << "Stop TakeSignal" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	//emit SignalAcqFinished(m_iThreadID, 1);
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | DataFrame CAbstractFSController::TakeOneFrame() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	DataFrame dfTemp; | 
					
						
							|  |  |  | 	int iRes = m_pFSCtrl->SingleShot(dfTemp); | 
					
						
							|  |  |  | 	if (iRes != 0) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		qDebug() << "Err. SingleShot" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return dfTemp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | int CAbstractFSController::SaveDataFile() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int CAbstractFSController::StartAcquisitionSignal() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	//
 | 
					
						
							|  |  |  | 	qDebug() << "Starting acq Signal" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | // 	DataFrame struDF;
 | 
					
						
							|  |  |  | // 	int iii;
 | 
					
						
							|  |  |  | // 	m_pFSCtrl->SetExposureTime(10000000);
 | 
					
						
							|  |  |  | // 	m_pFSCtrl->GetExposureTime(iii);
 | 
					
						
							|  |  |  | // 	m_pFSCtrl->SingleShot(struDF);
 | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	//PerformAutoExposure();
 | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 	TakeSignalFrame(); | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	qDebug() << "Stop acq Signal" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	emit SignalAcqFinished_Signal(m_iThreadID, 1); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int CAbstractFSController::StartAcquisitionDark() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	qDebug() << "Starting acq Dark" << " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	TakeDarkFrame(); | 
					
						
							|  |  |  | 	qDebug() << "Stop acq Dark"<< " Thread ID:" << m_iThreadID; | 
					
						
							|  |  |  | 	emit SignalAcqFinished_Dark(m_iThreadID, 1); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-24 17:38:18 +08:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int CAbstractFSController::StopAcquisition() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | int CAbstractFSController::ClearBuffer() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	m_vecDataFrameDark.clear(); | 
					
						
							|  |  |  | 	m_vecDataFrameSignal.clear(); | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-11-26 17:32:50 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | int CAbstractFSController::GetBuffer(std::vector<DataFrame> &pvecDataFrameDark, std::vector<DataFrame> &pvecDataFrameSignal) | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2021-12-08 17:43:27 +08:00
										 |  |  | 	for (size_t i=0; i < m_vecDataFrameSignal.size(); i++) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		pvecDataFrameSignal.push_back(m_vecDataFrameSignal[i]); | 
					
						
							|  |  |  | 		pvecDataFrameDark.push_back(m_vecDataFrameDark[i]); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-12-06 17:50:39 +08:00
										 |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-12-02 18:07:29 +08:00
										 |  |  | 
 |