00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038 #include "Component/ModelManager.H"
00039 #include "Image/Image.H"
00040 #include "Psycho/PsychoDisplay.H"
00041 #include "Psycho/EyeTrackerConfigurator.H"
00042 #include "Psycho/EyeTracker.H"
00043 #include "Psycho/PsychoOpts.H"
00044 #include "Component/EventLog.H"
00045 #include "Component/ComponentOpts.H"
00046 #include "Raster/Raster.H"
00047 #include "Util/MathFunctions.H"
00048 #include "Util/Types.H"
00049 #include "GameBoard/basic-graphics.H"
00050 #include "GameBoard/resize.h"
00051 #include <sys/types.h>
00052 #include <dirent.h>
00053 #include <errno.h>
00054 #include <vector>
00055 #include <string>
00056 #include <iostream>
00057 #include <SDL/SDL.h>
00058 #include <SDL/SDL_image.h>
00059 #include <stdio.h>
00060 #include <stdlib.h>
00061 #include <sstream>
00062 #include <time.h>
00063 #include "Image/DrawOps.H"
00064 #include "GameBoard/resize.h"
00065 #include <iostream>
00066 #include <fstream>
00067 #include <set>
00068 #include <algorithm>
00069 using namespace std;
00070 map<string,string> argMap ;
00071
00072
00073
00074 int getdir (string dir, vector<string> &files ,string ext)
00075 {
00076 DIR *dp;
00077 struct dirent *dirp;
00078 if((dp = opendir(dir.c_str())) == NULL) {
00079 cout << "Error(" << errno << ") opening " << dir << endl;
00080 return errno;
00081 }
00082 string fn = "" ;
00083 size_t found;
00084 string extension = "" ;
00085 while ((dirp = readdir(dp)) != NULL) {
00086 fn = string(dirp->d_name) ;
00087 found = fn.find_last_of(".");
00088 if(found > 0 && found <1000){
00089 extension = fn.substr(found) ;
00090 if(extension.compare(ext)== 0 )
00091 files.push_back(dir+"/"+fn);
00092 }
00093 }
00094 closedir(dp);
00095 return 0;
00096 }
00097
00098 string getCorrespondingDataFile(string fn, vector<string> files){
00099 uint pos = fn.find_last_of("/");
00100 string lp = fn.substr(pos+1) ;
00101 lp = lp.substr(0,lp.find("."));
00102 for( uint i = 0 ; i < files.size() ; i++ ){
00103 uint posd = files[i].find_last_of("/");
00104 string lpd = files[i].substr(posd+1) ;
00105 lpd = lpd.substr(0,lpd.find("."));
00106 if(lpd.compare(lp) == 0) return files[i] ;
00107 }
00108 return "" ;
00109 }
00110 void overlay_rect(SDL_Surface* surf,Point2D<int> location , Point2D<int> size , Uint32 bc){
00111 Point2D<int> corner = Point2D<int>(location.i- size.i/2 , location.j - size.j/2) ;
00112 drawRectangle(surf,bc,corner.i,corner.j,size.i -1,size.j -1 ,1);
00113
00114 }
00115
00116
00117 int addArgument(const string st,const string delim="="){
00118 int i = st.find(delim) ;
00119 argMap[st.substr(0,i)] = st.substr(i+1);
00120
00121 return 0 ;
00122 }
00123
00124 std::string getArgumentValue(string arg){
00125 return argMap[arg] ;
00126 }
00127
00128 std::string getUsageComment(){
00129
00130 string com = string("\nlist of arguments : \n");
00131
00132 com += "\ndelay=[>=0] (the delaly for overlaying marks) {default=0}\n";
00133 com += "\nlogfile=[logfilename.psy] {default = eyemarkup.psy}\n" ;
00134 com += "\nmode=[1..2] (1 for static , 2 for dynamic) {default=2}\n" ;
00135 com += "\nimage-dir=[path to directory of images]\n" ;
00136 com += "\ndata-dir=[path to directory of .ceyeS files]\n" ;
00137 return com ;
00138 }
00139
00140 extern "C" int main(const int argc, char** argv)
00141 {
00142 ModelManager manager("Psycho Skin");
00143 nub::soft_ref<PsychoDisplay> d(new PsychoDisplay(manager));
00144
00145 MYLOGVERB = LOG_INFO;
00146 argMap["mode"] = "2" ;
00147 argMap["logfile"]="eyemarkup.psy" ;
00148 argMap["image-dir"]=".";
00149 argMap["data-dir"] = "." ;
00150 argMap["delay"]="0" ;
00151
00152 manager.addSubComponent(d);
00153 nub::soft_ref<EventLog> el(new EventLog(manager));
00154 manager.addSubComponent(el);
00155 d->setEventLog(el);
00156 if (manager.parseCommandLine(argc, argv,
00157 "at least one argument needed", 1, -1)==false){
00158 cout<<getUsageComment()<<endl;
00159 return(1);
00160 }
00161
00162 for(uint i = 0 ; i < manager.numExtraArgs() ; i++){
00163 addArgument(manager.getExtraArg(i),std::string("=")) ;
00164 }
00165
00166 manager.setOptionValString(&OPT_EventLogFileName, argMap["logfile"]);
00167 manager.start();
00168
00169 string dir = argMap["image-dir"];
00170 vector<string> imfiles = vector<string>();
00171 getdir(dir,imfiles,".png");
00172
00173 dir = argMap["data-dir"];
00174 vector<string> datafiles = vector<string>();
00175 getdir(dir,datafiles,".ceyeS");
00176
00177 while(imfiles.size() > 0){
00178 string imfilename = imfiles[0] ;
00179 imfiles.erase(imfiles.begin());
00180 LINFO("%s", imfilename.c_str());
00181
00182
00183
00184
00185
00186
00187
00188
00189 Uint32 blue = d->getUint32color(PixRGB<byte>(0, 0, 255));
00190 Uint32 green = d->getUint32color(PixRGB<byte>(0,255,0) );
00191 Uint32 red = d->getUint32color(PixRGB<byte>(255,0,0) );
00192 Uint32 saccade_green = d->getUint32color(PixRGB<byte>(0,150,0) );
00193 Uint32 magenta = d->getUint32color(PixRGB<byte>(0,255,255) );
00194 Uint32 black = d->getUint32color(PixRGB<byte>(0,0,0) );
00195 map<string,Uint32> colormap = map<string,Uint32>() ;
00196 colormap["0"] = blue ; colormap["1"] = green ;colormap["2"] = red ;
00197 colormap["3"] = saccade_green ; colormap["4"]=magenta ; colormap["5"]= black ;
00198
00199
00200 string datafilename = getCorrespondingDataFile(imfilename,datafiles);
00201 if(datafilename.size()!=0){
00202
00203 SDL_Surface* im = load_image(imfilename) ;
00204 float rsf = min((float)d->getWidth()/(float)im->w , (float)d->getHeight()/(float)im->h ) ;
00205 im = SDL_Resize(im , rsf, 5) ;
00206 SDL_Rect offset ;
00207 offset.x= (d->getWidth() - im->w) /2;
00208 offset.y=(d-> getHeight() - im->h) /2;
00209
00210 ifstream inFile( datafilename.c_str() , ios::in);
00211 if (! inFile)
00212 {
00213 LINFO("profile '%s' not found!" , datafilename.c_str());
00214 return -1;
00215 }
00216 Point2D<int> rectsize = Point2D<int>(6,6) ;
00217 Point2D<int> loc ;
00218 char ch[1000];
00219
00220 while (inFile.getline(ch , 1000) ){
00221 string line = ch;
00222
00223 uint pos = line.find(" ");
00224 loc.i = (int) (rsf*atof(line.substr(0,pos).c_str())) ;
00225 line = line.substr(pos+1);
00226 pos = line.find(" ");
00227 loc.j = (int) (rsf*atof(line.substr(0,pos).c_str())) ;
00228 string colorcode = line.substr(line.size()-1) ;
00229 if (loc.i > 4 && loc.j > 4 )
00230 overlay_rect(im,loc,rectsize,colormap[colorcode]);
00231 if(argMap["mode"].compare("2")==0)
00232 d->waitFrames(atoi(argMap["delay"].c_str()));
00233 d->displaySDLSurfacePatch(im , &offset,NULL , -2,false, true) ;
00234 }
00235 d->waitForMouseClick() ;
00236 dumpSurface(im) ;
00237
00238 }
00239
00240
00241
00242
00243 }
00244 manager.stop();
00245 return 0 ;
00246 }
00247