iText in Action 2nd Edition
The DirectorPhrases1 example is part of the book iText in Action (ISBN 9781935182610).
It's a
small standalone application. You can use this example for inspiration, but please buy the book if there's something
you don't understand about the example.
Read Chapter 2 for more info.
Note that this example depends on
DatabaseConnection,
HsqldbConnection,
and maybe some other examples.
Chapter 2: Using iText's basic building blocks
Keywords for this example: Font, SQL, Underline, Basic building blocks > Phrase, Encoding > Database query
If you want this example to work, you need the following jars:
iText.jar, hsqldb.jar
This example is used as a helper class for: DirectorPhrases2
part1.chapter02.DirectorPhrases1
If you compile and execute this example, you'll get the following result:
You can download the full source code of DirectorPhrases1, or read it here:
/* * This class is part of the book "iText in Action - 2nd Edition" * written by Bruno Lowagie (ISBN: 9781935182610) * For more info, go to: http://itextpdf.com/examples/ * This example only works with the AGPL version of iText. */ package part1.chapter02; import java.io.FileOutputStream; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import com.lowagie.database.DatabaseConnection; import com.lowagie.database.HsqldbConnection; import com.itextpdf.text.Chunk; import com.itextpdf.text.Document; import com.itextpdf.text.DocumentException; import com.itextpdf.text.Font; import com.itextpdf.text.Phrase; import com.itextpdf.text.Font.FontFamily; import com.itextpdf.text.pdf.PdfWriter; /** * Writes a list of directors to a PDF file. */ public class DirectorPhrases1 { /** The resulting PDF file. */ public static final String RESULT = "results/part1/chapter02/director_phrases_1.pdf"; /** A font that will be used in our PDF. */ public static final Font BOLD_UNDERLINED = new Font(FontFamily.TIMES_ROMAN, 12, Font.BOLD | Font.UNDERLINE); /** A font that will be used in our PDF. */ public static final Font NORMAL = new Font(FontFamily.TIMES_ROMAN, 12); /** * Creates a Phrase with the name and given name of a director using different fonts. * @param rs the ResultSet containing director records. */ public Phrase createDirectorPhrase(ResultSet rs) throws UnsupportedEncodingException, SQLException { Phrase director = new Phrase(); director.add( new Chunk(new String(rs.getBytes("name"), "UTF-8"), BOLD_UNDERLINED)); director.add(new Chunk(",", BOLD_UNDERLINED)); director.add(new Chunk(" ", NORMAL)); director.add( new Chunk(new String(rs.getBytes("given_name"), "UTF-8"), NORMAL)); return director; } /** * Creates a PDF file with director names. * @param filename the name of the PDF file that needs to be created. * @throws DocumentException * @throws IOException * @throws SQLException */ public void createPdf(String filename) throws IOException, DocumentException, SQLException { // step 1 Document document = new Document(); // step 2 PdfWriter.getInstance(document, new FileOutputStream(filename)); // step 3 document.open(); // step 4 // create the database connection and statement DatabaseConnection connection = new HsqldbConnection("filmfestival"); Statement stm = connection.createStatement(); ResultSet rs = stm.executeQuery( "SELECT name, given_name FROM film_director ORDER BY name, given_name"); // loop over the results while (rs.next()) { document.add(createDirectorPhrase(rs)); document.add(Chunk.NEWLINE); } // close the statement and database connection stm.close(); connection.close(); // step 5 document.close(); } /** * Main method. * * @param args no arguments needed * @throws DocumentException * @throws IOException * @throws SQLException */ public static void main(String[] args) throws IOException, DocumentException, SQLException { new DirectorPhrases1().createPdf(RESULT); } }
Content © 2010-2013 1T3XT BVBA

