~ubuntu-branches/ubuntu/wily/ginkgocadx/wily-proposed

« back to all changes in this revision

Viewing changes to src/visualizator/visualizator/wxvtk/gvistacompleja.h

  • Committer: Bazaar Package Importer
  • Author(s): Andreas Tille
  • Date: 2011-05-02 08:09:26 UTC
  • Revision ID: james.westby@ubuntu.com-20110502080926-bql5wep49c7hg91t
Tags: upstream-2.4.1.1
ImportĀ upstreamĀ versionĀ 2.4.1.1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 *  
 
3
 *  $Id: gvistacompleja.h 3662 2011-04-08 09:03:14Z tovar $
 
4
 *  Ginkgo CADx Project
 
5
 *
 
6
 *  Copyright 2008-10 MetaEmotion S.L. All rights reserved.
 
7
 *  http://ginkgo-cadx.com
 
8
 *
 
9
 *  This file is licensed under LGPL v3 license.
 
10
 *  See License.txt for details
 
11
 *
 
12
 *
 
13
 */
 
14
#pragma once
 
15
 
 
16
#include <wx/aui/auibar.h>
 
17
#include "visualizatorviews.h"
 
18
#include <export/icontratoscore.h>
 
19
#include "../exportacion/icontratosaprimaria.h"
 
20
#include <api/icontroladoreventos.h>
 
21
#include "../estudios/overlay.h"
 
22
#include <api/ianotador.h>
 
23
 
 
24
#include <vtkCommand.h>
 
25
 
 
26
namespace GNKVisualizator{
 
27
        class VisualizatorStudy;
 
28
        class Vista2D;
 
29
}
 
30
 
 
31
class GVistaSimple;
 
32
 
 
33
class TimerPlay;
 
34
class BarraHerramientasBotones;
 
35
 
 
36
class vtkScalarsToColors;
 
37
class vtkAlgorithmOutput;
 
38
class GVistaCompleja: public VistaComplejaBase, public GNKVisualizator::IContratoMapaColor, public GNC::GCS::IContratoWidgets, public GNC::GCS::IContratoWindowLevel, public GNKVisualizator::IReconstructionContract, public GNC::GCS::IObservador, public GNKVisualizator::IContratoOverlays, public GNC::GCS::IAnotador, public GNC::GCS::IContratoLayoutVentana {
 
39
public:
 
40
 
 
41
   /* Constructor */
 
42
        GVistaCompleja( GNKVisualizator::Vista2D* pIVista);
 
43
   /* Destructor */
 
44
        ~GVistaCompleja();
 
45
 
 
46
        virtual void OnEraseBackground( wxEraseEvent& event ) { event.Skip(false); }
 
47
 
 
48
        void AddVistaSimple();
 
49
 
 
50
        void IniciarPipeline();
 
51
 
 
52
        void DetenerPipeline();
 
53
 
 
54
        virtual void OnCargaFinalizada();
 
55
 
 
56
        void SetOverlays(GNKVisualizator::TListaOverlays* pListaOverlays);
 
57
 
 
58
        bool GetManipulacionEnabled()
 
59
        {
 
60
                return m_pPanelManipulacion->IsEnabled();
 
61
        }
 
62
 
 
63
   //region "Eventos"
 
64
        virtual void OnPaint(wxPaintEvent& evt);
 
65
 
 
66
        void OnMenuVerClick(wxCommandEvent& event);
 
67
        void OnMenuCineClick(wxAuiToolBarEvent& evt);
 
68
        void OnMenuLayout(wxCommandEvent &event);
 
69
        void OnDesencajar(wxCommandEvent &event);
 
70
        void OnInvertColorMap(wxCommandEvent &event);
 
71
        void OnRotateLeft(wxCommandEvent &event);
 
72
        void OnRotateRight(wxCommandEvent &event);
 
73
        void OnFlipVertical(wxCommandEvent &event);
 
74
        void OnFlipHorizontal(wxCommandEvent &event);
 
75
 
 
76
        void ActualizarMaxMinSlider();
 
77
 
 
78
        void OnFocus(wxChildFocusEvent &event);
 
79
 
 
80
        void SetPeriodo(int milisegundos);
 
81
 
 
82
        void OnSize(wxSizeEvent &event);
 
83
 
 
84
        void OnZSliderScroll (wxScrollEvent& event);
 
85
 
 
86
        void OnKeyDown( wxKeyEvent& event );
 
87
 
 
88
        void OnMouseWheel( wxMouseEvent& event );
 
89
 
 
90
        void OnPlayStopClick(wxCommandEvent &event);
 
91
 
 
92
        void Play();
 
93
        void Stop();
 
94
 
 
95
        void OnBucleClick(wxCommandEvent &event);
 
96
 
 
97
        void OnTimer();
 
98
 
 
99
        void OnSincronizarClick(wxCommandEvent &event);
 
100
 
 
101
        void Sincronizar(bool sincronizar);
 
102
 
 
103
        void GoToSlice(int posicion, bool relativa =  true, bool propagar = true, bool render= true);
 
104
 
 
105
        void PreProcesarEvento(GNC::GCS::Eventos::IEvento* evt, GNC::GCS::IControladorEventos::TipoListaPunterosEventos& lista);
 
106
 
 
107
        void ProcesarEvento(GNC::GCS::Eventos::IEvento *evt) ;
 
108
 
 
109
        typedef std::vector<GNKVisualizator::Vista2D*> TipoListaVista2D;
 
110
        void Sincronizar(const TipoListaVista2D& lista);
 
111
        void DesSincronizar();
 
112
        bool EsSincronizable();
 
113
 
 
114
        //endregion
 
115
 
 
116
        //contrato widgets
 
117
        virtual vtkGinkgoImageViewer* GetViewer();
 
118
 
 
119
        //region "Realizacion de la interfaz IAnnotator"
 
120
        virtual std::string GetTopLeftAnnotation(GNC::GCS::Contexto3D* c);
 
121
        virtual std::string GetTopRightAnnotation(GNC::GCS::Contexto3D* c);
 
122
        virtual std::string GetBottomLeftAnnotation(GNC::GCS::Contexto3D* c);
 
123
        virtual std::string GetBottomRightAnnotation(GNC::GCS::Contexto3D* c);
 
124
        virtual std::string GetAnotacionPosicion(GNC::GCS::Vector* pPosicion);
 
125
        //endregion
 
126
 
 
127
        // Asigna los valores de los apuntadores a la la imagen y el slice actual
 
128
        void AsignarConexionesDeFiltrado(vtkImageData** pImagen, int* slice, vtkImageData** pChroma);
 
129
        void ActualizarImagen();
 
130
 
 
131
        //contrato mapa de color
 
132
        virtual void SetMapaColor(vtkLookupTable* pTabla, int idLookupTable);
 
133
 
 
134
        //contrato layout
 
135
        virtual void SetLayoutVentana(int filas, int columnas);
 
136
        virtual int GetColumnas();
 
137
        virtual int GetFilas();
 
138
        //
 
139
        //region "IContratoExportacionImagenes interface realization"
 
140
        void GetImage(GNC::GCS::IContratoExportacionImages::ImageType::Pointer& img, int index, bool conWidgets, const GNC::GCS::Vector& size);
 
141
 
 
142
        //region "IReconstructionContract interface realization"
 
143
        void SetReconstructionMode(GNKVisualizator::Reconstruction::ReconstructionMode mode);
 
144
 
 
145
        vtkScalarsToColors* GetLookupTable();
 
146
 
 
147
protected:
 
148
        GNKVisualizator::Vista2D*                  IVista;
 
149
        TimerPlay*                           m_playTimer;
 
150
        BarraHerramientasBotones*            m_pBarraIzquierda;
 
151
        BarraHerramientasBotones*            m_pBarraCine;
 
152
        BarraHerramientasBotones*            m_pBarraDerecha;
 
153
 
 
154
        int                                  m_orientacion;
 
155
        TipoListaVista2D                     m_ListaSincronizacion;
 
156
        int m_posicion;
 
157
        bool                                 m_ReproducirBucle;
 
158
        int                                  m_PeriodoMs;
 
159
        typedef std::vector<GVistaSimple*>   TListaGVistasSimples;
 
160
        TListaGVistasSimples                 m_VistasSimples;
 
161
        ///widgets
 
162
        //TipoFicherosGNKVisualizator*              m_pFicherosAprimaria;
 
163
        
 
164
 
 
165
        //si se ha pintado
 
166
        bool                                 m_hasBeenRendered;
 
167
 
 
168
        friend class GNKVisualizator::Vista2D;
 
169
};