X-Git-Url: http://git.kpe.io/?p=ctsim.git;a=blobdiff_plain;f=include%2Farray2d.h;h=d397e5f45160ce4824f5245eca3bfed47efe9cad;hp=8c323f4034ca45f3b1449b3ba3f2b50c7db3c2ed;hb=f13a8c004b8f182b42d9e4df2bcd7c7f030bf1ad;hpb=bfcc769cf8019eabc8c65c07257c8dbee4b4c977 diff --git a/include/array2d.h b/include/array2d.h index 8c323f4..d397e5f 100644 --- a/include/array2d.h +++ b/include/array2d.h @@ -1,15 +1,13 @@ /***************************************************************************** ** FILE IDENTIFICATION ** -** Name: array2d.h +** Name: array2d.h ** Purpose: 2-dimension array classes -** Programmer: Kevin Rosenberg -** Date Started: June 2000 +** Programmer: Kevin Rosenberg +** Date Started: June 2000 ** ** This is part of the CTSim program -** Copyright (C) 1983-2000 Kevin Rosenberg -** -** $Id: array2d.h,v 1.8 2000/09/02 05:10:39 kevin Exp $ +** Copyright (c) 1983-2009 Kevin Rosenberg ** ** This program is free software; you can redistribute it and/or modify ** it under the terms of the GNU General Public License (version 2) as @@ -31,49 +29,49 @@ #include "ctsupport.h" -template +template class Array2d { public: Array2d (unsigned int x, unsigned int y) - : m_nx(x), m_ny(y), array_data(0) - { - allocArray(); - } + : m_nx(x), m_ny(y), array_data(0) + { + allocArray(); + } Array2d () - : m_nx(0), m_ny(0), array_data(0) - {} + : m_nx(0), m_ny(0), array_data(0) + {} ~Array2d () - { - deleteArray(); - } - + { + deleteArray(); + } + void initSetSize (unsigned int x, unsigned int y) - { - m_nx = x; - m_ny = y; - deleteArray(); - allocArray(); - } + { + m_nx = x; + m_ny = y; + deleteArray(); + allocArray(); + } T** getArray () const - { return array_data; } + { return array_data; } T* getColumn (unsigned int x) const - { return (array_data ? array_data[x] : NULL); } + { return (array_data ? array_data[x] : NULL); } T getPoint (unsigned int x, unsigned int y) const - { return (array_data ? array_data[x][y] : NULL); } + { return (array_data ? array_data[x][y] : NULL); } - unsigned int sizeofPixel () const - { return sizeof(T); } + unsigned int sizeofPixel () const + { return sizeof(T); } unsigned int sizeofColumn () const - { return (sizeof(T) * m_ny); } + { return (sizeof(T) * m_ny); } unsigned int sizeofArray () const - { return (sizeof(T) * m_nx * m_ny); } + { return (sizeof(T) * m_nx * m_ny); } private: @@ -82,25 +80,25 @@ class Array2d { T** array_data; void allocArray () - { - if (array_data) - deleteArray(); + { + if (array_data) + deleteArray(); + + array_data = new T*[m_nx]; - array_data = new T*[m_nx]; - - for (unsigned int i = 0; i < m_nx; i++) - array_data[i] = new T[m_ny]; - } + for (unsigned int i = 0; i < m_nx; i++) + array_data[i] = new T[m_ny]; + } void deleteArray () - { - if (array_data) { - for (unsigned int i = 0; i < m_nx; i++) - delete array_data [i]; - delete array_data; - array_data = NULL; - } - } + { + if (array_data) { + for (unsigned int i = 0; i < m_nx; i++) + delete array_data [i]; + delete array_data; + array_data = NULL; + } + } Array2d& operator= (const Array2d& rhs); //assignment operator