use of com.revolsys.geometry.model.impl.BoundingBoxDoubleXY in project com.revolsys.open by revolsys.
the class QuadtreeCorrectTest method newGrid.
void newGrid(final int nGridCells) {
int gridSize = (int) Math.sqrt(nGridCells);
gridSize += 1;
final double extent = MAX_EXTENT - MIN_EXTENT;
final double gridInc = extent / gridSize;
final double cellSize = 2 * gridInc;
for (int i = 0; i < gridSize; i++) {
for (int j = 0; j < gridSize; j++) {
final double x = MIN_EXTENT + gridInc * i;
final double y = MIN_EXTENT + gridInc * j;
final BoundingBox env = new BoundingBoxDoubleXY(x, y, x + cellSize, y + cellSize);
this.index.insertItem(env, env);
this.envList.add(env);
}
}
}
use of com.revolsys.geometry.model.impl.BoundingBoxDoubleXY in project com.revolsys.open by revolsys.
the class SpatialIndexTester method addSourceData.
private void addSourceData(final double offset, final List<BoundingBox> sourceData) {
for (int i = 0; i < CELLS_PER_GRID_SIDE; i++) {
final double minx = i * CELL_EXTENT + offset;
final double maxx = minx + FEATURE_EXTENT;
for (int j = 0; j < CELLS_PER_GRID_SIDE; j++) {
final double miny = j * CELL_EXTENT + offset;
final double maxy = miny + FEATURE_EXTENT;
final BoundingBox e = new BoundingBoxDoubleXY(minx, miny, maxx, maxy);
sourceData.add(e);
}
}
}
use of com.revolsys.geometry.model.impl.BoundingBoxDoubleXY in project com.revolsys.open by revolsys.
the class GridGenerator method newBoundingBox.
/**
* @return BoundingBox
*
* @see com.revolsys.geometry.testold.generator.GeometryGenerator#newIterator()
*
* @throws NoSuchElementException when all the grids have been created
* @throws NullPointerException when either the Geometry Factory, or the Bounding Box are undefined.
*/
public BoundingBox newBoundingBox() {
if (!canCreate()) {
throw new NoSuchElementException("There are not any grids left to create.");
}
if (this.geometryFactory == null) {
throw new NullPointerException("GeometryFactoryI is not declared");
}
if (this.boundingBox == null || this.boundingBox.isEmpty()) {
throw new NullPointerException("Bounding Box is not declared");
}
// base x
final double x = this.boundingBox.getMinX();
final double dx = this.boundingBox.getMaxX() - x;
// base y
final double y = this.boundingBox.getMinY();
final double dy = this.boundingBox.getMaxY() - y;
final int row = this.numberRows == 1 ? 0 : this.index / this.numberRows;
final int col = this.numberColumns == 1 ? 0 : this.index % this.numberColumns;
// size of a step
double sx, sy;
sx = dx / this.numberColumns;
sy = dy / this.numberRows;
double minx, miny;
minx = x + col * sx;
miny = y + row * sy;
final BoundingBox box = new BoundingBoxDoubleXY(this.geometryFactory.makePrecise(0, minx), this.geometryFactory.makePrecise(1, miny), this.geometryFactory.makePrecise(0, minx + sx), this.geometryFactory.makePrecise(1, miny + sy));
this.index++;
return box;
}
use of com.revolsys.geometry.model.impl.BoundingBoxDoubleXY in project com.revolsys.open by revolsys.
the class STRtreeTest method testEmptyTreeUsingItemVisitorQuery.
public void testEmptyTreeUsingItemVisitorQuery() {
final StrTree tree = new StrTree();
tree.query(new BoundingBoxDoubleXY(0, 1, 0, 1), (item) -> {
assertTrue("Should never reach here", true);
});
}
use of com.revolsys.geometry.model.impl.BoundingBoxDoubleXY in project com.revolsys.open by revolsys.
the class STRtreeTest method testEmptyTreeUsingListQuery.
public void testEmptyTreeUsingListQuery() {
final StrTree tree = new StrTree();
final List list = tree.getItems(new BoundingBoxDoubleXY(0, 1, 0, 1));
assertTrue(list.isEmpty());
}
Aggregations