PluginCommunication.cc 7.98 KB
Newer Older
Jan Möbius's avatar
 
Jan Möbius committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
//=============================================================================
//
//                               OpenFlipper
//        Copyright (C) 2008 by Computer Graphics Group, RWTH Aachen
//                           www.openflipper.org
//
//-----------------------------------------------------------------------------
//
//                                License
//
//  OpenFlipper is free software: you can redistribute it and/or modify
//  it under the terms of the GNU Lesser General Public License as published by
//  the Free Software Foundation, either version 3 of the License, or
//  (at your option) any later version.
Jan Möbius's avatar
Jan Möbius committed
15
//
Jan Möbius's avatar
 
Jan Möbius committed
16
17
18
19
//  OpenFlipper 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 Lesser General Public License for more details.
Jan Möbius's avatar
Jan Möbius committed
20
//
Jan Möbius's avatar
 
Jan Möbius committed
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
//  You should have received a copy of the GNU Lesser General Public License
//  along with OpenFlipper.  If not, see <http://www.gnu.org/licenses/>.
//
//-----------------------------------------------------------------------------
//
//   $Revision$
//   $Author$
//   $Date$
//
//=============================================================================




//=============================================================================
//
//  CLASS Core - IMPLEMENTATION of Comunication with plugins
//
//=============================================================================


//== INCLUDES =================================================================

#include "Core.hh"

#include <QToolBox>

#include "OpenFlipper/BasePlugin/BaseInterface.hh"
#include "OpenFlipper/BasePlugin/ToolboxInterface.hh"
#include "OpenFlipper/BasePlugin/TextureInterface.hh"

52
53
#include "OpenFlipper/BasePlugin/PluginFunctions.hh"

Jan Möbius's avatar
Jan Möbius committed
54
//== IMPLEMENTATION ==========================================================
Jan Möbius's avatar
 
Jan Möbius committed
55
56
57

//========================================================================================
// ===             Object List Communication                       =======================
Jan Möbius's avatar
Jan Möbius committed
58
59
//========================================================================================

Jan Möbius's avatar
 
Jan Möbius committed
60
61
62
/** This function is called by a plugin if it changed something in the object list (source,target,...). The information is passed to all plugins.
 * @param _identifier Id of the updated object
 */
63
void Core::slotObjectUpdated(int _identifier) {
Jan Möbius's avatar
Jan Möbius committed
64
65
66
  if ( OpenFlipper::Options::doSlotDebugging() ) {
    if ( sender() != 0 ) {
      if ( sender()->metaObject() != 0 ) {
67
        emit log(LOGINFO,"updatedObject( " + QString::number(_identifier) + " ) called by " +
Jan Möbius's avatar
Jan Möbius committed
68
69
70
71
72
                 QString( sender()->metaObject()->className() ) );
      }
    }
  }

73
74
75
  // Disable redraws as everything here has to update the object only once
  OpenFlipper::Options::redrawDisabled(true);

76
  // If we are called for a special object, we update it ourself so the Plugins dont need to do that.
77
  BaseObject* object = 0;
78
  if ( _identifier != -1 ) {
79
    if ( !PluginFunctions::get_object(_identifier,object) ) {
80
81
82
83
84
      emit log(LOGERR,"updated_objects called for non existing object with id : " + QString::number(_identifier) );
      return;
    }
  }

Jan Möbius's avatar
Jan Möbius committed
85
  // just inform the plugins as we dont do anything else
86
  emit signalObjectUpdated(_identifier);
87

88
89
  if ( object != 0 )
    object->update();
90
91
92
93

  // Reenable redraws
  OpenFlipper::Options::redrawDisabled(false);

94
  updateView();
Jan Möbius's avatar
Jan Möbius committed
95
96
}

Jan Möbius's avatar
 
Jan Möbius committed
97
98
99
100
101
102
103
104
 /** This function is called if the active object has changed. The information is passed to all plugins.
 */
 void Core::slotActiveObjectChanged()
 {
    // just inform the plugins as we dont do anything else
    emit activeObjectChanged();
 }

Jan Möbius's avatar
Jan Möbius committed
105
//====================================================================================
Jan Möbius's avatar
 
Jan Möbius committed
106
107
// ===             Toolbox handling                                   =================
//=====================================================================================
Jan Möbius's avatar
Jan Möbius committed
108

Jan Möbius's avatar
 
Jan Möbius committed
109
110
111
112
113
114
115
 /** If the Toolbox is switched the toolboxActivated function of the each plugin that has a toolbox is called by this function.
  */
// void
// Core::slotToolboxSwitched(int _index)
// {
//    // Check all plugins
//    for ( uint i = 0 ; i < plugins.size(); ++i) {
Jan Möbius's avatar
Jan Möbius committed
116
//       if (plugins[i].toolboxindex == -1)
Jan Möbius's avatar
 
Jan Möbius committed
117
//          continue;
Jan Möbius's avatar
Jan Möbius committed
118
//
Jan Möbius's avatar
 
Jan Möbius committed
119
120
121
//       ToolboxInterface* toolboxPlugin = qobject_cast< ToolboxInterface * >(plugins[i].plugin);
//       if (! toolboxPlugin)
//          continue;
Jan Möbius's avatar
Jan Möbius committed
122
//
Jan Möbius's avatar
 
Jan Möbius committed
123
124
//       // Call the corresponding function of the plugins
//       if ( _index == plugins[i].toolboxindex ) {
Jan Möbius's avatar
Jan Möbius committed
125
//            toolboxPlugin->toolboxActivated(true);
Jan Möbius's avatar
 
Jan Möbius committed
126
//       } else {
Jan Möbius's avatar
Jan Möbius committed
127
//            toolboxPlugin->toolboxActivated(false);
Jan Möbius's avatar
 
Jan Möbius committed
128
129
130
131
132
133
134
135
136
137
138
139
140
//       }
//    }
// }

//========================================================================================
// ===             Texture Communication                       ===========================
//========================================================================================


/** Called by a plugin if it created a texture. The information is passed to all plugins. If a texture control plugin is available it has to react on the signal.\n
 * See in the documentation of the texture plugin interfaces for further detail.
*/
void Core::slotAddTexture( QString _textureName , QString _filename, uint _dimension) {
Jan Möbius's avatar
Jan Möbius committed
141
  emit addTexture(_textureName , _filename,_dimension);
Jan Möbius's avatar
 
Jan Möbius committed
142
143
144
145
146
147
}

/** Called by a plugin if a texture has to be updated. The information is passed to all plugins. The Plugin providing the given Texture should react on this event.\n
 * See in the documentation of the texture plugin interfaces for further detail.
*/
void Core::slotUpdateTexture( QString _name , int _identifier){
148
149
150
151
152
153
154
155
156
157

  if ( OpenFlipper::Options::doSlotDebugging() ) {
    if ( sender() != 0 ) {
      if ( sender()->metaObject() != 0 ) {
        emit log(LOGINFO,"slotUpdateTexture( "  + _name + " , " + QString::number(_identifier) + " ) called by " +
                 QString( sender()->metaObject()->className() ) );
      }
    }
  }

Jan Möbius's avatar
Jan Möbius committed
158
  emit updateTexture(_name, _identifier);
Jan Möbius's avatar
 
Jan Möbius committed
159
160
161
162
163
164
}

/** Called by a plugin if all textures should be updated. The information is passed to all plugins. All plugins providing textures should react on this event.\n
 * See in the documentation of the texture plugin interfaces for further detail.
*/
void Core::slotUpdateAllTextures( ){
Jan Möbius's avatar
Jan Möbius committed
165
  emit updateAllTextures();
Jan Möbius's avatar
 
Jan Möbius committed
166
167
168
169
170
171
}

/** Called by a plugin if the parameters of a texture should be changed. The information is passed to all plugins. A Texturecontrol plugin should react on this event.\n
 * See in the documentation of the texture plugin interfaces for further detail.
*/
void Core::slotSetTextureMode(QString _textureName ,QString _mode) {
Jan Möbius's avatar
Jan Möbius committed
172
  emit setTextureMode(_textureName,_mode);
Jan Möbius's avatar
 
Jan Möbius committed
173
174
175
176
177
178
}

/** Called by a plugin if it updated a texture. The information is passed to all plugins. If a texture control plugin is available it has to react on the signal and update the visualization of the texture.\n
 * See in the documentation of the texture plugin interfaces for further detail.
*/
void Core::slotTextureUpdated( QString _textureName , int _identifier ) {
179
180
181
182
183
184
185
186
  if ( OpenFlipper::Options::doSlotDebugging() ) {
    if ( sender() != 0 ) {
      if ( sender()->metaObject() != 0 ) {
        emit log(LOGINFO,"slotTextureUpdated( " + _textureName + " , " + QString::number(_identifier) + " ) called by " +
                 QString( sender()->metaObject()->className() ) );
      }
    }
  }
Jan Möbius's avatar
Jan Möbius committed
187
  emit updatedTextures(_textureName,_identifier);
Jan Möbius's avatar
 
Jan Möbius committed
188
189
190
191
192
193
194
195
196
197
198
199
200
201
}

/** Called by plugins if texture mode should be switched
 */
void Core::slotSwitchTexture( QString _textureName ) {
  emit switchTexture(_textureName);
}

//========================================================================================
// ===             Backup Communication                       ============================
//========================================================================================

/// Called if a backup is requested by the plugins
void Core::backupRequest( int _id , QString _name ) {
Jan Möbius's avatar
Jan Möbius committed
202
203
  emit createBackup(  _id , _name , nextBackupId_);
  ++nextBackupId_;
Jan Möbius's avatar
 
Jan Möbius committed
204
205
206
207
208
209
210
}





//=============================================================================