挿入するレイヤーの回転角度を指定レイヤーの回転角度を90度単位で指定します。
90度単位で回転角度を指定し、6.1.1 レイヤーに使用するPDF文書ページを設定と同様にしてレイヤーを挿入します。
『PDF Tool API V7.0』以降のバージョンでは、回転角度を自由に設定できるsetAngle()関数が追加されました。詳細は「『PDF CookBook』(第5巻)10.5.1 角度設定(レイヤー描画)」を参照してください。
PtlParamDrawLayer.APIsetRotate(int value): 回転角度を設定
角度は絶対値で90度単位のみで指定してください。それ以外の値を指定した場合の動作は保証されません。回転角度を設定する場合は他の関数より先に設定してください。
package cookbook; import jp.co.antenna.ptl.*; public class DrawLayerSetRotationAngle { // そのクラスのusageを表示する関数 private static void printUsage() { System.out.println("usage: java DrawLayerSetRotationAngle in-pdf-file" + " out-pdf-file page-num insert-pdf-file" + " page-num-to-insert rotation-angle"); System.out.println("rotation-angle:"); System.out.println("回転する角度。0, 90, 180, 270のいずれかで指定。"); } /** * @param args the command line arguments */ public static void main(String[] args) { if (args.length < 5) { printUsage(); return; } try (PtlParamInput inputFile = new PtlParamInput(args[0]); PtlParamOutput outputFile = new PtlParamOutput(args[1]); PtlPDFDocument doc = new PtlPDFDocument()) { // PDFファイルをロードします。 doc.load(inputFile); // コマンドライン引数の判定 int pageToAdd = Integer.parseInt(args[2]); int numPages = doc.getPageCount(); System.out.println("ページ数:" + numPages); if((numPages < 0)||(numPages < pageToAdd)) { System.err.println("page-numは入力PDFの全ページ数よりも小さい正の値を" + "指定してください。"); printUsage(); return; } String insertPDFPath = args[3]; int insertPageNum = Integer.parseInt(args[4]); int angle = Integer.parseInt(args[5]); switch(angle) { case 0: case 90: case 180: case 270: break; default : System.out.println("rotation-angleは0, 90, 180, 270のいずれかを" + "指定して下さい。"); printUsage(); return ; } try (PtlPages pages = doc.getPages()) { // ページコンテナの取得 // ページコンテナが空かどうか if (pages.isEmpty()) { System.out.println("ページコンテナが空"); return; } // ページの取得(パラメータindexは0が先頭のため1を引く) try (PtlPage page = pages.get(pageToAdd - 1)) { //レイヤーの描画 drawLayerSetRotationAngle(page, insertPDFPath, insertPageNum, angle); } } // ファイルに保存します。 doc.save(outputFile); } ...【ExtractText.javaと同じ処理のため省略 ・エラーメッセージ処理と出力】... } public static void drawLayerSetRotationAngle(PtlPage page, String insertPDFPath, int insertPageNum, int angle) throws PtlException, Exception, Error { try (PtlSize pageSize = page.getSize(); // ページサイズ PtlContent content = page.getContent(); // ページコンテントの取得 PtlPDFDocument docToInsert = new PtlPDFDocument(); //挿入するPDF PtlParamInput inputFileToInsert = new PtlParamInput(insertPDFPath); // 描画矩形の指定(PDFいっぱいに指定) PtlRect rect = new PtlRect(0.0f, 0.0f, pageSize.getWidth(), pageSize.getHeight())) { // PDFファイルをロードします。 docToInsert.load(inputFileToInsert); try (PtlPages pagesToInsert = docToInsert.getPages()) { // ページコンテナの取得 // ページコンテナが空かどうか if (pagesToInsert.isEmpty()) { System.out.println("ページコンテナが空"); return; } // ページの取得(パラメータindexは0が先頭のため1を引く) // レイヤーのパラメーターの取得 try (PtlPage pageInsert = pagesToInsert.get(insertPageNum - 1); PtlParamDrawLayer param = new PtlParamDrawLayer()) { // レイヤーの回転角度を指定 param.setRotate(angle); // レイヤーにするページ param.setPage(pageInsert); // レイヤーの名前 param.setName("Layer1"); // レイヤーを前面に param.setZorder(PtlParamDrawLayer.ZORDER.ZORDER_FRONT); // レイヤーを表示 param.setShow(PtlParamDrawLayer.SHOW.SHOW_ON); // レイヤーの描画 content.drawLayer(rect, PtlContent.ALIGN.ALIGN_CENTER, param); } } } } }
DrawLayerSetRotationAngle.java
C:\samples>>java cookbook.DrawLayerSetRotationAngle usage: java DrawLayerSetRotationAngle in-pdf-file out-pdf-file page-num insert-pdf-file page-num-to-insert rotation-angle rotation-angle: 回転する角度。0, 90, 180, 270のいずれかで指定。 C:\samples>>java cookbook.DrawLayerSetRotationAngle AHLetterHead.pdf DrawLayerSetRotationAngle.pdf 1 AHLogo.pdf 1 270 ページ数:1 -- 完了 --
次の図のようにロゴのレイヤーは時計回りに270度回転されています。