Currently job artifacts in CI/CD pipelines on LRZ GitLab never expire. Starting from Wed 26.1.2022 the default expiration time will be 30 days (GitLab default). Currently existing artifacts in already completed jobs will not be affected by the change. The latest artifacts for all jobs in the latest successful pipelines will be kept. More information: https://gitlab.lrz.de/help/user/admin_area/settings/continuous_integration.html#default-artifacts-expiration

imageseries.h 3.64 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-2014, all rights reserved,
6
7
//      Christian Schulte zu Berge <christian.szb@in.tum.de>
//      Chair for Computer Aided Medical Procedures
8
9
//      Technische Universitaet Muenchen
//      Boltzmannstr. 3, 85748 Garching b. Muenchen, Germany
10
// 
11
12
// For a full list of authors and contributors, please refer to the file "AUTHORS.txt".
// 
13
14
15
16
// 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
17
// 
18
19
20
21
// 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.
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
// 
// ================================================================================================

#ifndef IMAGESERIES_H__
#define IMAGESERIES_H__

#include "core/datastructures/abstractdata.h"
#include "core/datastructures/datahandle.h"
#include <vector>

namespace campvis {
    class ImageData;

    /**
     * Class encapsulating a series of images.
     */
38
    class CAMPVIS_CORE_API ImageSeries : public AbstractData, public IHasWorldBounds {
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
    public:
        /**
         * Constructor
         */
        ImageSeries();

        /**
         * Virtual destructor
         */
        virtual ~ImageSeries();


        /**
         * Prototype - clone method, some people call this virtual constructor...
         * \return  A copy of this object.
         */
        virtual ImageSeries* clone() const;

        /**
         * Returns the local memory footprint of the data in bytes.
         * \return  Number of bytes occupied in local memory by the data.
         */
        virtual size_t getLocalMemoryFootprint() const;

        /**
         * Returns the video memory footprint of the data in bytes.
         * \return  Number of bytes occupied in video memory by the data.
         */
        virtual size_t getVideoMemoryFootprint() const;
68
69
70

        /// \see AbstractData::getTypeAsString()
        virtual std::string getTypeAsString() const;
71
        
72
73
74
75
76
77
        /**
         * Returns the data extent in world coordinates.
         * \return  The data extent in world coordinates.
         */
        virtual cgt::Bounds getWorldBounds() const;

78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
        /**
         * Appends the image \a image to the series.
         * \param   image   Image to be added.
         */
        void addImage(ImageData* image);
        
        /**
         * Appends the image \a image to the series.
         * \note    The DataHandle must contain walid image data.
         * \param   dh  DataHandle with image to be added.
         */
        void addImage(DataHandle dh);

        /**
         * Returns the number of images in this series
         * \return  _images.size()
         */
        size_t getNumImages() const;

        /**
         * Returns a DataHandle with the image number \a index of this series.
         * \param   index   Index of the image to return
         * \return  _images[index]
         */
        DataHandle getImage(size_t index) const;

    protected:
        std::vector<DataHandle> _images;    ///< the images of this series
    };

}

#endif // IMAGESERIES_H__