Конвертировать PPT и PPTX в PDF в PHP [Включены расширенные функции]

Обзор

Преобразование презентаций PowerPoint (PPT, PPTX, ODP и др.) в формат PDF в PHP дает несколько преимуществ, включая совместимость с различными устройствами и сохранение макета и форматирования вашей презентации. В этом руководстве показано, как конвертировать презентации в PDF‑документы, использовать различные параметры для управления качеством изображений, включать скрытые слайды, защищать PDF паролем, обнаруживать замену шрифтов, выбирать отдельные слайды для конвертации и применять стандарты соответствия к выходным документам.

Конвертация PowerPoint в PDF

С помощью Aspose.Slides вы можете конвертировать презентации следующих форматов в PDF:

  • PPT
  • PPTX
  • ODP

Чтобы конвертировать презентацию в PDF, передайте имя файла в конструктор класса Presentation, а затем сохраните презентацию как PDF с помощью метода save. Класс Presentation предоставляет метод save, который обычно используется для преобразования презентации в PDF.

Aspose.Slides позволяет конвертировать:

  • Полные презентации в PDF
  • Определённые слайды из презентации в PDF

Aspose.Slides экспортирует презентации в PDF, обеспечивая максимально точное совпадение полученных PDF с исходными презентациями. При конвертации точно воспроизводятся элементы и атрибуты, включая:

  • Изображения
  • Текстовые поля и фигуры
  • Форматирование текста
  • Форматирование абзацев
  • Гиперссылки
  • Верхние и нижние колонтитулы
  • Маркеры
  • Таблицы

Конвертация PowerPoint в PDF

Стандартный процесс конвертации PowerPoint в PDF использует параметры по умолчанию. В этом случае Aspose.Slides пытается преобразовать указанную презентацию в PDF, используя оптимальные настройки с максимальным качеством.

Ниже показан код, который конвертирует презентацию (PPT, PPTX, ODP и др.) в PDF:

# Создайте экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("PowerPoint.pptx");
try {
    # Сохраните презентацию в PDF.
    $presentation->save("PPT-to-PDF.pdf", SaveFormat::Pdf);
} finally {
    $presentation->dispose();
}

Конвертация PowerPoint в PDF с параметрами

Aspose.Slides предоставляет пользовательские параметры — свойства класса PdfOptions, — которые позволяют настроить получаемый PDF, защитить его паролем или указать, как должен происходить процесс конвертации.

Конвертация PowerPoint в PDF с пользовательскими параметрами

С помощью пользовательских параметров конвертации вы можете задать предпочтительные настройки качества растровых изображений, указать, как обрабатывать метафайлы, установить уровень сжатия текста, задать DPI для изображений и многое другое.

Ниже пример кода, показывающий, как конвертировать презентацию PowerPoint в PDF с несколькими пользовательскими параметрами.

# Создать экземпляр класса PdfOptions.
$pdfOptions = new PdfOptions();

# Установить качество JPG‑изображений.
$pdfOptions->setJpegQuality(90);

# Установить DPI для изображений.
$pdfOptions->setSufficientResolution(300);

# Установить поведение для метафайлов.
$pdfOptions->setSaveMetafilesAsPng(true);

# Установить уровень сжатия текста для текстового содержимого.
$pdfOptions->setTextCompression(PdfTextCompression::Flate);

# Задать режим соответствия PDF.
$pdfOptions->setCompliance(PdfCompliance::Pdf15);

# Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("PowerPoint.pptx");
try {
    # Сохранить презентацию как PDF‑документ.
    $presentation->save("PowerPoint-to-PDF.pdf", SaveFormat::Pdf, $pdfOptions);
} finally {
    $presentation->dispose();
}

Конвертация PowerPoint в PDF с включением скрытых слайдов

Если в презентации есть скрытые слайды, вы можете использовать метод setShowHiddenSlides класса PdfOptions, чтобы включить скрытые слайды как страницы в результирующий PDF.

Этот код демонстрирует, как конвертировать презентацию PowerPoint в PDF с включёнными скрытыми слайдами:

# Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("PowerPoint.pptx");
try {
    # Создать экземпляр класса PdfOptions.
    $pdfOptions = new PdfOptions();

    # Добавить скрытые слайды.
    $pdfOptions->setShowHiddenSlides(true);

    # Сохранить презентацию как PDF.
    $presentation->save("PowerPoint-to-PDF.pdf", SaveFormat::Pdf, $pdfOptions);
} finally {
    $presentation->dispose();
}

Конвертация PowerPoint в защищённый паролем PDF

Этот пример показывает, как конвертировать презентацию PowerPoint в PDF, защищённый паролем, используя параметры защиты из класса PdfOptions:

# Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("PowerPoint.pptx");
try {
    # Создать экземпляр класса PdfOptions.
    $pdfOptions = new PdfOptions();

    # Установить пароль PDF и права доступа.
    $pdfOptions->setPassword("password");
    $pdfOptions->setAccessPermissions(PdfAccessPermissions::PrintDocument | PdfAccessPermissions::HighQualityPrint);

    # Сохранить презентацию как PDF.
    $presentation->save("PPTX-to-PDF.pdf", SaveFormat::Pdf, $pdfOptions);
} finally {
    $presentation->dispose();
}

Обнаружение замены шрифтов

Aspose.Slides предоставляет метод setWarningCallback в классе PdfOptions, позволяющий обнаружить замену шрифтов во время конвертации презентации в PDF.

Пример кода, показывающий, как обнаружить замену шрифтов:

class FontSubstitutionHandler {
    function warning($warning)
    {
        if (java_values($warning->getWarningType()) == WarningType::DataLoss &&
        $warning->getDescription()->startsWith("Font will be substituted")) {
            echo("Font substitution warning: " . $warning->getDescription());
        }

        return ReturnAction::Continue;
    }
}

// Установить обратный вызов предупреждения в параметрах PDF.
$pdfOptions = new PdfOptions();
$warningCallback = java_closure(new FontSubstitutionHandler(), null, java("com.aspose.slides.IWarningCallback"));
$pdfOptions->setWarningCallback($warningCallback);

// Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("sample.pptx");
try {
    // Сохранить презентацию как PDF.
    $presentation->save("output.pdf", SaveFormat::Pdf, $pdfOptions);
} finally {
    $presentation->dispose();
}

Конвертация выбранных слайдов PowerPoint в PDF

Этот пример демонстрирует, как конвертировать только определённые слайды презентации PowerPoint в PDF:

# Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("PowerPoint.pptx");
try {
    # Установить массив номеров слайдов.
    $slides = array(1, 3);

    # Сохранить презентацию как PDF.
    $presentation->save("PPTX-to-PDF.pdf", $slides, SaveFormat::Pdf);
} finally {
    $presentation->dispose();
}

Конвертация PowerPoint в PDF с пользовательским размером слайда

Этот пример демонстрирует, как конвертировать презентацию PowerPoint в PDF с указанным размером слайда:

$slideWidth = 612.0;
$slideHeight = 792.0;

# Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("SelectedSlides.pptx");

# Создать новую презентацию с изменённым размером слайда.
$resizedPresentation = new Presentation();

try {
    # Установить пользовательский размер слайда.
    $resizedPresentation->getSlideSize()->setSize($slideWidth, $slideHeight, SlideSizeScaleType::EnsureFit);

    # Клонировать первый слайд из исходной презентации.
    $slide = $presentation->getSlides()->get_Item(0);
    $resizedPresentation->getSlides()->insertClone(0, $slide);

    # Сохранить изменённую презентацию в PDF с примечаниями.
    $resizedPresentation->save("PDFnotes_out.pdf", SaveFormat::Pdf);
} finally {
    $resizedPresentation->dispose();
    $presentation->dispose();
}

Конвертация PowerPoint в PDF в режиме просмотра заметок

Этот пример демонстрирует, как конвертировать презентацию PowerPoint в PDF, включающий заметки:

# Создать экземпляр класса Presentation, представляющего файл PowerPoint или OpenDocument.
$presentation = new Presentation("SelectedSlides.pptx");
try {
    # Настроить параметры PDF с размещением заметок.
    $notesOptions = new NotesCommentsLayoutingOptions();
    $notesOptions->setNotesPosition(NotesPositions::BottomFull);
    $pdfOptions = new PdfOptions();
    $pdfOptions->setSlidesLayoutOptions($notesOptions);

    # Сохранить презентацию в PDF с заметками.
    $presentation->save("PDF_with_notes.pdf", SaveFormat::Pdf, $pdfOptions);
} finally {
    $presentation->dispose();
}

Доступность и стандарты соответствия для PDF

Aspose.Slides позволяет использовать процедуру конвертации, соответствующую Руководству по доступности веб‑контента (WCAG). Вы можете экспортировать документ PowerPoint в PDF, используя любой из следующих стандартов соответствия: PDF/A1a, PDF/A1b и PDF/UA.

Ниже показан процесс конвертации PowerPoint в PDF, создающий несколько PDF‑файлов в соответствии с разными стандартами соответствия:

$presentation = new Presentation("pres.pptx");
try {
    $pdfOptions = new PdfOptions();

    $pdfOptions->setCompliance(PdfCompliance::PdfA1a);
    $presentation->save("pres-a1a-compliance.pdf", SaveFormat::Pdf, $pdfOptions);

    $pdfOptions->setCompliance(PdfCompliance::PdfA1b);
    $presentation->save("pres-a1b-compliance.pdf", SaveFormat::Pdf, $pdfOptions);

    $pdfOptions->setCompliance(PdfCompliance::PdfUa);
    $presentation->save("pres-ua-compliance.pdf", SaveFormat::Pdf, $pdfOptions);
} finally {
    $presentation->dispose();
}

FAQ

Можно ли конвертировать несколько файлов PowerPoint в PDF пакетно?

Да, Aspose.Slides поддерживает пакетную конвертацию нескольких файлов PPT или PPTX в PDF. Вы можете пройтись по вашим файлам и программно выполнить процесс конвертации.

Можно ли защитить полученный PDF паролем?

Абсолютно. Используйте класс PdfOptions для установки пароля и определения прав доступа во время конвертации.

Как включить скрытые слайды в PDF?

Воспользуйтесь методом setShowHiddenSlides в классе PdfOptions, чтобы включить скрытые слайды в результирующий PDF.

Сможет ли Aspose.Slides сохранять высокое качество изображений в PDF?

Да, вы можете управлять качеством изображений, используя методы setJpegQuality и setSufficientResolution в классе PdfOptions для обеспечения высокого качества изображений в PDF.

Поддерживает ли Aspose.Slides стандарты соответствия PDF/A?

Да, Aspose.Slides позволяет экспортировать PDF, соответствующие различным стандартам, включая PDF/A1a, PDF/A1b и PDF/UA, гарантируя, что ваши документы отвечают требованиям доступности и архивирования.

Дополнительные ресурсы