Class LocationTextExtractionStrategy.TextChunkLocationDefaultImp
java.lang.Object
com.itextpdf.text.pdf.parser.LocationTextExtractionStrategy.TextChunkLocationDefaultImp
- All Implemented Interfaces:
LocationTextExtractionStrategy.TextChunkLocation, Comparable<LocationTextExtractionStrategy.TextChunkLocation>
- Enclosing class:
LocationTextExtractionStrategy
public static class LocationTextExtractionStrategy.TextChunkLocationDefaultImp
extends Object
implements LocationTextExtractionStrategy.TextChunkLocation
- Since:
- 5.0.2
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final floatthe width of a single space character in the font of the chunkprivate final floatdistance of the end of the chunk parallel to the orientation unit vector (i.e.private final floatdistance of the start of the chunk parallel to the orientation unit vector (i.e.private final intperpendicular distance to the orientation unit vector (i.e.private final Vectorthe ending location of the chunkprivate final intthe orientation as a scalar for quick sortingprivate final Vectorunit vector in the orientation of the chunkprivate final Vectorthe starting location of the chunk -
Constructor Summary
ConstructorsConstructorDescriptionTextChunkLocationDefaultImp(Vector startLocation, Vector endLocation, float charSpaceWidth) -
Method Summary
Modifier and TypeMethodDescriptionintfloatComputes the distance between the end of 'other' and the beginning of this chunk in the direction of this chunk's orientation vector.floatfloatintfloatbooleanintboolean
-
Field Details
-
startLocation
the starting location of the chunk -
endLocation
the ending location of the chunk -
orientationVector
unit vector in the orientation of the chunk -
orientationMagnitude
private final int orientationMagnitudethe orientation as a scalar for quick sorting -
distPerpendicular
private final int distPerpendicularperpendicular distance to the orientation unit vector (i.e. the Y position in an unrotated coordinate system) we round to the nearest integer to handle the fuzziness of comparing floats -
distParallelStart
private final float distParallelStartdistance of the start of the chunk parallel to the orientation unit vector (i.e. the X position in an unrotated coordinate system) -
distParallelEnd
private final float distParallelEnddistance of the end of the chunk parallel to the orientation unit vector (i.e. the X position in an unrotated coordinate system) -
charSpaceWidth
private final float charSpaceWidththe width of a single space character in the font of the chunk
-
-
Constructor Details
-
TextChunkLocationDefaultImp
-
-
Method Details
-
orientationMagnitude
public int orientationMagnitude()- Specified by:
orientationMagnitudein interfaceLocationTextExtractionStrategy.TextChunkLocation
-
distPerpendicular
public int distPerpendicular()- Specified by:
distPerpendicularin interfaceLocationTextExtractionStrategy.TextChunkLocation
-
distParallelStart
public float distParallelStart()- Specified by:
distParallelStartin interfaceLocationTextExtractionStrategy.TextChunkLocation
-
distParallelEnd
public float distParallelEnd()- Specified by:
distParallelEndin interfaceLocationTextExtractionStrategy.TextChunkLocation
-
getStartLocation
- Specified by:
getStartLocationin interfaceLocationTextExtractionStrategy.TextChunkLocation- Returns:
- the start location of the text
-
getEndLocation
- Specified by:
getEndLocationin interfaceLocationTextExtractionStrategy.TextChunkLocation- Returns:
- the end location of the text
-
getCharSpaceWidth
public float getCharSpaceWidth()- Specified by:
getCharSpaceWidthin interfaceLocationTextExtractionStrategy.TextChunkLocation- Returns:
- the width of a single space character as rendered by this chunk
-
sameLine
- Specified by:
sameLinein interfaceLocationTextExtractionStrategy.TextChunkLocation- Parameters:
as- the location to compare to- Returns:
- true is this location is on the the same line as the other
-
distanceFromEndOf
Computes the distance between the end of 'other' and the beginning of this chunk in the direction of this chunk's orientation vector. Note that it's a bad idea to call this for chunks that aren't on the same line and orientation, but we don't explicitly check for that condition for performance reasons.- Specified by:
distanceFromEndOfin interfaceLocationTextExtractionStrategy.TextChunkLocation- Parameters:
other-- Returns:
- the number of spaces between the end of 'other' and the beginning of this chunk
-
isAtWordBoundary
- Specified by:
isAtWordBoundaryin interfaceLocationTextExtractionStrategy.TextChunkLocation
-
compareTo
- Specified by:
compareToin interfaceComparable<LocationTextExtractionStrategy.TextChunkLocation>
-