A bookmark in a PDF document consists of formatted text linking to a specific section of the document. Readers can navigate through pages by simply clicking on the bookmarks displayed on the side of the page instead of scrolling up and down, which is very helpful for those huge documents. Moreover, well-organized bookmarks can also serve as contents. When you create a PDF document with a lot of pages, it’s better to add bookmarks to link to significant content. This article is going to show how to add, modify, and remove bookmarks in PDF documents using Spire.PDF for Java through programming.
- Add Bookmarks to a PDF Document
- Edit Bookmarks in a PDF Document
- Delete Bookmarks from a PDF Document
Install Spire.PDF for Java
First of all, you're required to add the Spire.Pdf.jar file as a dependency in your Java program. The JAR file can be downloaded from this link. If you use Maven, you can easily import the JAR file in your application by adding the following code to your project's pom.xml file.
<repositories> <repository> <id>com.e-iceblue</id> <name>e-iceblue</name> <url>https://repo.e-iceblue.com/nexus/content/groups/public/</url> </repository> </repositories> <dependencies> <dependency> <groupId>e-iceblue</groupId> <artifactId>spire.pdf</artifactId> <version>10.10.7</version> </dependency> </dependencies>
Add Bookmarks to a PDF Document
Spire.PDF for Java provides PdfDocument.getBookmarks().add() method to add bookmarks to a PDF document. In addition to adding primary bookmarks, we can use PdfBookmark.add() method to add a sub-bookmark to a primary bookmark. There are also many other methods under PdfBookmark class which are used to set the destination, text color, and text style of bookmarks. The detailed steps of adding bookmarks to a PDF document are as follows.
- Create a PdfDocument class instance.
- Load a PDF document using PdfDocument.loadFromFile() method.
- Loop through the pages in the PDF document to add bookmarks and set their styles.
- Add a primary bookmark to the document using PdfDocument.getBookmarks().add() method.
- Create a PdfDestination class object and set the destination of the primary bookmark using PdfBookmark.setAction() method.
- Set the text color of the primary bookmark using PdfBookmark.setColor() method.
- Set the text style of the Primary bookmark using PdfBookmark.setDisplayStyle() method.
- Add a sub-bookmark to the primary bookmark using PdfBookmark.add() method.
- Use the above methods to set the destination, text color, and text style of the sub-bookmark.
- Save the document using PdfDocument.saveToFile() method.
- Java
import com.spire.pdf.PdfDocument; import com.spire.pdf.PdfPageBase; import com.spire.pdf.actions.PdfGoToAction; import com.spire.pdf.bookmarks.PdfBookmark; import com.spire.pdf.bookmarks.PdfTextStyle; import com.spire.pdf.general.PdfDestination; import com.spire.pdf.graphics.PdfRGBColor; import java.awt.*; import java.awt.geom.Point2D; public class addBookmark { public static void main(String[] args) { //Create a PdfDocument class instance PdfDocument pdf = new PdfDocument(); //Load a PDF file pdf.loadFromFile("There's No Planet B.pdf"); //Loop through the pages in the PDF file for(int i = 0; i< pdf.getPages().getCount();i++) { PdfPageBase page = pdf.getPages().get(i); //Add a bookmark PdfBookmark bookmark = pdf.getBookmarks().add(String.format("Bookmark-%s", i + 1)); //Set the destination page and location PdfDestination destination = new PdfDestination(page, new Point2D.Float(0, 0)); bookmark.setAction(new PdfGoToAction(destination)); //Set the text color bookmark.setColor(new PdfRGBColor(new Color(139, 69, 19))); //Set the text style bookmark.setDisplayStyle(PdfTextStyle.Bold); //Add a child bookmark PdfBookmark childBookmark = bookmark.add(String.format("Sub-Bookmark-%s", i + 1)); //Set the destination page and location PdfDestination childDestination = new PdfDestination(page, new Point2D.Float(0, 100)); childBookmark.setAction(new PdfGoToAction(childDestination)); //Set the text color childBookmark.setColor(new PdfRGBColor(new Color(255, 127, 80))); //Set the text style childBookmark.setDisplayStyle(PdfTextStyle.Italic); } //Save the result file pdf.saveToFile("AddBookmarks.pdf"); } }
Edit Bookmarks in a PDF Document
We can also use methods of PdfBookmark class in Spire.PDF for Java to edit existing PDF bookmarks. The detailed steps are as follows.
- Create a PdfDocument class instance.
- Load a PDF document using PdfDocument.loadFromFile() method.
- Get the first bookmark using PdfDocument.getBookmarks().get() method.
- Change the title of the bookmark using PdfBookmark.setTitle() method.
- Change the font color of the bookmark using PdfBookmark.setColor() method.
- Change the outline text style of the bookmark using PdfBookmark.setDisplayStyle() method.
- Change the text color and style of the sub-bookmark using the above methods.
- Save the document using PdfDocument.saveToFile() method.
- Java
import com.spire.pdf.PdfDocument; import com.spire.pdf.bookmarks.PdfBookmark; import com.spire.pdf.bookmarks.PdfTextStyle; import com.spire.pdf.graphics.PdfRGBColor; import java.awt.*; public class editBookmarks { public static void main(String[] args) { //Create a PdfDocument class instance PdfDocument doc = new PdfDocument(); //Load a PDF file doc.loadFromFile("AddBookmarks.pdf"); //Get the first bookmark PdfBookmark bookmark = doc.getBookmarks().get(0); //Change the title of the bookmark bookmark.setTitle("New Title"); //Change the font color of the bookmark bookmark.setColor(new PdfRGBColor(new Color(255,0,0))); //Change the outline text style of the bookmark bookmark.setDisplayStyle(PdfTextStyle.Italic); //Edit sub-bookmarks of the first bookmark for (PdfBookmark childBookmark : (Iterable) bookmark) { childBookmark.setColor(new PdfRGBColor(new Color(0,0,255))); childBookmark.setDisplayStyle(PdfTextStyle.Bold); } //Save the result file doc.saveToFile("EditBookmarks.pdf"); doc.close(); } }
Delete Bookmarks from a PDF Document
We can use Spire.PDF for Java to delete any bookmark in a PDF document. PdfDocument.getBookmarks().removeAt() is used to remove a specific primary bookmark, PdfDocument.getBookmarks().clear() method is used to remove all bookmarks, and PdfBookmark.removeAt() method is used to remove a specific sub-bookmark of a primary bookmark. The detailed steps of removing bookmarks form a PDF document are as follows.
- Create PdfDocument class instance.
- Load a PDF document using PdfDocument.loadFromFile() method.
- Get the first bookmark using PdfDocument.getBookmarks().get() method.
- Remove the sub-bookmark of the first bookmark using PdfBookmark.removeAt() method.
- Save the document using PdfDocument.saveToFile() method.
- Java
import com.spire.pdf.PdfDocument; import com.spire.pdf.bookmarks.PdfBookmark; public class deleteBookmarks { public static void main(String[] args) { //Create a PdfDocument instance PdfDocument pdf = new PdfDocument(); //Load the PDF file pdf.loadFromFile("AddBookmarks.pdf"); //Get the first bookmark PdfBookmark pdfBookmark = pdf.getBookmarks().get(0); //Delete the sub-bookmark of the first bookmark pdfBookmark.removeAt(0); //Delete the first bookmark along with its child bookmark //pdf.getBookmarks().removeAt(0); //Delete all the bookmarks //pdf.getBookmarks().clear(); //Save the result file pdf.saveToFile("DeleteBookmarks.pdf"); } }
Apply for a Temporary License
If you'd like to remove the evaluation message from the generated documents, or to get rid of the function limitations, please request a 30-day trial license for yourself.