Преобразовать слайды презентации в изображения на Java
Обзор
Aspose.Slides for Java позволяет вам легко преобразовывать слайды презентаций PowerPoint и OpenDocument в различные форматы изображений, включая BMP, PNG, JPG (JPEG), GIF и другие.
Чтобы преобразовать слайд в изображение, выполните следующие действия:
- Определите необходимые параметры конверсии и выберите слайды, которые хотите экспортировать, используя:
- интерфейс ITiffOptions
- интерфейс IRenderingOptions
- Создайте изображение слайда, вызвав метод getImage.
В Aspose.Slides for Java интерфейс IImage представляет собой интерфейс, позволяющий работать с изображениями, определенными пиксельными данными. Вы можете использовать этот интерфейс для сохранения изображений в широком спектре форматов (BMP, JPG, PNG и т.д.).
Преобразование слайдов в растровые изображения и сохранение их в PNG
Вы можете преобразовать слайд в объект bitmap и использовать его непосредственно в приложении. Кроме того, вы можете преобразовать слайд в bitmap, а затем сохранить изображение в JPEG или любом другом предпочтительном формате.
Этот код демонстрирует, как преобразовать первый слайд презентации в объект bitmap и затем сохранить изображение в формате PNG:
Presentation presentation = new Presentation("Presentation.pptx");
try {
// Преобразовать первый слайд презентации в bitmap.
IImage image = presentation.getSlides().get_Item(0).getImage();
try {
// Сохранить изображение в формате PNG.
image.save("Slide_0.png", ImageFormat.Png);
} finally {
image.dispose();
}
} finally {
presentation.dispose();
}
Преобразование слайдов в изображения с пользовательскими размерами
Возможно, вам понадобится изображение определённого размера. Используя перегрузку метода getImage, вы можете преобразовать слайд в изображение с конкретными параметрами ширины и высоты.
Этот пример кода демонстрирует, как это сделать:
Dimension imageSize = new Dimension(1820, 1040);
Presentation presentation = new Presentation("Presentation.pptx");
try {
// Преобразовать первый слайд презентации в bitmap заданного размера.
IImage image = presentation.getSlides().get_Item(0).getImage(imageSize);
try {
// Сохранить изображение в формате JPEG.
image.save("Slide_0.jpg", ImageFormat.Jpeg);
} finally {
image.dispose();
}
} finally {
presentation.dispose();
}
Преобразование слайдов с примечаниями и комментариями в изображения
Некоторые слайды могут содержать примечания и комментарии.
Aspose.Slides предоставляет два интерфейса — ITiffOptions и IRenderingOptions — которые позволяют управлять рендерингом слайдов презентации в изображения. Оба интерфейса включают метод setSlidesLayoutOptions, позволяющий настроить рендеринг примечаний и комментариев на слайде при его преобразовании в изображение.
С помощью класса NotesCommentsLayoutingOptions вы можете указать предпочтительное расположение примечаний и комментариев в результирующем изображении.
Этот код демонстрирует, как преобразовать слайд с примечаниями и комментариями:
float scaleX = 2;
float scaleY = scaleX;
// Загрузить файл презентации.
Presentation presentation = new Presentation("Presentation_with_notes_and_comments.pptx");
try {
NotesCommentsLayoutingOptions notesCommentsOptions = new NotesCommentsLayoutingOptions();
notesCommentsOptions.setNotesPosition(NotesPositions.BottomTruncated); // Установить положение заметок.
notesCommentsOptions.setCommentsPosition(CommentsPositions.Right); // Установить положение комментариев.
notesCommentsOptions.setCommentsAreaWidth(500); // Установить ширину области комментариев.
notesCommentsOptions.setCommentsAreaColor(Color.LIGHT_GRAY); // Установить цвет области комментариев.
// Создать параметры рендеринга.
RenderingOptions options = new RenderingOptions();
options.setSlidesLayoutOptions(notesCommentsOptions);
// Преобразовать первый слайд презентации в изображение.
IImage image = presentation.getSlides().get_Item(0).getImage(options, scaleX, scaleY);
try {
// Сохранить изображение в формате GIF.
image.save("Image_with_notes_and_comments_0.gif", ImageFormat.Gif);
} finally {
image.dispose();
}
} finally {
presentation.dispose();
}
Note
В любом процессе преобразования слайдов в изображения метод setNotesPosition не может применитьBottomFull (для указания положения примечаний), поскольку текст примечания может быть слишком объёмным и не помещаться в указанном размере изображения.
Преобразование слайдов в изображения с помощью параметров TIFF
Интерфейс ITiffOptions предоставляет более тонкую настройку итогового TIFF‑изображения, позволяя задавать такие параметры, как размер, разрешение, цветовая палитра и т.д.
Этот код демонстрирует процесс конверсии, где параметры TIFF используются для вывода черно‑белого изображения с разрешением 300 DPI и размером 2160 × 2800:
// Загрузить файл презентации.
Presentation presentation = new Presentation("sample.pptx");
try {
// Получить первый слайд из презентации.
ISlide slide = presentation.getSlides().get_Item(0);
// Настроить параметры выводимого TIFF‑изображения.
TiffOptions tiffOptions = new TiffOptions();
tiffOptions.setImageSize(new Dimension(2160, 2880)); // Установить размер изображения.
tiffOptions.setPixelFormat(ImagePixelFormat.Format1bppIndexed); // Установить пиксельный формат (чёрно‑белый).
tiffOptions.setDpiX(300); // Установить горизонтальное разрешение.
tiffOptions.setDpiY(300); // Установить вертикальное разрешение.
// Преобразовать слайд в изображение с указанными параметрами.
IImage image = slide.getImage(tiffOptions);
try {
// Сохранить изображение в формате TIFF.
image.save("output.tiff", ImageFormat.Tiff);
} finally {
image.dispose();
}
} finally {
presentation.dispose();
}
Note
Поддержка TIFF не гарантируется в версиях JDK ниже 9.Преобразование всех слайдов в изображения
Aspose.Slides позволяет преобразовать все слайды презентации в изображения, фактически превращая всю презентацию в набор изображений.
Этот пример кода демонстрирует, как преобразовать все слайды презентации в изображения на Java:
float scaleX = 2;
float scaleY = scaleX;
Presentation presentation = new Presentation("Presentation.pptx");
try {
// Отрисовать презентацию в изображения слайд за слайдом.
for (int i = 0 ; i < presentation.getSlides().size(); i++)
{
// Управление скрытыми слайдами (не отрисовывать скрытые слайды).
if (presentation.getSlides().get_Item(i).getHidden())
continue;
// Преобразовать слайд в изображение.
IImage image = presentation.getSlides().get_Item(i).getImage(scaleX, scaleY);
try {
// Сохранить изображение в формате JPEG.
image.save("Slide_" + i + ".jpg", ImageFormat.Jpeg);
} finally {
image.dispose();
}
}
} finally {
presentation.dispose();
}
Часто задаваемые вопросы
Поддерживает ли Aspose.Slides отображение слайдов с анимацией?
Нет, метод getImage сохраняет только статическое изображение слайда без анимации.
Можно ли экспортировать скрытые слайды в виде изображений?
Да, скрытые слайды можно обрабатывать так же, как обычные. Просто убедитесь, что они включены в цикл обработки.
Можно ли сохранять изображения с тенями и эффектами?
Да, Aspose.Slides поддерживает рендеринг теней, прозрачности и других графических эффектов при сохранении слайдов как изображений.