Interface Cell
- All Known Subinterfaces:
- CellCanPrune
- All Known Implementing Classes:
- LegacyCell,- NumberRangePrefixTree.NRCell,- PackedQuadPrefixTree.PackedQuadCell,- QuadPrefixTree.QuadCell
public interface Cell
Represents a grid cell. Cell instances are generally very transient and may be re-used
 internally. To get an instance, you could start with 
SpatialPrefixTree.getWorldCell().
 And from there you could either traverse down the tree with getNextLevelCells(org.locationtech.spatial4j.shape.Shape), or you could read an indexed term
 via SpatialPrefixTree.readCell(org.apache.lucene.util.BytesRef,Cell). When a cell is read
 from a term, it is comprised of just the base bytes plus optionally a leaf flag.- WARNING: This API is experimental and might change in incompatible ways in the next release.
- 
Method SummaryModifier and TypeMethodDescriptionintcompareToNoLeaf(Cell fromCell) Equivalent tothis.getTokenBytesNoLeaf(null).compareTo(fromCell.getTokenBytesNoLeaf(null)).intgetLevel()Level 0 is the world (and has no parent), from then on a higher level means a smaller cell than the level before it.getNextLevelCells(org.locationtech.spatial4j.shape.Shape shapeFilter) Gets the cells at the next grid cell level underneath this one, optionally filtered byshapeFilter.org.locationtech.spatial4j.shape.ShapegetShape()Gets the shape for this cell; typically a Rectangle.org.locationtech.spatial4j.shape.SpatialRelationGets the relationship this cell has with the shape from which it was filtered from, assuming it came from aCellIterator.getTokenBytesNoLeaf(BytesRef result) Returns the bytes for this cell, without a leaf set.getTokenBytesWithLeaf(BytesRef result) Returns the bytes for this cell, with a leaf byte if this is a leaf cell.booleanisLeaf()Some cells are flagged as leaves, which are indexed as such.booleanisPrefixOf(Cell c) Returns if the target term is within/underneath this cell; not necessarily a direct descendant.voidsetLeaf()Set this cell to be a leaf.voidsetShapeRel(org.locationtech.spatial4j.shape.SpatialRelation rel) SeegetShapeRel().
- 
Method Details- 
getShapeRelorg.locationtech.spatial4j.shape.SpatialRelation getShapeRel()Gets the relationship this cell has with the shape from which it was filtered from, assuming it came from aCellIterator. Arguably it belongs there but it's very convenient here.
- 
setShapeRelvoid setShapeRel(org.locationtech.spatial4j.shape.SpatialRelation rel) SeegetShapeRel().- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
isLeafboolean isLeaf()Some cells are flagged as leaves, which are indexed as such. A leaf cell is either within some shape or it both intersects and the cell is at an accuracy threshold such that no smaller cells for the shape will be represented.
- 
setLeafvoid setLeaf()Set this cell to be a leaf. Warning: never call on a cell initialized to reference the same bytes from termsEnum, which should be treated as immutable. Note: not supported at level 0.- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
 
- 
getTokenBytesWithLeafReturns the bytes for this cell, with a leaf byte if this is a leaf cell. The result param is used to save object allocation, though its bytes aren't used.- Parameters:
- result- where the result goes, or null to create new
 
- 
getTokenBytesNoLeafReturns the bytes for this cell, without a leaf set. The bytes should sort beforegetTokenBytesWithLeaf(org.apache.lucene.util.BytesRef). The result param is used to save object allocation, though its bytes aren't used.- Parameters:
- result- where the result goes, or null to create new
 
- 
getLevelint getLevel()Level 0 is the world (and has no parent), from then on a higher level means a smaller cell than the level before it.
- 
getNextLevelCellsGets the cells at the next grid cell level underneath this one, optionally filtered byshapeFilter. The returned cells should havegetShapeRel()set to their relation withshapeFilter. In addition, for non-pointsisLeaf()must be true when that relation is WITHIN.IMPORTANT: Cells returned from this iterator can be shared, as well as the bytes. Precondition: Never called when getLevel() == maxLevel. - Parameters:
- shapeFilter- an optional filter for the returned cells.
- Returns:
- A set of cells (no dups), sorted. Not Modifiable.
 
- 
getShapeorg.locationtech.spatial4j.shape.Shape getShape()Gets the shape for this cell; typically a Rectangle.
- 
isPrefixOfReturns if the target term is within/underneath this cell; not necessarily a direct descendant.- Parameters:
- c- the term
 
- 
compareToNoLeafEquivalent tothis.getTokenBytesNoLeaf(null).compareTo(fromCell.getTokenBytesNoLeaf(null)).
 
-