paysages3d/src/rendering/tools/zone.h

44 lines
1.7 KiB
C++

#ifndef _RENDERING_TOOLS_ZONE_H_
#define _RENDERING_TOOLS_ZONE_H_
/**
* Definition of a geographic area.
*/
#include "../rendering_global.h"
#include "../tools/euclid.h"
#include "../tools/curve.h"
namespace paysages {
namespace system {
class PackStream;
}
}
typedef struct Zone Zone;
RENDERINGSHARED_EXPORT Zone* zoneCreate();
RENDERINGSHARED_EXPORT void zoneDelete(Zone* zone);
RENDERINGSHARED_EXPORT void zoneSave(PackStream* stream, Zone* zone);
RENDERINGSHARED_EXPORT void zoneLoad(PackStream* stream, Zone* zone);
RENDERINGSHARED_EXPORT void zoneCopy(Zone* source, Zone* destination);
RENDERINGSHARED_EXPORT void zoneClear(Zone* zone);
RENDERINGSHARED_EXPORT void zoneSetAbsoluteHeight(Zone* zone);
RENDERINGSHARED_EXPORT void zoneSetRelativeHeight(Zone* zone, double min, double middle, double max);
RENDERINGSHARED_EXPORT void zoneIncludeCircleArea(Zone* zone, double value, double centerx, double centerz, double softradius, double hardradius);
RENDERINGSHARED_EXPORT void zoneExcludeCircleArea(Zone* zone, double centerx, double centerz, double softradius, double hardradius);
RENDERINGSHARED_EXPORT void zoneGetHeightCurve(Zone* zone, Curve* curve);
RENDERINGSHARED_EXPORT void zoneSetHeightCurve(Zone* zone, Curve* curve);
RENDERINGSHARED_EXPORT void zoneAddHeightRangeQuick(Zone* zone, double value, double hardmin, double softmin, double softmax, double hardmax);
RENDERINGSHARED_EXPORT void zoneGetSlopeCurve(Zone* zone, Curve* curve);
RENDERINGSHARED_EXPORT void zoneSetSlopeCurve(Zone* zone, Curve* curve);
RENDERINGSHARED_EXPORT void zoneAddSlopeRangeQuick(Zone* zone, double value, double hardmin, double softmin, double softmax, double hardmax);
RENDERINGSHARED_EXPORT double zoneGetValue(Zone* zone, Vector3 location, Vector3 normal);
#endif