use of mil.nga.geopackage.features.index.FeatureIndexResults in project geopackage-android-map by ngageoint.
the class FeatureInfoBuilder method buildResultsInfoMessage.
/**
* Build a feature results information message
*
* @param results feature index results
* @param tolerance distance tolerance
* @param clickLocation map click location
* @param projection desired geometry projection
* @return results message or null if no results
*/
public String buildResultsInfoMessage(FeatureIndexResults results, double tolerance, LatLng clickLocation, Projection projection) {
String message = null;
// Fine filter results so that the click location is within the tolerance of each feature row result
FeatureIndexResults filteredResults = fineFilterResults(results, tolerance, clickLocation);
long featureCount = filteredResults.count();
if (featureCount > 0) {
int maxFeatureInfo = 0;
if (geometryType == GeometryType.POINT) {
maxFeatureInfo = maxPointDetailedInfo;
} else {
maxFeatureInfo = maxFeatureDetailedInfo;
}
if (featureCount <= maxFeatureInfo) {
StringBuilder messageBuilder = new StringBuilder();
messageBuilder.append(name).append("\n");
int featureNumber = 0;
DataColumnsDao dataColumnsDao = getDataColumnsDao();
for (FeatureRow featureRow : filteredResults) {
featureNumber++;
if (featureNumber > maxFeatureInfo) {
break;
}
if (featureCount > 1) {
if (featureNumber > 1) {
messageBuilder.append("\n");
} else {
messageBuilder.append("\n").append(featureCount).append(" Features").append("\n");
}
messageBuilder.append("\n").append("Feature ").append(featureNumber).append(":").append("\n");
}
int geometryColumn = featureRow.getGeometryColumnIndex();
for (int i = 0; i < featureRow.columnCount(); i++) {
if (i != geometryColumn) {
Object value = featureRow.getValue(i);
if (value != null) {
String columnName = featureRow.getColumnName(i);
columnName = getColumnName(dataColumnsDao, featureRow, columnName);
messageBuilder.append("\n").append(columnName).append(": ").append(value);
}
}
}
GeoPackageGeometryData geomData = featureRow.getGeometry();
if (geomData != null && geomData.getGeometry() != null) {
boolean printFeatures = false;
if (geomData.getGeometry().getGeometryType() == GeometryType.POINT) {
printFeatures = detailedInfoPrintPoints;
} else {
printFeatures = detailedInfoPrintFeatures;
}
if (printFeatures) {
if (projection != null) {
projectGeometry(geomData, projection);
}
messageBuilder.append("\n\n");
messageBuilder.append(GeometryPrinter.getGeometryString(geomData.getGeometry()));
}
}
}
message = messageBuilder.toString();
} else {
StringBuilder messageBuilder = new StringBuilder();
messageBuilder.append(name).append("\n\t").append(featureCount).append(" features");
if (clickLocation != null) {
messageBuilder.append(" near location:\n");
Point point = new Point(clickLocation.longitude, clickLocation.latitude);
messageBuilder.append(GeometryPrinter.getGeometryString(point));
}
message = messageBuilder.toString();
}
}
return message;
}
use of mil.nga.geopackage.features.index.FeatureIndexResults in project geopackage-android-map by ngageoint.
the class FeatureInfoBuilder method buildTableDataAndClose.
/**
* Build a feature results information message
*
* @param results feature index results
* @param tolerance distance tolerance
* @param clickLocation map click location
* @param projection desired geometry projection
* @return feature table data or null if not results
*/
public FeatureTableData buildTableDataAndClose(FeatureIndexResults results, double tolerance, LatLng clickLocation, Projection projection) {
FeatureTableData tableData = null;
// Fine filter results so that the click location is within the tolerance of each feature row result
FeatureIndexResults filteredResults = fineFilterResults(results, tolerance, clickLocation);
long featureCount = filteredResults.count();
if (featureCount > 0) {
int maxFeatureInfo = 0;
if (geometryType == GeometryType.POINT) {
maxFeatureInfo = maxPointDetailedInfo;
} else {
maxFeatureInfo = maxFeatureDetailedInfo;
}
if (featureCount <= maxFeatureInfo) {
DataColumnsDao dataColumnsDao = getDataColumnsDao();
List<FeatureRowData> rows = new ArrayList<>();
for (FeatureRow featureRow : filteredResults) {
Map<String, Object> values = new HashMap<>();
String geometryColumnName = null;
int geometryColumn = featureRow.getGeometryColumnIndex();
for (int i = 0; i < featureRow.columnCount(); i++) {
Object value = featureRow.getValue(i);
String columnName = featureRow.getColumnName(i);
columnName = getColumnName(dataColumnsDao, featureRow, columnName);
if (i == geometryColumn) {
geometryColumnName = columnName;
if (projection != null && value != null) {
GeoPackageGeometryData geomData = (GeoPackageGeometryData) value;
projectGeometry(geomData, projection);
}
}
if (value != null) {
values.put(columnName, value);
}
}
FeatureRowData featureRowData = new FeatureRowData(values, geometryColumnName);
rows.add(featureRowData);
}
tableData = new FeatureTableData(featureDao.getTableName(), featureCount, rows);
} else {
tableData = new FeatureTableData(featureDao.getTableName(), featureCount);
}
}
results.close();
return tableData;
}
use of mil.nga.geopackage.features.index.FeatureIndexResults in project geopackage-android-map by ngageoint.
the class ReadmeTest method testGeoPackage.
/**
* Test GeoPackage
*
* @param context context
* @param geoPackageFile GeoPackage file
* @param map Google map
* @throws IOException upon error
* @throws SQLException upon error
*/
private void testGeoPackage(Context context, File geoPackageFile, GoogleMap map) throws IOException, SQLException {
// Context context = ...;
// File geoPackageFile = ...;
// GoogleMap map = ...;
// Get a manager
GeoPackageManager manager = GeoPackageFactory.getManager(context);
// Import database
boolean imported = manager.importGeoPackage(geoPackageFile);
// Available databases
List<String> databases = manager.databases();
// Open database
GeoPackage geoPackage = manager.open(databases.get(0));
// GeoPackage Table DAOs
SpatialReferenceSystemDao srsDao = geoPackage.getSpatialReferenceSystemDao();
ContentsDao contentsDao = geoPackage.getContentsDao();
GeometryColumnsDao geomColumnsDao = geoPackage.getGeometryColumnsDao();
TileMatrixSetDao tileMatrixSetDao = geoPackage.getTileMatrixSetDao();
TileMatrixDao tileMatrixDao = geoPackage.getTileMatrixDao();
SchemaExtension schemaExtension = new SchemaExtension(geoPackage);
DataColumnsDao dao = schemaExtension.getDataColumnsDao();
DataColumnConstraintsDao dataColumnConstraintsDao = schemaExtension.getDataColumnConstraintsDao();
MetadataExtension metadataExtension = new MetadataExtension(geoPackage);
MetadataDao metadataDao = metadataExtension.getMetadataDao();
MetadataReferenceDao metadataReferenceDao = metadataExtension.getMetadataReferenceDao();
ExtensionsDao extensionsDao = geoPackage.getExtensionsDao();
// Feature and tile tables
List<String> features = geoPackage.getFeatureTables();
List<String> tiles = geoPackage.getTileTables();
// Query Features
String featureTable = features.get(0);
FeatureDao featureDao = geoPackage.getFeatureDao(featureTable);
GoogleMapShapeConverter converter = new GoogleMapShapeConverter(featureDao.getProjection());
FeatureCursor featureCursor = featureDao.queryForAll();
try {
for (FeatureRow featureRow : featureCursor) {
GeoPackageGeometryData geometryData = featureRow.getGeometry();
if (geometryData != null && !geometryData.isEmpty()) {
Geometry geometry = geometryData.getGeometry();
GoogleMapShape shape = converter.toShape(geometry);
GoogleMapShape mapShape = GoogleMapShapeConverter.addShapeToMap(map, shape);
// ...
}
}
} finally {
featureCursor.close();
}
// Query Tiles
String tileTable = tiles.get(0);
TileDao tileDao = geoPackage.getTileDao(tileTable);
TileCursor tileCursor = tileDao.queryForAll();
try {
for (TileRow tileRow : tileCursor) {
byte[] tileBytes = tileRow.getTileData();
Bitmap tileBitmap = tileRow.getTileDataBitmap();
// ...
}
} finally {
tileCursor.close();
}
// Retrieve Tiles by XYZ
GeoPackageTileRetriever retriever = new GeoPackageTileRetriever(tileDao);
GeoPackageTile geoPackageTile = retriever.getTile(2, 2, 2);
if (geoPackageTile != null) {
byte[] tileBytes = geoPackageTile.getData();
Bitmap tileBitmap = geoPackageTile.getBitmap();
// ...
}
// Retrieve Tiles by Bounding Box
TileCreator tileCreator = new TileCreator(tileDao, ProjectionFactory.getProjection(ProjectionConstants.EPSG_WORLD_GEODETIC_SYSTEM));
GeoPackageTile geoPackageTile2 = tileCreator.getTile(new BoundingBox(-90.0, 0.0, 0.0, 66.513260));
if (geoPackageTile2 != null) {
byte[] tileBytes = geoPackageTile2.getData();
Bitmap tileBitmap = geoPackageTile2.getBitmap();
// ...
}
// Tile Provider (GeoPackage or Google API)
TileProvider overlay = GeoPackageOverlayFactory.getTileProvider(tileDao);
TileOverlayOptions overlayOptions = new TileOverlayOptions();
overlayOptions.tileProvider(overlay);
overlayOptions.zIndex(-1);
map.addTileOverlay(overlayOptions);
BoundingBox boundingBox = BoundingBox.worldWebMercator();
Projection projection = ProjectionFactory.getProjection(ProjectionConstants.EPSG_WEB_MERCATOR);
// Index Features
FeatureIndexManager indexer = new FeatureIndexManager(context, geoPackage, featureDao);
indexer.setIndexLocation(FeatureIndexType.GEOPACKAGE);
int indexedCount = indexer.index();
// Query Indexed Features in paginated chunks
FeatureIndexResults indexResults = indexer.queryForChunk(boundingBox, projection, 50);
FeaturePaginatedCursor paginatedCursor = indexer.paginate(indexResults);
for (FeatureRow featureRow : paginatedCursor) {
GeoPackageGeometryData geometryData = featureRow.getGeometry();
if (geometryData != null && !geometryData.isEmpty()) {
Geometry geometry = geometryData.getGeometry();
// ...
}
}
// Feature Tile Provider (dynamically draw tiles from features)
FeatureTiles featureTiles = new DefaultFeatureTiles(context, featureDao, context.getResources().getDisplayMetrics().density);
// Set max features to draw per tile
featureTiles.setMaxFeaturesPerTile(1000);
// Custom feature tile implementation
NumberFeaturesTile numberFeaturesTile = new NumberFeaturesTile(context);
// Draw feature count tiles when max features passed
featureTiles.setMaxFeaturesTileDraw(numberFeaturesTile);
// Set index manager to query feature indices
featureTiles.setIndexManager(indexer);
FeatureOverlay featureOverlay = new FeatureOverlay(featureTiles);
// Set zoom level to start showing tiles
featureOverlay.setMinZoom(featureDao.getZoomLevel());
TileOverlayOptions featureOverlayOptions = new TileOverlayOptions();
featureOverlayOptions.tileProvider(featureOverlay);
// Draw the feature tiles behind map markers
featureOverlayOptions.zIndex(-1);
map.addTileOverlay(featureOverlayOptions);
// URL Tile Generator (generate tiles from a URL)
TileGenerator urlTileGenerator = new UrlTileGenerator(context, geoPackage, "url_tile_table", "http://url/{z}/{x}/{y}.png", 0, 0, boundingBox, projection);
int urlTileCount = urlTileGenerator.generateTiles();
// Feature Tile Generator (generate tiles from features)
TileGenerator featureTileGenerator = new FeatureTileGenerator(context, geoPackage, "tiles_" + featureTable, featureTiles, 1, 2, boundingBox, projection);
int featureTileCount = featureTileGenerator.generateTiles();
// Close feature tiles (and indexer)
featureTiles.close();
// Close database when done
geoPackage.close();
}
use of mil.nga.geopackage.features.index.FeatureIndexResults in project geopackage-android-map by ngageoint.
the class FeatureOverlayQuery method queryFeatures.
/**
* Query for features in the bounding box
*
* @param columns columns
* @param boundingBox query bounding box
* @param projection bounding box projection
* @return feature index results, must be closed
* @since 3.5.0
*/
public FeatureIndexResults queryFeatures(String[] columns, BoundingBox boundingBox, Projection projection) {
if (projection == null) {
projection = ProjectionFactory.getProjection(ProjectionConstants.EPSG_WORLD_GEODETIC_SYSTEM);
}
// Query for features
FeatureIndexManager indexManager = featureTiles.getIndexManager();
if (indexManager == null) {
throw new GeoPackageException("Index Manager is not set on the Feature Tiles and is required to query indexed features");
}
FeatureIndexResults results = indexManager.query(columns, boundingBox, projection);
return results;
}
Aggregations