mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-26 00:00:02 +02:00

git-svn-id: file:///afs/psi.ch/project/sls_det_software/svn/slsDetectorGui@16 af1100a4-978c-4157-bff7-07162d2ba061
140 lines
4.0 KiB
C++
140 lines
4.0 KiB
C++
/*
|
|
* qDefs.h
|
|
*
|
|
* Created on: May 4, 2012
|
|
* Author: l_maliakal_d
|
|
*/
|
|
|
|
#ifndef QDEFS_H
|
|
#define QDEFS_H
|
|
|
|
#include <iostream>
|
|
#include <QMessageBox>
|
|
using namespace std;
|
|
|
|
class qDefs:public QWidget{
|
|
public:
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/** Empty Constructor
|
|
*/
|
|
qDefs(){};
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/** unit of time
|
|
*/
|
|
enum timeUnit{
|
|
HOURS, /** hr */
|
|
MINUTES, /** min */
|
|
SECONDS, /** s */
|
|
MILLISECONDS, /** ms */
|
|
MICROSECONDS, /** us */
|
|
NANOSECONDS /** ns */
|
|
};
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/** returns the unit in words
|
|
* @param unit is the time unit
|
|
*/
|
|
static string getUnitString(timeUnit unit){
|
|
switch(unit){
|
|
case HOURS: return string("hrs");
|
|
case MINUTES: return string("min");
|
|
case SECONDS: return string("sec");
|
|
case MILLISECONDS: return string("msec");
|
|
case MICROSECONDS: return string("usec");
|
|
case NANOSECONDS: return string("nsec");
|
|
default: return string("error");
|
|
}
|
|
};
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/** returns the value in ns to send to server as the
|
|
* server class slsdetector accepts in ns.
|
|
* @param unit unit of time
|
|
* @param value time
|
|
* returns time value in ns
|
|
*/
|
|
static float getNSTime(timeUnit unit, float value){
|
|
float valueNS=value;
|
|
switch(unit){
|
|
case HOURS: valueNS*=60;
|
|
case MINUTES: valueNS*=60;
|
|
case SECONDS: valueNS*=1000;
|
|
case MILLISECONDS: valueNS*=1000;
|
|
case MICROSECONDS: valueNS*=1000;
|
|
case NANOSECONDS:
|
|
default:;
|
|
}
|
|
return valueNS;
|
|
};
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/** returns the time in the appropriate time unit
|
|
* @param unit unit of time
|
|
* @param value time in seconds
|
|
* returns the corresponding time value
|
|
*/
|
|
static float getCorrectTime(timeUnit& unit, float value){
|
|
int intUnit = (int)SECONDS;
|
|
|
|
/** hr, min, sec */
|
|
if(value>=1){
|
|
float newVal = value;
|
|
while((newVal>=1)&&(intUnit>=(int)HOURS)){
|
|
/** value retains the old value */
|
|
value = newVal;
|
|
newVal = value/60;
|
|
intUnit--;
|
|
}
|
|
/** returning the previous value*/
|
|
unit = (timeUnit)(intUnit+1);
|
|
return value;
|
|
}
|
|
/** ms, us, ns */
|
|
else{
|
|
while((value<1)&&(intUnit<(int)NANOSECONDS)){
|
|
value = value*1000;
|
|
intUnit++;
|
|
}
|
|
unit = (timeUnit)(intUnit);
|
|
return value;
|
|
}
|
|
};
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**displays an error message
|
|
* @param errorMessage the message to be displayed
|
|
* @param source is the tab or the source of the error
|
|
* */
|
|
static void ErrorMessage(string errorMessage,char source[])
|
|
{
|
|
static QMessageBox* errorBox;
|
|
errorBox= new QMessageBox(QMessageBox::Warning,source,tr(errorMessage.c_str()),QMessageBox::Ok, errorBox);
|
|
errorBox->exec();
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**displays an information message
|
|
* @param infoMessage the message to be displayed
|
|
* @param source is the tab or the source of the information
|
|
* */
|
|
static void InfoMessage(string infoMessage,char source[])
|
|
{
|
|
static QMessageBox* msgBox;
|
|
msgBox= new QMessageBox(QMessageBox::Information,source,tr(infoMessage.c_str()),QMessageBox::Ok, msgBox);
|
|
msgBox->exec();
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
};
|
|
|
|
|
|
#endif /* QDEFS_H */
|