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