Skip to content
This repository has been archived by the owner on Aug 8, 2023. It is now read-only.

Commit

Permalink
Encoding --> DEMEncoding, avoid if statement when unpacking elevation…
Browse files Browse the repository at this point in the history
… values
  • Loading branch information
Molly Lloyd committed Feb 14, 2018
1 parent 0bbd54c commit e7aa8e1
Show file tree
Hide file tree
Showing 11 changed files with 31 additions and 25 deletions.
7 changes: 4 additions & 3 deletions include/mbgl/util/tileset.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,21 +14,22 @@ namespace mbgl {
class Tileset {
public:
enum class Scheme : bool { XYZ, TMS };
enum class Encoding : bool { Mapbox, Terrarium };
enum class DEMEncoding : bool { Mapbox, Terrarium };

std::vector<std::string> tiles;
Range<uint8_t> zoomRange;
std::string attribution;
Scheme scheme;
Encoding encoding;
// DEMEncoding is not supported by the TileJSON spec
DEMEncoding encoding;
optional<LatLngBounds> bounds;


Tileset(std::vector<std::string> tiles_ = std::vector<std::string>(),
Range<uint8_t> zoomRange_ = { 0, util::DEFAULT_MAX_ZOOM },
std::string attribution_ = {},
Scheme scheme_ = Scheme::XYZ,
Encoding encoding_ = Encoding::Mapbox)
DEMEncoding encoding_ = DEMEncoding::Mapbox)
: tiles(std::move(tiles_)),
zoomRange(std::move(zoomRange_)),
attribution(std::move(attribution_)),
Expand Down
19 changes: 11 additions & 8 deletions src/mbgl/geometry/dem_data.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

namespace mbgl {

DEMData::DEMData(const PremultipliedImage& _image, Tileset::Encoding encoding):
DEMData::DEMData(const PremultipliedImage& _image, Tileset::DEMEncoding encoding):
dim(_image.size.height),
border(std::max<int32_t>(std::ceil(_image.size.height / 2), 1)),
stride(dim + 2 * border),
Expand All @@ -13,15 +13,18 @@ DEMData::DEMData(const PremultipliedImage& _image, Tileset::Encoding encoding):
throw std::runtime_error("raster-dem tiles must be square.");
}

auto decodeRGB = [&] (const uint8_t r, const uint8_t g, const uint8_t b) {
if (encoding == Tileset::Encoding::Mapbox) {
return (r * 256 * 256 + g * 256 + b)/10 - 10000;
} else {
// encoding == Tileset::Encoding::Terrarium;
return ((r * 256 + g + b / 256) - 32768);
}
auto decodeMapbox = [] (const uint8_t r, const uint8_t g, const uint8_t b){
// https://www.mapbox.com/help/access-elevation-data/#mapbox-terrain-rgb
return (r * 256 * 256 + g * 256 + b)/10 - 10000;
};

auto decodeTerrarium = [] (const uint8_t r, const uint8_t g, const uint8_t b){
// https://aws.amazon.com/public-datasets/terrain/
return ((r * 256 + g + b / 256) - 32768);
};

auto decodeRGB = encoding == Tileset::DEMEncoding::Terrarium ? decodeTerrarium : decodeMapbox;

std::memset(image.data.get(), 0, image.bytes());

for (int32_t y = 0; y < dim; y++) {
Expand Down
2 changes: 1 addition & 1 deletion src/mbgl/geometry/dem_data.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ namespace mbgl {

class DEMData {
public:
DEMData(const PremultipliedImage& image, Tileset::Encoding encoding);
DEMData(const PremultipliedImage& image, Tileset::DEMEncoding encoding);
void backfillBorder(const DEMData& borderTileData, int8_t dx, int8_t dy);

void set(const int32_t x, const int32_t y, const int32_t value) {
Expand Down
2 changes: 1 addition & 1 deletion src/mbgl/renderer/buckets/hillshade_bucket.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ namespace mbgl {

using namespace style;

HillshadeBucket::HillshadeBucket(PremultipliedImage&& image_, Tileset::Encoding encoding): demdata(image_, encoding) {
HillshadeBucket::HillshadeBucket(PremultipliedImage&& image_, Tileset::DEMEncoding encoding): demdata(image_, encoding) {
}

HillshadeBucket::HillshadeBucket(DEMData&& demdata_) : demdata(std::move(demdata_)) {
Expand Down
4 changes: 2 additions & 2 deletions src/mbgl/renderer/buckets/hillshade_bucket.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@ namespace mbgl {

class HillshadeBucket : public Bucket {
public:
HillshadeBucket(PremultipliedImage&&, Tileset::Encoding encoding);
HillshadeBucket(std::shared_ptr<PremultipliedImage>, Tileset::Encoding encoding);
HillshadeBucket(PremultipliedImage&&, Tileset::DEMEncoding encoding);
HillshadeBucket(std::shared_ptr<PremultipliedImage>, Tileset::DEMEncoding encoding);
HillshadeBucket(DEMData&&);


Expand Down
4 changes: 3 additions & 1 deletion src/mbgl/style/conversion/tileset.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,9 @@ optional<Tileset> Converter<Tileset>::operator()(const Convertible& value, Error
if (encodingValue) {
optional<std::string> encoding = toString(*encodingValue);
if (encoding && *encoding == "terrarium") {
result.encoding = Tileset::Encoding::Terrarium;
result.encoding = Tileset::DEMEncoding::Terrarium;
} else if (encoding && *encoding != "mapbox") {
error = { "invalid raster-dem encoding type - valid types are 'mapbox' and 'terrarium' " };
}
}

Expand Down
2 changes: 1 addition & 1 deletion src/mbgl/tile/raster_dem_tile.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -94,7 +94,7 @@ class RasterDEMTile : public Tile {
Actor<RasterDEMTileWorker> worker;

uint64_t correlationID = 0;
Tileset::Encoding encoding;
Tileset::DEMEncoding encoding;

// Contains the Bucket object for the tile. Buckets are render
// objects and they get added by tile parsing operations.
Expand Down
2 changes: 1 addition & 1 deletion src/mbgl/tile/raster_dem_tile_worker.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ RasterDEMTileWorker::RasterDEMTileWorker(ActorRef<RasterDEMTileWorker>, ActorRef
: parent(std::move(parent_)) {
}

void RasterDEMTileWorker::parse(std::shared_ptr<const std::string> data, uint64_t correlationID, Tileset::Encoding encoding) {
void RasterDEMTileWorker::parse(std::shared_ptr<const std::string> data, uint64_t correlationID, Tileset::DEMEncoding encoding) {
if (!data) {
parent.invoke(&RasterDEMTile::onParsed, nullptr, correlationID); // No data; empty tile.
return;
Expand Down
2 changes: 1 addition & 1 deletion src/mbgl/tile/raster_dem_tile_worker.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ class RasterDEMTileWorker {
public:
RasterDEMTileWorker(ActorRef<RasterDEMTileWorker>, ActorRef<RasterDEMTile>);

void parse(std::shared_ptr<const std::string> data, uint64_t correlationID, Tileset::Encoding encoding);
void parse(std::shared_ptr<const std::string> data, uint64_t correlationID, Tileset::DEMEncoding encoding);

private:
ActorRef<RasterDEMTile> parent;
Expand Down
10 changes: 5 additions & 5 deletions test/geometry/dem_data.test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ auto fakeImage = [](Size s) {

TEST(DEMData, Constructor) {
PremultipliedImage image = fakeImage({16, 16});
DEMData demdata(image, Tileset::Encoding::Mapbox);
DEMData demdata(image, Tileset::DEMEncoding::Mapbox);

EXPECT_EQ(demdata.dim, 16);
EXPECT_EQ(demdata.border, 8);
Expand All @@ -29,7 +29,7 @@ TEST(DEMData, Constructor) {

TEST(DEMData, RoundTrip) {
PremultipliedImage image = fakeImage({16, 16});
DEMData demdata(image, Tileset::Encoding::Mapbox);
DEMData demdata(image, Tileset::DEMEncoding::Mapbox);

demdata.set(4, 6, 255);
EXPECT_EQ(demdata.get(4, 6), 255);
Expand All @@ -38,7 +38,7 @@ TEST(DEMData, RoundTrip) {
TEST(DEMData, InitialBackfill) {

PremultipliedImage image1 = fakeImage({4, 4});
DEMData dem1(image1, Tileset::Encoding::Mapbox);
DEMData dem1(image1, Tileset::DEMEncoding::Mapbox);

bool nonempty = true;
// checking that a 1 px border around the fake image has been populated
Expand Down Expand Up @@ -92,10 +92,10 @@ TEST(DEMData, InitialBackfill) {

TEST(DEMData, BackfillNeighbor) {
PremultipliedImage image1 = fakeImage({4, 4});
DEMData dem0(image1, Tileset::Encoding::Mapbox);
DEMData dem0(image1, Tileset::DEMEncoding::Mapbox);

PremultipliedImage image2 = fakeImage({4, 4});
DEMData dem1(image2, Tileset::Encoding::Mapbox);
DEMData dem1(image2, Tileset::DEMEncoding::Mapbox);

dem0.backfillBorder(dem1, -1, 0);
for (int y = 0; y < 4; y++) {
Expand Down
2 changes: 1 addition & 1 deletion test/tile/raster_dem_tile.test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,7 @@ TEST(RasterDEMTile, onError) {
TEST(RasterDEMTile, onParsed) {
RasterDEMTileTest test;
RasterDEMTile tile(OverscaledTileID(0, 0, 0), test.tileParameters, test.tileset);
tile.onParsed(std::make_unique<HillshadeBucket>(PremultipliedImage({16, 16}), Tileset::Encoding::Mapbox), 0);
tile.onParsed(std::make_unique<HillshadeBucket>(PremultipliedImage({16, 16}), Tileset::DEMEncoding::Mapbox), 0);
EXPECT_TRUE(tile.isRenderable());
EXPECT_TRUE(tile.isLoaded());
EXPECT_TRUE(tile.isComplete());
Expand Down

0 comments on commit e7aa8e1

Please sign in to comment.