viscontestdemo.h 3.45 KB
Newer Older
1
2
3
4
// ================================================================================================
// 
// This file is part of the CAMPVis Software Framework.
// 
5
// If not explicitly stated otherwise: Copyright (C) 2012-2015, all rights reserved,
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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
//      Christian Schulte zu Berge <christian.szb@in.tum.de>
//      Chair for Computer Aided Medical Procedures
//      Technische Universitaet Muenchen
//      Boltzmannstr. 3, 85748 Garching b. Muenchen, Germany
// 
// For a full list of authors and contributors, please refer to the file "AUTHORS.txt".
// 
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file 
// except in compliance with the License. You may obtain a copy of the License at
// 
// http://www.apache.org/licenses/LICENSE-2.0
// 
// Unless required by applicable law or agreed to in writing, software distributed under the 
// License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, 
// either express or implied. See the License for the specific language governing permissions 
// and limitations under the License.
// 
// ================================================================================================

#ifndef VISCONTESTDEMO_H__
#define VISCONTESTDEMO_H__

#include "core/eventhandlers/mwheeltonumericpropertyeventlistener.h"
#include "core/pipeline/autoevaluationpipeline.h"
#include "core/pipeline/viewportsplitter.h"

#include "modules/modulesapi.h"
#include "modules/base/processors/lightsourceprovider.h"
#include "modules/base/processors/trackballcameraprovider.h"
#include "modules/dti/processors/fiberreader.h"
#include "modules/dti/processors/fiberrenderer.h"
#include "modules/io/processors/genericimagereader.h"
#include "modules/neuro/processors/multivolumemprrenderer.h"
#include "modules/neuro/processors/multivolumeraycaster.h"
#include "modules/vis/processors/rendertargetcompositor.h"

namespace campvis {
    class CAMPVIS_MODULES_API ViscontestDemo : public AutoEvaluationPipeline {
    public:
        /**
46
47
48
         * Creates a ViscontestDemo pipeline.
         * \param   dataContainer   Reference to the DataContainer containing local working set of data
         *                          for this pipeline, must be valid the whole lifetime of this pipeline.
49
         */
50
        explicit ViscontestDemo(DataContainer& dataContainer);
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95

        /**
         * Virtual Destructor
         **/
        virtual ~ViscontestDemo();

        /// \see AutoEvaluationPipeline::init()
        virtual void init();
        virtual void deinit();

        static const std::string getId() { return "ViscontestDemo"; };

        /// \see AbstractPipeline::executePipeline()
        virtual void executePipeline();

    protected:
        void onReaderValidated(AbstractProcessor* p);
        
        void onSplitterEvent(size_t index, cgt::Event* e);

        LightSourceProvider _lsp;
        TrackballCameraProvider _tcp;

        dti::FiberReader _fiberReader;
        dti::FiberRenderer _fiberRenderer;

        GenericImageReader _t1PostReader;
        GenericImageReader _t1PreReader;
        GenericImageReader _flairReader;

        neuro::MultiVolumeMprRenderer _mvmpr2D;
        neuro::MultiVolumeMprRenderer _mvmpr3D;
        neuro::MultiVolumeRaycaster _mvr;

        RenderTargetCompositor _rtc1;
        RenderTargetCompositor _rtc2;

        ViewportSplitter _horizontalSplitter;

        MWheelToNumericPropertyEventListener _slicePositionEventHandler;

    };
}

#endif // VISCONTESTDEMO_H__