mirror of
https://github.com/slsdetectorgroup/slsDetectorPackage.git
synced 2025-04-24 23:30:03 +02:00

git-svn-id: file:///afs/psi.ch/project/sls_det_software/svn/slsDetectorGui@22 af1100a4-978c-4157-bff7-07162d2ba061
172 lines
5.0 KiB
C++
172 lines
5.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(){};
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
enum{
|
|
OK,
|
|
FAIL
|
|
};
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
/** 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 double getNSTime(timeUnit unit, double value){
|
|
double 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 double getCorrectTime(timeUnit& unit, double value){
|
|
int intUnit = (int)SECONDS;
|
|
|
|
/** hr, min, sec */
|
|
if(value>=1){
|
|
double 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 warning message
|
|
* @param warningMessage the message to be displayed
|
|
* @param source is the tab or the source of the warning
|
|
* */
|
|
static void WarningMessage(string warningMessage,string source)
|
|
{
|
|
static QMessageBox* warningBox;
|
|
source.append(": WARNING");
|
|
warningBox= new QMessageBox(QMessageBox::Warning,source.c_str(),tr(warningMessage.c_str()),QMessageBox::Ok, warningBox);
|
|
warningBox->exec();
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**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,string source)
|
|
{
|
|
static QMessageBox* errorBox;
|
|
source.append(": ERROR");
|
|
errorBox= new QMessageBox(QMessageBox::Critical,source.c_str(),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,string source)
|
|
{
|
|
static QMessageBox* msgBox;
|
|
source.append(": INFORMATION");
|
|
msgBox= new QMessageBox(QMessageBox::Information,source.c_str(),tr(infoMessage.c_str()),QMessageBox::Ok, msgBox);
|
|
msgBox->exec();
|
|
}
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
/** range of x and y axes
|
|
*/
|
|
enum range{
|
|
XMINIMUM,
|
|
XMAXIMUM,
|
|
YMINIMUM,
|
|
YMAXIMUM
|
|
};
|
|
|
|
//-------------------------------------------------------------------------------------------------------------------------------------------------
|
|
|
|
};
|
|
|
|
|
|
#endif /* QDEFS_H */
|