forked from mirror/openmw-tes3mp
55 lines
1.3 KiB
C++
55 lines
1.3 KiB
C++
#ifndef TERRAIN_LAND_FACTORY_H
|
|
#define TERRAIN_LAND_FACTORY_H
|
|
|
|
#include <mangle/stream/stream.hpp>
|
|
|
|
namespace Terrain
|
|
{
|
|
enum LandInfoGridType
|
|
{
|
|
LGT_Quadratic
|
|
};
|
|
|
|
enum LandInfoDataType
|
|
{
|
|
LDT_Float
|
|
};
|
|
|
|
struct LandInfo
|
|
{
|
|
// Type information
|
|
LandInfoGridType grid;
|
|
LandInfoDataType data;
|
|
|
|
// Landscape size and number of vertices. Note that xsize and
|
|
// ysize may be negative, signaling a flipped landscape in that
|
|
// direction.
|
|
float xsize, ysize;
|
|
int numx, numy;
|
|
|
|
// World offset along the same x/y axes. Whether these are set or
|
|
// used depends on the client implementation.
|
|
float xoffset, yoffset;
|
|
};
|
|
|
|
/* We use normal streams for data. This allows us to just pass (for
|
|
example) a file stream as height map input later, with no extra
|
|
fuzz.
|
|
*/
|
|
typedef Mangle::Stream::StreamPtr LandDataPtr;
|
|
|
|
/*
|
|
Factory class that provides streams to land data cells. Each
|
|
"cell" has a unique integer coordinate in the plane.
|
|
*/
|
|
struct LandFactory
|
|
{
|
|
// True if this factory has any data for the given grid cell.
|
|
virtual bool has(int x, int y) = 0;
|
|
|
|
// Return stream to data for this cell. Additional data about the
|
|
// landscape is returned through the LandInfo struct.
|
|
virtual LandDataPtr get(int x, int y, LandInfo &info) = 0;
|
|
};
|
|
}
|
|
#endif
|