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");
// 出力を制御するセッター(圧縮の例)
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 クラスに多数の追加オプション があります
