X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=include%2Farray2d.h;h=5eb23b3804b3e66424399ff806f99672da05cc71;hp=30b92d474d264b6025bc79bcaa7e7f6cda808f92;hb=12e2c29153a0f55ac23bdeec06b404638672985b;hpb=2451ac413848718a1dd666ce6f6464e974680f47 diff --git a/include/array2d.h b/include/array2d.h index 30b92d4..5eb23b3 100644 --- a/include/array2d.h +++ b/include/array2d.h @@ -9,8 +9,14 @@ ** This is part of the CTSim program ** Copyright (C) 1983-2000 Kevin Rosenberg ** -** $Id: array2d.h,v 1.3 2000/06/09 01:35:33 kevin Exp $ +** $Id: array2d.h,v 1.5 2000/06/19 19:04:05 kevin Exp $ ** $Log: array2d.h,v $ +** Revision 1.5 2000/06/19 19:04:05 kevin +** reorganized header files +** +** Revision 1.4 2000/06/09 11:03:08 kevin +** Made ImageFile inherit from Array2dFile +** ** Revision 1.3 2000/06/09 01:35:33 kevin ** Convert MPI structure to C++ class ** @@ -32,44 +38,43 @@ #ifndef ARRAY2D_H #define ARRAY2D_H -#include +#include "ctsupport.h" + template class Array2d { - private: - unsigned int nx; - unsigned int ny; - public: - - T** array_data; - Array2d (unsigned int x, unsigned int y) + : nx(x), ny(y), array_data(0) { - nx = x; - ny = y; - array_data = new T*[nx]; - - for (unsigned int i = 0; i < nx; i++) - array_data[i] = new T[ny]; + allocArray(); } + Array2d (void) + : array_data(0), nx(0), ny(0) + {} ~Array2d () { - for (int i = 0; i < nx; i++) - delete array_data[i]; - delete array_data; + deleteArray(); } + void initSetSize (unsigned int x, unsigned int y) + { + nx = x; + ny = y; + deleteArray(); + allocArray(); + } + T** getArray (void) const { return array_data; } T* getColumn (unsigned int x) const - { return array_data[x]; } + { return (array_data ? array_data[x] : NULL); } T getPoint (unsigned int x, unsigned int y) const - { return (array_data[x][y]); } + { return (array_data ? array_data[x][y] : NULL); } unsigned int sizeofPixel (void) const { return sizeof(T); } @@ -79,6 +84,33 @@ class Array2d { unsigned int sizeofArray (void) const { return (sizeof(T) * nx * ny); } + + + private: + unsigned int nx; + unsigned int ny; + T** array_data; + + void allocArray (void) + { + array_data = new T*[nx]; + + for (unsigned int i = 0; i < nx; i++) + array_data[i] = new T[ny]; + } + + void deleteArray (void) + { + if (array_data) { + for (int i = 0; i < nx; i++) + delete array_data[i]; + delete array_data; + } + } + + + Array2d& operator= (const Array2d& rhs); + Array2d (const Array2d& rhs); // copy constructor };