Logo Search packages:      
Sourcecode: aeskulap version File versions  Download package

poolstudy.cpp

/*
    Aeskulap ImagePool - DICOM abstraction library
    Copyright (C) 2005  Alexander Pipelka

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Library General Public
    License as published by the Free Software Foundation; either
    version 2 of the License, or (at your option) any later version.

    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    Library General Public License for more details.

    You should have received a copy of the GNU Library General Public
    License along with this library; if not, write to the Free
    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA

    Alexander Pipelka
    pipelka@teleweb.at

    Last Update:      $Author: braindead $
    Update Date:      $Date: 2007/05/10 14:29:59 $
    Source File:      $Source: /sources/aeskulap/aeskulap/imagepool/poolstudy.cpp,v $
    CVS/RCS Revision: $Revision: 1.7 $
    Status:           $State: Exp $
*/

#include "poolstudy.h"
#include "imagepool.h"
#include <iostream>

namespace ImagePool {

Study::Study() : 
m_max_series(0),
m_max_instances(0),
m_cur_instances(0) {
}

Study::Study(const std::string& studyinstanceuid) :
m_max_series(0),
m_max_instances(0),
m_cur_instances(0),
m_studyinstanceuid(studyinstanceuid) {
}

Study::~Study() {
      for(iterator i = begin(); i != end(); i++) {
            i->second.clear();
      }
      m_list.clear();
}

const std::string& Study::studyinstanceuid() {
      return m_studyinstanceuid;
}

const std::string& Study::patientsname() {
      return m_patientsname;
}

const std::string& Study::patientsbirthdate() {
      return m_patientsbirthdate;
}

const std::string& Study::studydescription() {
      return m_studydescription;
}

const std::string& Study::studydate() {
      return m_studydate;
}

const std::string& Study::studytime() {
      return m_studytime;
}

const std::string& Study::patientssex() {
      return m_patientssex;
}

void Study::set_instancecount(int cur, int max) {
      if(max != -1) {
            m_max_instances = max;
      }
      
      if(cur != -1) {
            m_cur_instances = cur;
      }
      
      //std::cout << "instances current: " << m_cur_instances << std::endl;
      //std::cout << "instances max: " << m_max_instances << std::endl;
}

int Study::get_instancecount() {
      return m_cur_instances;
}

void Study::emit_progress() {
      if(m_max_instances == 0) {
            return;
      }

      signal_progress((double)m_cur_instances / (double)m_max_instances);
}

const std::string& Study::server() {
      return m_server;
}

int Study::seriescount() {
      return m_max_series;
}

int Study::studyrelatedinstances() {
      return m_max_instances;
}

void Study::set_seriescount(int series) {
      m_max_series = series;
}

int Study::has_3d_information() {
      int c = 0;
      for(iterator i = begin(); i != end(); i++) {
            if(i->second->has_3d_information()) {
                  c++;
            }
      }
      
      return c;
}

} // namespace ImagePool

Generated by  Doxygen 1.6.0   Back to index