This week's giveaway is in the Android forum.
We're giving away four copies of Android Security Essentials Live Lessons and have Godfrey Nolan on-line!
See this thread for details.
The moose likes Java in General and the fly likes PDFBox. Assigning Multiple Quads to an Annotation. Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login


Win a copy of Android Security Essentials Live Lessons this week in the Android forum!
JavaRanch » Java Forums » Java » Java in General
Bookmark "PDFBox. Assigning Multiple Quads to an Annotation." Watch "PDFBox. Assigning Multiple Quads to an Annotation." New topic
Author

PDFBox. Assigning Multiple Quads to an Annotation.

Jonny On
Greenhorn

Joined: Oct 26, 2013
Posts: 2
Hello. My first post.

Is it possible to create 'grouped' highlights using PDFBox?

I am trying to use PDFBox to highlight text within a document. I have extracted the text and have obtained the coordinates, but am having trouble creating annotations. PDFBox annotations (for example: PDAnnotationTextMarkup) only seem to accept one quad and/or rectangle for the highlight area. This means that 2 lines of text cannot be highlighted without creating one large highlight that surrounds both lines. Acrobat itself creates multiple boxes when highlighting multiple lines, and they all are part of the one annotation, so they only have one popup, and will be deleted as a group. Is there a way to replicate this using PDFBox?

The following is a test I did in which I used Adobe Acrobat Reader to make a single annotation which is comprised of two highlights (last line of one paragraph and first line of the other). It extracts each individual highlight, deletes all highlights on the page, then reintroduces them.




The System.print output shows two PDAnnotations for the my one annotation (comprised of two highlight boxes) in Acrobat.


Contents: Test
Rectangle: [97.6047,501.694,388.719,667.245]
Annotation name: 0ad2bc10-404b-43bc-8be8-58465a4c7e2f
***
Contents: null
Rectangle: [595.22,546.64,775.22,666.64]
Annotation name: null



So it seems to treat each highlighted area as a separate PDAnnotation. However, when each PDAnnotation is inserted back into the annotation array separately, they are still grouped together when the document is opened. So they are retaining some kind of connection. My current task is to create two separate annotations in Adobe Acrobat Reader and to try and group them together. I have had no luck over several hours.

Of course, if I have gone off on a tangent and a simpler solution exists, I would love to hear it. But as usual, hope of a clean solution is fading


Thanks
Jonny O.
Jonny On
Greenhorn

Joined: Oct 26, 2013
Posts: 2
So it seems I was misinterpreting the data.

The popup box for each annotation is listed as a separate annotation. So the two annotations I in my output were actually 1 highlight and 1 popup box. So when extracting the PDAnnotations from a page I need to find out what sub-class it is and then I can go from there.

And as far as multiple quad points. I received a prompt reply from Gilard D. who stated that all quad points are bundled into the one quad. I mislead myself by cramming two quads into a float[16] array but got a very messed up shape drawn on the page, so I assumed it was just ignoring the higher indexes. However, I did test Gilard's information by extracting an existing annotation and displaying the quad points. It showed a float of length 28 or so. Therefore it looks very plausible. Now I just have to work out how each point is arranged in the quad and then I can get back on track.

Thanks
Jonny O.
 
 
subject: PDFBox. Assigning Multiple Quads to an Annotation.
 
Similar Threads
Launching other applications from Java GUI
Question regarding State of session bean
Convert PDF to HTML & Enhanced Pdf to JPEG Conversion inside Java Apps
Archiving Files in zip files
PDF error from iText