Rev 1221 | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
1033 | werner | 1 | /******************************************************************************************** |
2 | ** iLand - an individual based forest landscape and disturbance model |
||
3 | ** http://iland.boku.ac.at |
||
4 | ** Copyright (C) 2009- Werner Rammer, Rupert Seidl |
||
5 | ** |
||
6 | ** This program is free software: you can redistribute it and/or modify |
||
7 | ** it under the terms of the GNU General Public License as published by |
||
8 | ** the Free Software Foundation, either version 3 of the License, or |
||
9 | ** (at your option) any later version. |
||
10 | ** |
||
11 | ** This program is distributed in the hope that it will be useful, |
||
12 | ** but WITHOUT ANY WARRANTY; without even the implied warranty of |
||
13 | ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
||
14 | ** GNU General Public License for more details. |
||
15 | ** |
||
16 | ** You should have received a copy of the GNU General Public License |
||
17 | ** along with this program. If not, see <http://www.gnu.org/licenses/>. |
||
18 | ********************************************************************************************/ |
||
909 | werner | 19 | #ifndef ABEGRID_H |
20 | #define ABEGRID_H |
||
873 | werner | 21 | #include "layeredgrid.h" |
905 | werner | 22 | namespace ABE { |
873 | werner | 23 | class FMStand; // forward |
939 | werner | 24 | class Agent; // forward |
873 | werner | 25 | } |
26 | |||
909 | werner | 27 | /** Helper class for visualizing ABE management data. |
873 | werner | 28 | */ |
905 | werner | 29 | typedef ABE::FMStand* FMStandPtr; |
909 | werner | 30 | class ABELayers: public LayeredGrid<FMStandPtr> { |
873 | werner | 31 | public: |
909 | werner | 32 | ~ABELayers(); |
873 | werner | 33 | void setGrid(Grid<FMStandPtr> &grid) { mGrid = &grid; } |
34 | double value(const FMStandPtr &data, const int index) const; |
||
1014 | werner | 35 | const QVector<LayeredGridBase::LayerElement> &names(); |
877 | werner | 36 | const QString labelvalue(const int value, const int index) const; |
873 | werner | 37 | void registerLayers(); |
877 | werner | 38 | void clearClasses(); // clear ID and agent classes... |
873 | werner | 39 | private: |
1014 | werner | 40 | QVector<LayeredGridBase::LayerElement> mNames; |
939 | werner | 41 | mutable QHash<const ABE::Agent*, int > mAgentIndex; |
877 | werner | 42 | mutable QHash<QString, int> mUnitIndex; |
43 | mutable QHash<int, int> mStandIndex; |
||
1058 | werner | 44 | mutable QHash<QString, int> mSTPIndex; |
873 | werner | 45 | }; |
46 | |||
939 | werner | 47 | |
48 | |||
909 | werner | 49 | #endif // ABEGRID_H |