volmetrics
changeset 5:92c163c939be
Volume::load
author | Eleni Maria Stea <elene.mst@gmail.com> |
---|---|
date | Fri, 17 Jan 2014 23:45:56 +0200 (2014-01-17) |
parents | 1fbbe10c8e08 |
children | e6485ef45e6e |
files | data/test1.vol src/volume.cc src/volume.h |
diffstat | 3 files changed, 95 insertions(+), 0 deletions(-) [+] |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/data/test1.vol Fri Jan 17 23:45:56 2014 +0200 1.3 @@ -0,0 +1,19 @@ 1.4 +VOLUME 1.5 +zaspect = 1 1.6 + 1.7 +SLICES 1.8 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0001.png 1.9 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0003.png 1.10 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0004.png 1.11 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0005.png 1.12 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0006.png 1.13 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0007.png 1.14 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0008.png 1.15 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0009.png 1.16 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0010.png 1.17 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0011.png 1.18 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0012.png 1.19 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0013.png 1.20 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0014.png 1.21 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0015.png 1.22 +/home/eleni/code/med/test1/data/la_colonoscopie/IM-0001-0016.png
2.1 --- a/src/volume.cc Sat Jan 11 23:49:58 2014 +0200 2.2 +++ b/src/volume.cc Fri Jan 17 23:45:56 2014 +0200 2.3 @@ -1,14 +1,70 @@ 2.4 +#include <ctype.h> 2.5 +#include <errno.h> 2.6 #include <stdio.h> 2.7 +#include <string.h> 2.8 + 2.9 +#include <string> 2.10 +#include <vector> 2.11 2.12 #include "volume.h" 2.13 2.14 +static char *strip_whitespaces(char *buf); 2.15 + 2.16 Volume::Volume() 2.17 { 2.18 width = height = 0; 2.19 + zaspect = 1; 2.20 } 2.21 2.22 bool Volume::load_volume(const char *fname) 2.23 { 2.24 + FILE *fp = fopen(fname, "r"); 2.25 + if(!fp) { 2.26 + fprintf(stderr, "Failed to open file: %s: %s\n", fname, strerror(errno)); 2.27 + return false; 2.28 + } 2.29 + 2.30 + char buf[512]; 2.31 + if(!fgets(buf, sizeof buf, fp)) { 2.32 + fprintf(stderr, "Empty file: %s.\n", fname); 2.33 + return false; 2.34 + } 2.35 + if(strstr(buf, "VOLUME") != buf) { 2.36 + fprintf(stderr, "Invalid volume file format: %s\n", fname); 2.37 + return false; 2.38 + } 2.39 + 2.40 + bool reading_slices = false; 2.41 + std::vector<std::string> img_fnames; 2.42 + 2.43 + while(fgets(buf, sizeof buf, fp)) { 2.44 + char *line = strip_whitespaces(buf); 2.45 + if(!line || *line == 0 || *line == '#') 2.46 + continue; 2.47 + 2.48 + if(reading_slices == false) { 2.49 + if(strcmp(line, "SLICES") == 0) 2.50 + reading_slices = true; 2.51 + 2.52 + sscanf(line, "zaspect = %f", &zaspect); 2.53 + } 2.54 + else { 2.55 + img_fnames.push_back(line); 2.56 + } 2.57 + } 2.58 + 2.59 + fclose(fp); 2.60 + 2.61 + for(size_t i=0; i<img_fnames.size(); i++) { 2.62 + Image img; 2.63 + if(img.load(img_fnames[i].c_str())) { 2.64 + push_slice(std::move(img)); 2.65 + } 2.66 + else { 2.67 + fprintf(stderr, "Failed to load slice: %s\n", img_fnames[i].c_str()); 2.68 + } 2.69 + } 2.70 + 2.71 return true; 2.72 } 2.73 2.74 @@ -28,3 +84,22 @@ 2.75 slices.push_back(slice); 2.76 return true; 2.77 } 2.78 + 2.79 +void Volume::draw() 2.80 +{ 2.81 +} 2.82 + 2.83 +static char *strip_whitespaces(char *buf) 2.84 +{ 2.85 + while(*buf && isspace(*buf)) 2.86 + buf++; 2.87 + 2.88 + if(!*buf) 2.89 + return 0; 2.90 + 2.91 + char *end = buf + strlen(buf) - 1; 2.92 + while(end > buf && isspace(*end)) 2.93 + end--; 2.94 + end[1] = 0; 2.95 + return buf; 2.96 +}