break; case CROSSES: propertyName = ( (Crosses) operator ).getPropName(); geometry = ( (Crosses) operator ).getGeometry(); break; case DISJOINT:
@Override public <T> boolean evaluate( T obj, XPathEvaluator<T> xpathEvaluator ) throws FilterEvaluationException { for ( TypedObjectNode paramValue : propName.evaluate( obj, xpathEvaluator ) ) { Geometry geom = checkGeometryOrNull( paramValue ); if ( geom != null ) { Geometry transformedLiteral = getCompatibleGeometry( geom, geometry ); return geom.crosses( transformedLiteral ); } } return false; }
case CROSSES: Crosses crosses = (Crosses) op; return new Crosses( copy( crosses.getPropName() ), crosses.getGeometry() ); case DISJOINT: Disjoint disjoint = (Disjoint) op;
break; case CROSSES: geometry = ( (Crosses) operator ).getGeometry(); break; case DISJOINT:
private static BBOX extractBBox( SpatialOperator oper ) { SubType type = oper.getSubType(); switch ( type ) { case BBOX: return (BBOX) oper; case CONTAINS: // Oracle does not like zero-extent bboxes if ( !( ( (Contains) oper ).getGeometry() instanceof Point ) ) return new BBOX( ( (Contains) oper ).getParam1(), ( (Contains) oper ).getGeometry().getEnvelope() ); return null; case CROSSES: return new BBOX( ( (Crosses) oper ).getParam1(), ( (Crosses) oper ).getGeometry().getEnvelope() ); case DWITHIN: // TOOD use enlarged bbox return null; case EQUALS: return new BBOX( ( (Equals) oper ).getParam1(), ( (Equals) oper ).getGeometry().getEnvelope() ); case INTERSECTS: return new BBOX( ( (Intersects) oper ).getParam1(), ( (Intersects) oper ).getGeometry().getEnvelope() ); case OVERLAPS: return new BBOX( ( (Overlaps) oper ).getParam1(), ( (Overlaps) oper ).getGeometry().getEnvelope() ); case WITHIN: return new BBOX( ( (Within) oper ).getParam1(), ( (Within) oper ).getGeometry().getEnvelope() ); default: { return null; } } }
spatialOperator = new Crosses( param1, param2 ); break;
Crosses crosses = (Crosses) op; builder.add( propNameExpr ).add( ".STCrosses(" ); builder.add( toProtoSQL( crosses.getGeometry(), storageCRS, srid ) ); builder.add( ")=1" ); break;
return new Contains( (Expression) os[0], (Geometry) os[1] ); case CROSSES: return new Crosses( (Expression) os[0], (Geometry) os[1] ); case DISJOINT: return new Disjoint( (Expression) os[0], (Geometry) os[1] );
builder.add( toProtoSQL( crosses.getGeometry(), storageCRS, srid ) ); builder.add( ")" ); break;
spatialOperator = new Crosses( param1, param2 ); break;
spatialOperator = new Crosses( param1, param2 ); break;