Введение
Aspose.Slides FOSS for .NET is now available on NuGet: a free, MIT-licensed library for creating, reading, and editing PowerPoint .pptx файлы полностью на C#, без зависимости от Microsoft Office или какого-либо проприетарного runtime.
Библиотека предназначена для разработчиков, которым необходимо программно генерировать или манипулировать файлами презентаций: автоматизировать наборы слайдов из данных, извлекать текст и метаданные из загруженных файлов PPTX, создавать конвейеры отчетности на основе презентаций или встраивать создание презентаций в приложения ASP.NET. Потому что Aspose.Slides.Foss требует .NET 9.0 или новее, он развертывается одинаково на Windows, macOS, Linux и в Docker‑контейнерах.
Ключевые возможности
- Полная поддержка полного цикла PPTX: Откройте любой
.pptxфайл, измените его содержимое и сохраните обратно, не теряя неизвестные XML‑части, которые библиотека пока не понимает. - Управление слайдами: Добавляйте, удаляйте и перебирайте слайды с помощью
prs.Slides; презентация начинается с одного пустого слайда послеnew Presentation(). - AutoShapes, таблицы и соединители: Вставить фигуры через
slide.Shapes.AddAutoShape(), табличные данные черезslide.Shapes.AddTable(), и визуальные соединители между фигурами черезslide.Shapes.AddConnector(). - Форматирование Rich Text: Форматировать текст на уровне символов с помощью
PortionFormat: размер шрифта, полужирный, курсив, подчеркивание и цвет ARGB черезFillType.SolidиColorFormat. - Типы заливки: Применить
FillType.Solid,Gradient,Pattern, илиPictureзаполняет любую форму. - Визуальные эффекты: Внешняя тень, свечение, мягкий край, размытие, отражение и внутренняя тень через
shape.EffectFormat. - 3D formatting: Фаска, камера, световая установка, материал и глубина выдавливания через
shape.ThreeDFormat. - Заметки докладчика: Прикрепить текст заметок к каждому слайду через
NotesSlideManager.AddNotesSlide(). - Ветвящиеся комментарии: Добавлять комментарии с метаданными автора и позицией слайда.
- Встроенные изображения: Встраивать из пути к файлу, байтов или
Stream. - Свойства документа: Читать и записывать основные, свойства приложения и пользовательские свойства.
Начало работы
Установите через NuGet. Требуется .NET 9.0 или новее.
dotnet add package Aspose.Slides.Foss
Создайте свою первую презентацию с фигурой и сохраните её:
using Aspose.Slides.Foss;
using var prs = new Presentation();
var slide = prs.Slides[0];
var shape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 50, 50, 400, 120);
shape.AddTextFrame("Hello from Aspose.Slides FOSS!");
prs.Save("hello.pptx", SaveFormat.Pptx);
Всегда используйте Presentation внутри using блока; это гарантирует, что все внутренние ресурсы будут освобождены при выходе из блока.
Пример форматирования текста
using Aspose.Slides.Foss;
using var prs = new Presentation();
var shape = prs.Slides[0].Shapes.AddAutoShape(ShapeType.Rectangle, 50, 50, 500, 150);
var tf = shape.AddTextFrame("Bold heading in corporate blue");
var fmt = tf.Paragraphs[0].Portions[0].PortionFormat;
fmt.FontHeight = 28;
fmt.FontBold = NullableBool.True;
fmt.FillFormat.FillType = FillType.Solid;
fmt.FillFormat.SolidFillColor.Color = Color.FromArgb(255, 0, 70, 127);
prs.Save("formatted.pptx", SaveFormat.Pptx);
Текущие ограничения
Следующие области вызывают NotImplementedException в этом выпуске:
- Диаграммы, SmartArt и OLE‑объекты
- Анимации и переходы слайдов
- Экспорт в PDF, HTML, SVG или форматы изображений
- Гиперссылки, настройки действий, макросы VBA и цифровые подписи
Неизвестные XML‑части, обнаруженные при загрузке, сохраняются дословно при сохранении, поэтому PPTX‑файлы, созданные другими инструментами, безопасно проходят цикл загрузки‑сохранения.