org.oscim.tiling.source.mapfile.MapReadResult Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vtm Show documentation
Show all versions of vtm Show documentation
OpenGL vector map library written in Java - running on Android, iOS, Desktop and within the browser.
/*
* Copyright 2010, 2011, 2012, 2013 mapsforge.org
* Copyright 2014-2015 Ludwig M Brinckmann
* Copyright 2017 devemux86
*
* This program is free software: you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License along with
* this program. If not, see .
*/
package org.oscim.tiling.source.mapfile;
import java.util.ArrayList;
import java.util.List;
/**
* An immutable container for the data returned from a MapDataStore.
*/
public class MapReadResult {
/**
* True if the read area is completely covered by water, false otherwise.
*/
public boolean isWater;
/**
* The read POIs.
*/
public List pointOfInterests;
/**
* The read ways.
*/
public List ways;
public MapReadResult() {
this.pointOfInterests = new ArrayList<>();
this.ways = new ArrayList<>();
}
public void add(PoiWayBundle poiWayBundle) {
this.pointOfInterests.addAll(poiWayBundle.pois);
this.ways.addAll(poiWayBundle.ways);
}
/**
* Adds other MapReadResult by combining pois and ways. Optionally, deduplication can
* be requested (much more expensive).
*
* @param other the MapReadResult to add to this.
* @param deduplicate true if check for duplicates is required.
*/
public void add(MapReadResult other, boolean deduplicate) {
if (deduplicate) {
for (PointOfInterest poi : other.pointOfInterests) {
if (!this.pointOfInterests.contains(poi)) {
this.pointOfInterests.add(poi);
}
}
for (Way way : other.ways) {
if (!this.ways.contains(way)) {
this.ways.add(way);
}
}
} else {
this.pointOfInterests.addAll(other.pointOfInterests);
this.ways.addAll(other.ways);
}
}
}