PDFをJPEG2000に変換
JPedalは、PDFファイルまたはPDFファイルのディレクトリをJPXにラスタライズするための複数のメソッドを提供しています。Javaの例では、ConvertPagesToImages クラスとJpeg2000EncoderOptions クラスを使用します。
すべてのページを画像としてレンダリング
java -jar jpedal.jar --convert "inputFileOrFolder" "outputFolder" jpx
変換を調整するために異なる設定を提供することもできます。
java -jar jpedal.jar --convert "inputFileOrFolder" "outputFolder" jpx ScalingAsFloat
java -jar jpedal.jar --convert "inputFileOrFolder" "outputFolder" jpx ScalingAsFloat PageRange
名前付き変数の使用方法は以下で詳しく説明します。
- ScalingAsFloat: 出力に適用されるスケーリングを指定するfloat値です。これは表示スケーリングを100で割った値で、例えば150%は1.5になります
- PageRange: 変換するページの範囲です。これはSetOfIntegerSyntax
と同じルールに従います。
カンマで区切られた値のシリーズで、単一のページ番号またはダッシュを使用した2つの値の範囲を指定できます。例えば、「1,3,4-7」はページ1,3,4,5,6,7を意味します
ConvertPagesToImages.writeAllPagesAsImagesToDir(
"inputFileOrFolder",
"outputFolder",
"jpx",
1.33f);
ConvertPagesToImages convert = new ConvertPagesToImages("inputFile.pdf");
try {
if (convert.openPDFFile()) {
for(int page = 1; page <= convert.getPageCount(); page++) {
final BufferedImage bi = convert.getPageAsImage(page);
final File out = new File("outputFolder" + page + ".jpx");
// 出力を制御するセッター(圧縮の例)
final Jpeg2000EncoderOptions options = new Jpeg2000EncoderOptions();
options.setQuality(90); //デフォルトは75。無圧縮は100
options.setOutputSubtype(Jpeg2000OutputSubtype.JPX); //デフォルトはJPX。JP2も可能
JDeli.write(bi, options, out);
}
}
} catch (PdfException | IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
convert.closePDFfile();
ConvertPagesToImages convert = new ConvertPagesToImages("inputFile.pdf");
// setPageRangeを使用すると、'-'または':'で範囲を指定し、
// ','で次の範囲に移動できます。すべてのページの場合は単にnullを指定します
convert.setPageRange(new PageRanges("1-5,8:10,15"));
// 上記はページ1から5(両端を含む)、8から10(両端を含む)、および15を取得します
try {
if (convert.openPDFFile()) {
convert.getPageRange().forEachRemaining(page -> {
try {
final BufferedImage bi = convert.getPageAsImage(page);
final File out = new File("outputFolder" + page + ".jpx");
JDeli.write(bi, options, out);
} catch (Exception e) {
e.printStackTrace();
}
});
}
} catch (PdfException e) {
e.printStackTrace();
}
convert.closePDFfile();
ConvertPagesToImages.writeAllPagesAsImagesToDir(
"inputFileOrFolder",
"outputFolder",
"jpx",
new int[] {width, height});
または
ConvertPagesToImages convert = new ConvertPagesToImages("inputFile.pdf");
//アスペクト比を維持してフィット(幅が300または高さが400になります)
convert.setFitToSize(new int[] {300,400});
try {
if (convert.openPDFFile()) {
for (int page = 1; page <= convert.getPageCount(); page++) {
final BufferedImage bi = convert.getPageAsImage(page);
final File out = new File("outputFolder" + page + ".jpx");
JDeli.write(bi, OutputFormat.JPEG2000, out);
}
}
} catch (PdfException | IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
convert.closePDFfile();
ConvertPagesToImages convert = new ConvertPagesToImages("inputFile.pdf");
convert.setPageScaling(1.33f); //Acrobatの100%と同じサイズになります
try {
if (convert.openPDFFile()) {
for (int page = 1; page <= convert.getPageCount(); page++) {
final BufferedImage bi = convert.getPageAsImage(page);
final File out = new File("outputFolder" + page + ".jpx");
JDeli.write(bi, OutputFormat.JPEG2000, out);
}
}
} catch (PdfException | IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
convert.closePDFfile();
ConvertPagesToImages convert = new ConvertPagesToImages("inputFile.pdf");
convert.setPassword("password");
try {
if (convert.openPDFFile()) {
for (int page = 1; page <= convert.getPageCount(); page++) {
final BufferedImage bi = convert.getPageAsImage(page);
final File out = new File("outputFolder" + page + ".jpx");
JDeli.write(bi, OutputFormat.JPEG2000, out);
}
}
} catch (PdfException | IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
convert.closePDFfile();
アップスケーリングやPDFからJPXへの変換のより複雑な制御をお探しの場合は、ConvertPagesToHiResImages クラスに多数の追加オプション があります
