1 : /******************************************************************************
2 : *
3 : * Purpose: Interface through which a PCIDSK GCP Segment would be accessed
4 : *
5 : ******************************************************************************
6 : * Copyright (c) 2009
7 : * PCI Geomatics, 50 West Wilmot Street, Richmond Hill, Ont, Canada
8 : *
9 : * Permission is hereby granted, free of charge, to any person obtaining a
10 : * copy of this software and associated documentation files (the "Software"),
11 : * to deal in the Software without restriction, including without limitation
12 : * the rights to use, copy, modify, merge, publish, distribute, sublicense,
13 : * and/or sell copies of the Software, and to permit persons to whom the
14 : * Software is furnished to do so, subject to the following conditions:
15 : *
16 : * The above copyright notice and this permission notice shall be included
17 : * in all copies or substantial portions of the Software.
18 : *
19 : * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20 : * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 : * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
22 : * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23 : * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
24 : * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
25 : * DEALINGS IN THE SOFTWARE.
26 : ****************************************************************************/
27 : #ifndef __INCLUDE_PCIDSK_PCIDSK_GCPSEGMENT_H
28 : #define __INCLUDE_PCIDSK_PCIDSK_GCPSEGMENT_H
29 :
30 : #include "pcidsk_gcp.h"
31 :
32 : #include <vector>
33 :
34 : namespace PCIDSK {
35 :
36 : //! Interface to PCIDSK GCP segment.
37 : class PCIDSKGCPSegment
38 0 : {
39 : public:
40 : //! Return all GCPs in the segment
41 : virtual std::vector<PCIDSK::GCP> const& GetGCPs(void) const = 0;
42 :
43 : //! Write the given GCPs to the segment. If the segment already exists, it will be replaced with this one.
44 : virtual void SetGCPs(std::vector<PCIDSK::GCP> const& gcps) = 0;
45 :
46 : //! Return the count of GCPs in the segment
47 : virtual unsigned int GetGCPCount(void) const = 0;
48 :
49 : //! Clear a GCP Segment
50 : virtual void ClearGCPs(void) = 0;
51 :
52 : //! Virtual Destructor
53 0 : virtual ~PCIDSKGCPSegment(void) {}
54 : };
55 : } // end namespace PCIDSK
56 :
57 :
58 : #endif // __INCLUDE_PCIDSK_PCIDSK_GCPSEGMENT_H
59 :
|