PDFをJPGに変換する
JPedalは、PDFファイルまたはPDFファイルのディレクトリをJPGにラスタライズするためのいくつかのメソッドを提供しています。Javaの例では、ConvertPagesToImages クラスとJpegEncoderOptions クラスを使用します。
すべてのページを画像としてレンダリングする
java -jar jpedal.jar --convert "inputFileOrFolder" "outputFolder" jpg
変換を調整するために、異なる設定を指定することもできます。
java -jar jpedal.jar --convert "inputFileOrFolder" "outputFolder" jpg ScalingAsFloat
java -jar jpedal.jar --convert "inputFileOrFolder" "outputFolder" jpg 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",
"jpg",
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 + ".jpg");
// 出力を制御するセッター(圧縮の例)
final JpegEncoderOptions options = new JpegEncoderOptions();
options.setQuality(90); //デフォルトは75。圧縮なしは100
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 + ".jpg");
JDeli.write(bi, options, out);
} catch (Exception e) {
e.printStackTrace();
}
});
}
} catch (PdfException e) {
e.printStackTrace();
}
convert.closePDFfile();
ConvertPagesToImages.writeAllPagesAsImagesToDir(
"inputFileOrFolder",
"outputFolder",
"jpg",
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 + ".jpg");
JDeli.write(bi, OutputFormat.JPEG, 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 + ".jpg");
JDeli.write(bi, OutputFormat.JPEG, 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 + ".jpg");
JDeli.write(bi, OutputFormat.JPEG, out);
}
}
} catch (PdfException | IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
convert.closePDFfile();
アップスケーリングやPDFからJPGへの変換をより複雑に制御したい場合は、ConvertPagesToHiResImages クラスに多数の追加オプション があります
