paysages3d/src/definition/CloudLayerDefinition.cpp

84 lines
2 KiB
C++
Raw Normal View History

2013-11-15 22:26:44 +00:00
#include "CloudLayerDefinition.h"
#include "Curve.h"
#include "NoiseGenerator.h"
#include "SurfaceMaterial.h"
#include "PackStream.h"
#include "FloatNode.h"
2013-11-15 22:26:44 +00:00
CloudLayerDefinition::CloudLayerDefinition(DefinitionNode *parent, const std::string &name)
: DefinitionNode(parent, name, "cloudlayer") {
2013-12-04 21:52:18 +00:00
type = CIRRUS;
altitude = 0.5;
scaling = 0.5;
coverage = 0.5;
xoffset = new FloatNode(this, "xoffset");
zoffset = new FloatNode(this, "zoffset");
2013-11-15 22:26:44 +00:00
}
CloudLayerDefinition::~CloudLayerDefinition() {
2013-11-15 22:26:44 +00:00
}
CloudLayerDefinition *CloudLayerDefinition::newCopy(const CloudLayerDefinition &other, DefinitionNode *parent) {
CloudLayerDefinition *layer = new CloudLayerDefinition(parent, other.getName());
2013-11-15 22:26:44 +00:00
other.copy(layer);
return layer;
}
CloudLayerDefinition *CloudLayerDefinition::newCopy(DefinitionNode *parent) const {
CloudLayerDefinition *layer = new CloudLayerDefinition(parent, getName());
2013-11-15 22:26:44 +00:00
copy(layer);
return layer;
}
void CloudLayerDefinition::save(PackStream *stream) const {
DefinitionNode::save(stream);
2013-11-15 22:26:44 +00:00
int clouds_type = (int)type;
stream->write(&clouds_type);
2013-12-04 21:52:18 +00:00
stream->write(&altitude);
stream->write(&scaling);
stream->write(&coverage);
noise_state.save(stream);
2013-11-15 22:26:44 +00:00
}
void CloudLayerDefinition::load(PackStream *stream) {
DefinitionNode::load(stream);
2013-11-15 22:26:44 +00:00
int clouds_type;
stream->read(&clouds_type);
type = (CloudsType)clouds_type;
2013-12-04 21:52:18 +00:00
stream->read(&altitude);
stream->read(&scaling);
stream->read(&coverage);
2013-11-15 22:26:44 +00:00
noise_state.load(stream);
2013-11-15 22:26:44 +00:00
validate();
}
void CloudLayerDefinition::copy(DefinitionNode *_destination) const {
DefinitionNode::copy(_destination);
CloudLayerDefinition *destination = (CloudLayerDefinition *)_destination;
2013-11-15 22:26:44 +00:00
destination->type = type;
2013-12-04 21:52:18 +00:00
destination->altitude = altitude;
destination->scaling = scaling;
destination->coverage = coverage;
noise_state.copy(&destination->noise_state);
2013-11-15 22:26:44 +00:00
}
void CloudLayerDefinition::validate() {
DefinitionNode::validate();
if (scaling < 0.1) {
2013-12-04 21:52:18 +00:00
scaling = 0.1;
2013-11-15 22:26:44 +00:00
}
}