/usr/include/magics/CellShading.h is in libmagics++-dev 2.18.15-5.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 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 46 47 48 49 50 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 96 | /******************************** LICENSE ********************************
Copyright 2007 European Centre for Medium-Range Weather Forecasts (ECMWF)
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.
******************************** LICENSE ********************************/
/*! \file CellShading.h
\brief Definition of the Template class CellShading.
Magics Team - ECMWF 2005
Started: Tue 30-Aug-2005
Changes:
*/
#ifndef CellShading_H
#define CellShading_H
#include "magics.h"
#include "IsoShading.h"
#include "CellShadingAttributes.h"
#include "ColourTable.h"
namespace magics {
class CellShading: public ShadingTechnique, public CellShadingAttributes {
public:
CellShading();
virtual ~CellShading();
void set(const map<string, string>& map ) { CellShadingAttributes::set(map); }
void set(const XmlNode& node ) { CellShadingAttributes::set(node); }
bool accept(const string& node) { return CellShadingAttributes::accept(node); }
virtual ShadingTechnique* clone() const {
CellShading* object = new CellShading();
return object;
}
void copy(const CellShading& from)
{
CellShadingAttributes::copy(from);
//IsoShadingAttributes::copy(from);
}
virtual void visit(LegendVisitor&, const ColourTechnique&);
bool hasLegend() { return true; } // Isolien legend is not needed!
virtual void operator()(MatrixHandler&, BasicGraphicsObjectContainer&);
virtual bool prepare(const LevelSelection&, const ColourTechnique&);
virtual void colour(double, Colour&);
CellArray* array(MatrixHandler& matrix, IntervalMap<int>& range,
const Transformation& transformation, int width, int height,
float resolution, const string& technique);
protected:
//! Method to print string about this class on to a stream of type ostream (virtual).
virtual void print(ostream&) const;
IntervalMap<int> map_;
vector<Colour> colours_;
private:
//! Copy constructor - No copy allowed
CellShading(const CellShading&);
//! Overloaded << operator to copy - No copy allowed
CellShading& operator=(const CellShading&);
// -- Friends
//! Overloaded << operator to call print().
friend ostream& operator<<(ostream& s,const CellShading& p)
{ p.print(s); return s; }
};
} // namespace magics
#endif
|