Colin Stearns
/
qcControl
QC Control software
Fork of dgps by
handle/handleCamera.cpp
- Committer:
- dylanembed123
- Date:
- 2014-04-05
- Revision:
- 12:e42985e3ea64
- Parent:
- 9:da906eeac51e
- Child:
- 13:a6d3cf2b018e
File content as of revision 12:e42985e3ea64:
#include "handleCamera.h" void ImageHandle::setup(){ char* version = cam.getVersion(); outputDevice.printf("Version %s\n",version); uint8_t targetSize=VC0706_160x120;//VC0706_640x480;//VC0706_160x120; cam.setImageSize(targetSize); uint8_t realSize=cam.getImageSize(); } void ImageHandle::take(){ if (! cam.takePicture()) { outputDevice.printf("Failed to snap!\n"); while(1){} } unsigned int sID=getPS().getSuperID(); getPS().sendPacket(sID,NULL,0,PT_IMAGE); int size=cam.frameLength(); outputDevice.printf("Image Start\n",size); int i; for(i=0;i<size;){ // read 32 bytes at a time; uint8_t bytesToRead = std::min(64, size-i); // change 32 to 64 for a speedup but may not work with all setups! uint8_t bytesRead=0; char* buffer = (char*)cam.readPicture(bytesToRead,&bytesRead); getPS().sendPacket(sID,buffer,bytesRead); //for(int a=0;a<bytesRead;a++){outputDevice.putc(buffer[a]);} i+=bytesRead; } outputDevice.printf("Image End\n",size); getPS().sendPacket(sID,NULL,0,PT_END); } bool ImageHandle::check(){ return true; } void ImageHandle::run(){ if(!initialized){ initialized=true; outputDevice.printf("Setup cam\n"); setup(); } if(check()){ take(); while(true){} } }