AURobotServers
4
|
#include <ufuncpicam.h>
Public Member Functions | |
virtual void | callGotNewDataWithObject () |
virtual void | createResources () |
virtual bool | handleCommand (UServerInMsg *msg, void *extra) |
virtual bool | methodCall (const char *name, const char *paramOrder, char **strings, const double *pars, double *value, UDataBase **returnStruct, int *returnStructCnt) |
virtual bool | methodCallV (const char *name, const char *paramOrder, UVariable *params[], UDataBase **returnStruct, int *returnStructCnt) |
void | run () |
void | runAlive () |
UFuncPiCam () | |
~UFuncPiCam () | |
Public Member Functions inherited from UFuncPlugBasePush | |
virtual bool | setResource (UResBase *resource, bool remove) |
UFuncPlugBasePush () | |
virtual | ~UFuncPlugBasePush () |
Public Member Functions inherited from UFunctionBase | |
bool | addResource (UResBase *resource, UFunctionBase *owner) |
void | closeLogfile () |
virtual const char * | commandList () |
const char * | getAliasName () |
const char * | getLoadedFileName () |
void * | getLoadedModuleRef () |
virtual bool | gotAllResources (char *missingThese, int missingTheseCnt) |
bool | isMine (const char *cmdName) |
bool | isStatic () |
is the module loaded as static A module is static if the ldFilename has a length of zero. More... | |
virtual const char * | name () |
bool | newCmd (UServerInMsg *newMsg, UDataBase *extra) |
bool | newCommand (UServerInMsg *newMsg, void *extra) |
bool | openLogfile (const char *name) |
void | print (const char *preString) |
virtual void | resourceUpdated () |
bool | sendEndTag (UServerInMsg *msg) |
bool | sendEndTag () |
bool | sendFullTag (const char *attributes) |
bool | sendHelpDone (UServerInMsg *msg) |
bool | sendHelpDone () |
bool | sendHelpStart (UServerInMsg *msg, const char *subject) |
bool | sendHelpStart (const char *subject) |
bool | sendHelpStart () |
bool | sendMsg (UServerInMsg *msg, const char *message, int size) |
bool | sendMsg (const char *message) |
bool | sendMsg (UServerInMsg *msg, const char *message) |
bool | sendMsg (int clientIdx, const char *message, int size) |
bool | sendMsgInt (int clientIdx, const char *message) |
bool | sendStartTag (const char *attributes) |
bool | sendText (UServerInMsg *msg, const char *text) |
bool | sendText (const char *text) |
virtual void | setAliasName (const char *name) |
virtual void | setCommand (const char *cmdList, const char *name, const char *note) |
void | setLoadedModuleRef (void *module, const char *moduleFileName) |
virtual void | setLoadTime (UTime) |
void | setName (const char *name) |
void | setVerbose (bool value) |
UFunctionBase () | |
virtual | ~UFunctionBase () |
Public Member Functions inherited from UCallBack | |
bool | addOnEvent (UOnEvent *dataObject) |
virtual bool | onEvent (const char *interface, const char *dataType, void *data) |
UCallBack () | |
virtual | ~UCallBack () |
Public Member Functions inherited from UResVarPool | |
int | addMethod (const char *formalName, const char *paramTypes, const char *comment) |
int | addMethodV (const char *formalName, const char *paramTypes, const char *comment) |
UVarPool * | addStruct (const char *name, const char *comment, bool copy=false) |
UVariable * | addVar (const char *name, const double initialValue, const char *type, const char *comment) |
UVariable * | addVar (const char *name, const char *initialValue, const char *type, const char *comment) |
UVariable * | addVarA (const char *name, const char *initialValue, const char *type, const char *comment) |
bool | callGlobal (const char *name, const char *paramOrder, char **strings, const double *doubles, double *value, UDataBase **returnStruct, int *returnStructCnt) |
bool | callGlobalV (const char *name, const char *paramOrder, UVariable **params, UDataBase **returnStruct, int *returnStructCnt) |
Call a method from the root var pool scope It may be in the structure direct (no '.') or in any sub-structure that the 'name.subname' indicate. More... | |
bool | callLocal (const char *name, const char *paramOrder, char **strings, const double *doubles, double *value, UDataBase **returnStruct, int *returnStructCnt) |
bool | callVS (const char *function, const char *stringParam) |
int | callVSCD (const char *function, const char *strPar, UDataBase *data, int cooSys) |
void | createBaseVar () |
virtual bool | createVarSpace (const int varCnt, const int structCnt, const int methCnt, const char *note, bool copy=false) |
bool | getGlobalString (const char *name, const char **value) |
bool | getGlobalValue (const char *name, double *value) |
bool | getGlobalValue (const char *name, const char **value) |
bool | getGlobalValue (const char *name, bool *value) |
bool | getGlobalValue (const char *name, UTime *value) |
bool | getLocalValue (const char *name, double *value) |
get a value in this variable tree More... | |
bool | getLocalValue (const char *name, bool *value) |
bool | getLocalValue (const char *name, UTime *value) |
double | getLocalValue (int idx) |
UPosition | getLocalValue3D (int idx) |
UPosRot | getLocalValue6D (int idx) |
bool | getLocalValueBool (int idx) |
int | getLocalValueInt (int idx) |
UTime | getLocalValueTime (int idx) |
const char * | getLogFileName () |
const char * | getVarDescription (int idx) |
UVarCalc * | getVarPool () |
bool | isLogFileOpen () |
bool | isLogFileOpen (const char *structName) |
bool | isVarPoolUpdated (int lastCnt, int *newCnt) |
void | logFileClose () |
bool | logFileOpen () |
void | logFileStart (const char *structName, bool open) |
virtual const char * | print (const char *preString, char *buff, int buffCnt) |
bool | setGlobalVar (const char *name, const double value, bool mayAdd) |
Assigns a value to a variable. The variable may be a part of a structure. More... | |
bool | setLocalVar (int idx, double value, const int element) |
bool | setLocalVar (const char *name, const double value, bool mayAdd) |
Assigns a value to a variable. The variable may be a part of a structure. More... | |
bool | setLocalVar3D (int idx, UPosition *value) |
bool | setLocalVar6D (int idx, UPosRot *value) |
bool | setLocalVarAdd (int idx, double value, const int element) |
bool | setLocalVarPose (int idx, UPose *value) |
void | setVarPool (UVarCalc *sharedVarPool) |
int | updateQTvars (int structIdx) |
UResVarPool () | |
virtual | ~UResVarPool () |
Public Member Functions inherited from UResBase | |
void | createReplayVar (UVarPool *pool) |
UCmdExe * | getCorePointer () |
char * | getLogFileName (char *fn, const int fnCnt) |
int | getResFuncIdx () |
const char * | getResID () |
int | getResVersion () |
bool | isA (const char *idStr) |
bool | isAlsoA (const char *id) |
virtual void | saveSettings () |
void | setCorePointer (UCmdExe *serverCore) |
void | setResFuncIdx (int idx) |
virtual void | setResID (const char *id, const int version) |
virtual void | updateReplayStatus () |
UResBase () | |
virtual | ~UResBase () |
Public Member Functions inherited from UReplay | |
void | addChild (UReplay *child) |
virtual bool | decodeReplayLine (char *) |
char * | getLogFileName (char *fn, const int fnCnt) |
char * | getReplayFileName (char *fn, const int fnCnt) |
int | getReplayLogLine () |
bool | isReplay () |
bool | isReplayFileOpen () |
void | removeChild (UReplay *child) |
virtual void | replayAdvanceTime (UTime untilTime) |
void | replaySetBaseFileName (const char *name, const char *preName="") |
void | replaySetFileName (const char *name) |
virtual bool | replayStep () |
int | replayStep (int steps) |
virtual bool | replayToTime (UTime untilTime) |
void | setParent (UReplay *parent) |
bool | setReplay (bool value) |
UReplay () | |
virtual | ~UReplay () |
Public Member Functions inherited from ULock | |
bool | lock () |
void | lockInit () |
void | post () |
bool | tryLock () |
bool | tryWait () |
ULock () | |
void | unlock () |
bool | wait () |
~ULock () | |
Public Member Functions inherited from UVarMethodImplement | |
virtual | ~UVarMethodImplement () |
Public Member Functions inherited from UServerPush | |
int | addPushCommand (UServerInMsg *msg) |
bool | doPushCall (UServerPushElement *pe, const char *value) |
void | flushClientCmds (int clientIdx) |
UServerPushImplement * | getImplementor () |
int | getPushCmdCnt (int *cmdCnt, int *callCnt) |
UServerPushQueue * | getPushQueue () |
bool | gotCmdExe () |
void | gotNewData (void *pData) |
bool | isUpdated (int lastCnt, int *newCnt) |
bool | needNewData () |
void | print (const char *preString) |
void | print (const char *preString, char *buff, int buffCnt) |
void | servicePendingPushCmds () |
void | setCmdExe (UServerPushImplement *executor) |
void | setImplementor (UServerPushImplement *executor) |
bool | setResource (UResBase *resource, bool remove) |
bool | setUpdated (const char *value) |
Add watch object if needed. An image or other object is updated. set object as updated, with an extra qualifier, that may be used as a parameter in a push call. this push list is then added to the to the push list examined by the server thread. when server thread reach this push list it will call to get a possible associated data structure by a call to needNewData() whish is expected to call gotNewData(void * data_structure) - but now in the server thread. More... | |
UServerPush () | |
virtual | ~UServerPush () |
Private Member Functions | |
bool | handleNormal (UServerInMsg *msg) |
void | init () |
void | logFileTest () |
bool | logImageToFile (UImage *imgToLog) |
bool | openCam () |
bool | start () |
start read thread More... | |
void | stop (bool andWait) |
Static Private Attributes | |
static const int | MWL = 100 |
static const int | PYRAMID_LEVELS_MAX = 10 |
Additional Inherited Members | |
Static Public Member Functions inherited from UResVarPool | |
static const char * | getResClassID () |
Public Attributes inherited from UFunctionBase | |
bool | silent |
is reply to client and console to be limited More... | |
Public Attributes inherited from UReplay | |
bool | replayTimeAdvancePending |
UTime | replayTimeNow |
Static Public Attributes inherited from UFunctionBase | |
static const int | MAX_ID_LENGTH = 30 |
static const int | MAX_RESOURCE_LIST_SIZE = 250 |
Protected Member Functions inherited from UFuncPlugBasePush | |
bool | handlePush (UServerInMsg *msg) |
Protected Member Functions inherited from UFunctionBase | |
int | getCmdIndex () |
UResBase * | getStaticResource (const char *resName, bool mayCreate, bool staticOnly=true) |
get a pointer to a static resource. More... | |
bool | isClientAlive (int clientIdx, double holdOffTime) |
bool | sendDebug (UServerInMsg *msg, const char *debugText) |
bool | sendDebug (const char *debugText) |
bool | sendError (UServerInMsg *msg, const char *errorText) |
bool | sendError (const char *errorText) |
bool | sendHelp (UServerInMsg *msg, const char *infoText) |
bool | sendHelp (const char *infoText) |
bool | sendInfo (UServerInMsg *msg, const char *infoText) |
bool | sendInfo (const char *infoText) |
bool | sendWarning (UServerInMsg *msg, const char *warningText) |
bool | sendWarning (const char *warningText) |
UResBase * | setThisResource (const char *ID, UResBase *resource, bool remove, bool *changed, UResBase *currentResPtr, bool *isLocal) |
Protected Member Functions inherited from UResVarPool | |
void | setDescription (const char *note, bool copy=false) |
Protected Member Functions inherited from UResBase | |
UResBase * | getStaticResource (const char *resName, bool mayCreate, bool staticOnly=true) |
get a pointer to a static resource. More... | |
Protected Attributes inherited from UFunctionBase | |
char | aliasName [MAX_ID_LENGTH] |
UCmdExe * | cmdHandler |
char * | cmdToks [20] |
int | cmdToksCnt |
char | commandsHandled [MAX_RESOURCE_LIST_SIZE] |
UServerInMsg * | msg |
char | pluginName [MAX_RESOURCE_LIST_SIZE] |
bool | verboseMessages |
Protected Attributes inherited from UResBase | |
int | resFuncIdx |
char | resID [MAX_RESOURCE_ID_LENGTH] |
char | resIsAlso [MAX_RESOURCE_ISALSO_LENGTH] |
int | resVersion |
Protected Attributes inherited from UReplay | |
bool | replay |
FILE * | replayFile |
char | replayFileName [REPLAY_FILE_NAME_LENGTH] |
replay filename More... | |
char | replayLine [MAX_LOG_LINE_LENGTH] |
int | replayLogLine |
UReplay * | replayParent |
UTime | replayTimeNext |
Static Protected Attributes inherited from UReplay | |
static const int | MAX_LOG_LINE_LENGTH = 10000 |
static const int | REPLAY_FILE_NAME_LENGTH = 264 |
max length of replay filename More... | |
This is functions to handle camera issues
|
inline |
Constructor
References callGotNewDataWithObject(), createResources(), handleCommand(), handleNormal(), init(), logFileTest(), logImageToFile(), methodCall(), methodCallV(), UFunctionBase::msg, UFunctionBase::name(), openCam(), run(), runAlive(), UFunctionBase::setCommand(), start(), stop(), and ~UFuncPiCam().
UFuncPiCam::~UFuncPiCam | ( | ) |
Destructor
References ULogFile::closeLog(), UImageLog::closeLogging(), imgCbuf, logf, logImage, and stop().
Referenced by UFuncPiCam().
|
virtual |
Called from push implementor to get the push object. should call to 'gotNewData(object)' with the available event object. if no object is available (anymore), then call with a NULL pointer.
Reimplemented from UServerPush.
References data, UFunctionBase::getAliasName(), and UServerPush::gotNewData().
Referenced by UFuncPiCam().
|
virtual |
Called by server after this module is integrated into the server core structure, i.e. all core services are in place, but no commands are serviced for this module yet. Create any resources that this modules needs.
Reimplemented from UFunctionBase.
References UResVarPool::addVar(), UResVarPool::addVarA(), aliasname, UFunctionBase::getAliasName(), logf, logImage, UReplay::replaySetBaseFileName(), ULogFile::setLogName(), start(), varCamDeviceNum, varExposureMeter, varExposureMode, varFramerate, varGain, varImageLogN, varIsOpen, varPyramidLevels, varResolution, varShutter, varSilent, varTime, varUpdateCnt, and varWhiteBal.
Referenced by UFuncPiCam().
|
virtual |
Handle incomming commands flagged for this module
msg | pointer to the message and the client issuing the command |
Reimplemented from UFunctionBase.
References UFunctionBase::getCmdIndex(), handleNormal(), UFuncPlugBasePush::handlePush(), and UFunctionBase::sendDebug().
Referenced by UFuncPiCam().
|
private |
Handle commands
References UFunctionBase::aliasName, bool2str(), USmlTagIn::getAttBool(), USmlTagIn::getAttCnt(), USmlTagIn::getAttInteger(), USmlTagIn::getAttValue(), UVariable::getBool(), UVariable::getInt(), ULogFile::getLogFileName(), UTime::getTimePassed(), ULogFile::isOpen(), lastLoopTime, logf, logImage, ULogFile::openLog(), UFunctionBase::sendHelpDone(), UFunctionBase::sendHelpStart(), UFunctionBase::sendInfo(), UFunctionBase::sendText(), UVariable::setBool(), UImageLog::setPng(), UVariable::setValued(), UFunctionBase::silent, UServerInMsg::tag, varImageLogN, varIsOpen, varSilent, and Wait().
Referenced by handleCommand(), and UFuncPiCam().
|
private |
Decode this replay line, that is assumed to be valid - has got a time stamp.
line | is a pointer to the line. |
References frameCntRgb, imgCbuf, logImage, logVideoImage, oldCamDevC, oldCamDevD, oldFocalLength, oldLed, UImageLog::setPng(), threadRunning, and threadStop.
Referenced by UFuncPiCam().
|
private |
Test for open or close logfiles using global variable
References UVariable::getInt(), ULogFile::getLogFileName(), ULogFile::isOpen(), logf, logImage, UImageLog::openLog(), UVariable::setValued(), ULogFile::toLog(), and varImageLogN.
Referenced by run(), and UFuncPiCam().
|
private |
Save image to imagelog and save the image itself in the imagePath. if camera device do not exist, then a default device is created..
imgToLog | is the image to be logged. |
References UImage::camDevice, UCamPool::getCam(), UVariable::getInt(), UFunctionBase::getStaticResource(), UImageLog::logImage(), logImage, UCamPool::makeDevice(), ULock::tryLock(), ULock::unlock(), and varImageLogN.
Referenced by run(), and UFuncPiCam().
|
virtual |
Function to implement a var-pool method call.
name | is the name of the called function |
paramOrder | is a string with one char for each parameter in the call - d is double, s is string, c is class object. |
strings | is an array of string pointers for the string type parameters (may be NULL if not used) |
doubles | is an array with double typed parameters (may be NULL if not used) |
value | is the (direct) result of the class, either a double value, or 0.0 for false 1.0 for true 2.0 for implicit stop if a controll call. |
returnStruct | is an array of class object pointers that can be used as parameters or return objects (may be NULL) |
returnStructCnt | is the number of objects in the returnStruct buffer |
Reimplemented from UResVarPool.
Referenced by UFuncPiCam().
|
virtual |
Function to implement an inter plug-in method call using UVariables as parameter (and return value). Structures of the base type UDatabase (but not UVariables) may be returned in the returnStruct pointer array. The returnStructCnt should be set to returned count, if values are returned.
name | is the name of the called function |
paramOrder | is a string with one char for each parameter in the call - d is double, s is string, c is class object. |
params | is an array of UVariable pointers, one pointer for each character in paramOrder. NB! params are not declared as constant, and may be used to return values. |
returnStruct | is an array of class object pointers that can be used as parameters or return objects (may be NULL) |
returnStructCnt | is the number of objects in the returnStruct buffer |
Reimplemented from UVarMethodImplement.
Referenced by UFuncPiCam().
|
private |
Open camera
Referenced by UFuncPiCam().
void UFuncPiCam::run | ( | ) |
Run receive thread
References UFunctionBase::aliasName, CCamera::BeginReadFrame(), UImage::camDevice, CCamera::EndReadFrame(), UVariable::getBool(), UCamPool::getCam(), UCamRad::getCamPar(), UImage::getData(), UImage::getDataSize(), UCamBase::getDevNum(), UCamPar::getFocalLength(), UCamPar::getHx(), UCamPar::getHy(), UImagePool::getImage(), UImage::getImageTime(), UVariable::getInt(), UCamPar::getK1(), UCamPar::getK2(), UFunctionBase::getStaticResource(), UImage::imageNumber, img, UImage::imgTime, ULogFile::isLogOpen(), lastLoopTime, ULock::lock(), logFileTest(), logImage, logImageToFile(), UCamPool::makeDevice(), newImg, UTime::Now(), UTime::now(), oldCamDevC, oldCamDevD, UPixel::p1, UPixel::p2, UPixel::p3, paramLock, picam, PYRAMID_LEVELS_MAX, UVariable::setBool(), UCamRad::setCameraParameters(), UImage::setColorType(), UVariable::setInt(), UCamMounted::setMountName(), UImage::setSize(), UVariable::setTime(), UCamBase::setTypeName(), UServerPush::setUpdated(), UFunctionBase::silent, StartCamera(), StopCamera(), threadRunning, threadStop, ULock::tryLock(), ULock::unlock(), UImage::updated(), varCamDeviceNum, varFramerate, varImageLogN, varIsOpen, varPyramidLevels, varResolution, varSilent, varTime, USemaphore::wait(), and Wait().
Referenced by startUFuncPiCamThread(), and UFuncPiCam().
void UFuncPiCam::runAlive | ( | ) |
Alive thread to wake image thread at times
References aliveThreadRunning, aliveThreadStop, RASPICAM_CAMERA_PARAMETERS::awbMode, CCamera::CameraComponent, RASPICAM_CAMERA_PARAMETERS::exposureMeterMode, RASPICAM_CAMERA_PARAMETERS::exposureMode, UVariable::getInt(), RASPICAM_CAMERA_PARAMETERS::ISO, newImg, paramLock, picam, ULock::post(), PYRAMID_LEVELS_MAX, raspicamcontrol_get_all_parameters(), raspicamcontrol_set_awb_mode(), raspicamcontrol_set_exposure_mode(), raspicamcontrol_set_ISO(), raspicamcontrol_set_metering_mode(), raspicamcontrol_set_shutter_speed(), UVariable::setInt(), RASPICAM_CAMERA_PARAMETERS::shutter_speed, ULock::tryLock(), ULock::unlock(), varExposureMeter, varExposureMode, varGain, varPyramidLevels, varShutter, varWhiteBal, and Wait().
Referenced by startUFuncPiCamAliveThread(), and UFuncPiCam().
|
private |
start read thread
References aliveThreadHandle, aliveThreadRunning, aliveThreadStop, startUFuncPiCamAliveThread(), startUFuncPiCamThread(), threadHandle, threadRunning, and threadStop.
Referenced by createResources(), and UFuncPiCam().
|
privatevirtual |
stop read thread
andWait | waits until thread is terminated, when false, then the call returns when the stop flag is set (i.e. immidiately). |
Reimplemented from UResBase.
References aliveThreadHandle, aliveThreadRunning, aliveThreadStop, threadHandle, threadRunning, and threadStop.
Referenced by UFuncPiCam(), and ~UFuncPiCam().
|
private |
Referenced by createResources().
|
private |
|
private |
alive thread runnung flag
Referenced by runAlive(), start(), and stop().
|
private |
alive stop thread flag
Referenced by runAlive(), start(), and stop().
|
private |
number of accepted video frames (rgb or ir)
Referenced by init().
|
private |
frame count for logging
|
private |
variable for frame rate calculation
|
private |
variable for frame rate calculation
|
private |
image buffer for color in 3d cloud
Referenced by init(), and ~UFuncPiCam().
|
private |
Kinect loop keep-alive time
Referenced by handleNormal(), and run().
|
private |
General Logfile
Referenced by createResources(), handleNormal(), logFileTest(), and ~UFuncPiCam().
|
private |
Logfile
Referenced by createResources(), handleNormal(), init(), logFileTest(), logImageToFile(), run(), and ~UFuncPiCam().
|
private |
pointer to video (color or IR) image to log
Referenced by init().
|
staticprivate |
|
private |
semaphore to indicate new image is available
Referenced by run(), and runAlive().
|
private |
last used focal length for rectified image
Referenced by init().
|
private |
Referenced by init().
|
private |
|
private |
lock for parameters
Referenced by run(), and runAlive().
|
private |
PI camera class.
Referenced by run(), and runAlive().
|
staticprivate |
Referenced by run(), and runAlive().
|
private |
|
private |
|
private |
|
private |
Referenced by createResources(), and run().
|
private |
Referenced by createResources(), and runAlive().
|
private |
Referenced by createResources(), and runAlive().
|
private |
Referenced by createResources(), and run().
|
private |
Referenced by createResources(), and runAlive().
|
private |
Referenced by createResources(), handleNormal(), logFileTest(), logImageToFile(), and run().
|
private |
Referenced by createResources(), handleNormal(), and run().
|
private |
Referenced by createResources(), run(), and runAlive().
|
private |
Referenced by createResources(), and run().
|
private |
Referenced by createResources(), and runAlive().
|
private |
processing parameters
Referenced by createResources(), handleNormal(), and run().
|
private |
Referenced by createResources(), and run().
|
private |
Pointers to "own" global variables.
Referenced by createResources().
|
private |
Referenced by createResources(), and runAlive().
|
private |
Short explanation to why processing failed