Developer Documentation
VolumeMeshObjectInfoPlugin.cc
1 /*===========================================================================*\
2 * *
3 * OpenFlipper *
4  * Copyright (c) 2001-2015, RWTH-Aachen University *
5  * Department of Computer Graphics and Multimedia *
6  * All rights reserved. *
7  * www.openflipper.org *
8  * *
9  *---------------------------------------------------------------------------*
10  * This file is part of OpenFlipper. *
11  *---------------------------------------------------------------------------*
12  * *
13  * Redistribution and use in source and binary forms, with or without *
14  * modification, are permitted provided that the following conditions *
15  * are met: *
16  * *
17  * 1. Redistributions of source code must retain the above copyright notice, *
18  * this list of conditions and the following disclaimer. *
19  * *
20  * 2. Redistributions in binary form must reproduce the above copyright *
21  * notice, this list of conditions and the following disclaimer in the *
22  * documentation and/or other materials provided with the distribution. *
23  * *
24  * 3. Neither the name of the copyright holder nor the names of its *
25  * contributors may be used to endorse or promote products derived from *
26  * this software without specific prior written permission. *
27  * *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39 * *
40 \*===========================================================================*/
41 
42 
43 //=============================================================================
44 //
45 // CLASS InfoVolumeMeshObjectPlugin - IMPLEMENTATION
46 //
47 //=============================================================================
48 
49 
50 //== INCLUDES =================================================================
51 
52 #include "VolumeMeshObjectInfoPlugin.hh"
58 
59 //== IMPLEMENTATION ==========================================================
60 
61 
62 InfoVolumeMeshObjectPlugin::InfoVolumeMeshObjectPlugin()
63 {
64 }
65 
66 InfoVolumeMeshObjectPlugin::~InfoVolumeMeshObjectPlugin()
67 {
68 }
69 
70 void InfoVolumeMeshObjectPlugin::updateInfoBar()
71 {
72  if (!infoBar_) {
73  return;
74  }
75  if ( PluginFunctions::targetCount() != 1) {
76  infoBar_->hideCounts();
77  return;
78  }
79  BaseObjectData *target = nullptr;
82  {
83  target = obj;
84  break;
85  }
86 
87  if (!target) {
88  infoBar_->hideCounts();
89  return;
90  }
91  auto *pmo = PluginFunctions::polyhedralMeshObject(target);
92  auto *hmo = PluginFunctions::hexahedralMeshObject(target);
93  auto *tmo = PluginFunctions::tetrahedralMeshObject(target);
94  if (pmo && pmo->mesh()) {
95  infoBar_->showCounts("Poly", pmo->mesh());
96  } else if (hmo && hmo->mesh()) {
97  infoBar_->showCounts("Hex", hmo->mesh());
98  } else if (tmo && tmo->mesh()) {
99  infoBar_->showCounts("Tet", tmo->mesh());
100  } else {
101  infoBar_->hideCounts();
102  }
103 }
104 
105 
106 void InfoVolumeMeshObjectPlugin::initializePlugin()
107 {
108 }
109 
112 {
113  setDescriptions();
114 
115  if ( OpenFlipper::Options::gui()) {
116 
117  infoBar_ = new VolumeMeshInfoBar();
118 
119  emit addWidgetToStatusbar(infoBar_);
120  }
121 }
122 
123 //------------------------------------------------------------------------------
124 
125 void InfoVolumeMeshObjectPlugin::slotObjectUpdated( int _identifier , const UpdateType& _type)
126 {
127  updateInfoBar();
128 }
129 
130 //------------------------------------------------------------------------------
131 
132 void InfoVolumeMeshObjectPlugin::slotObjectSelectionChanged( int _identifier )
133 {
134  slotObjectUpdated( _identifier , UPDATE_ALL );
135 }
136 
137 //------------------------------------------------------------------------------
138 
139 void InfoVolumeMeshObjectPlugin::slotAllCleared()
140 {
141 }
142 
143 
#define DATA_POLYHEDRAL_MESH
TetrahedralMeshObject * tetrahedralMeshObject(BaseObjectData *_object)
Cast an BaseObject to an TetrahedralMeshObject if possible.
const UpdateType UPDATE_ALL(UpdateTypeSet(1))
Identifier for all updates.
PolyhedralMeshObject * polyhedralMeshObject(BaseObjectData *_object)
Cast an BaseObject to an PolyhedralMeshObject if possible.
void pluginsInitialized()
initialize the plugin
#define DATA_TETRAHEDRAL_MESH
#define DATA_HEXAHEDRAL_MESH
Predefined datatypes.
Definition: DataTypes.hh:83
int targetCount()
Get the number of target objects.
Update type class.
Definition: UpdateType.hh:59
const QStringList TARGET_OBJECTS("target")
Iterable object range.
ObjectRange objects(IteratorRestriction _restriction, DataType _dataType)
Iterable object range.
void setDescriptions()
set scripting slot descriptions
HexahedralMeshObject * hexahedralMeshObject(BaseObjectData *_object)
Cast an BaseObject to an HexahedralMeshObject if possible.