Управление комментариями презентации в .NET

В PowerPoint комментарий отображается как заметка или аннотация на слайде. При щелчке по комментарию его содержимое или сообщения раскрываются.

Зачем добавлять комментарии к презентациям?

Вы можете использовать комментарии для предоставления обратной связи или общения с коллегами при просмотре презентаций.

Чтобы вы могли использовать комментарии в презентациях PowerPoint, Aspose.Slides для .NET предоставляет

  • Класс Presentation, который содержит коллекции авторов (из свойства CommentAuthorCollection). Авторы добавляют комментарии к слайдам.
  • Интерфейс ICommentCollection, который содержит коллекцию комментариев для отдельных авторов.
  • Класс IComment, который содержит информацию об авторах и их комментариях: кто добавил комментарий, время его добавления, позицию комментария и т.д.
  • Класс CommentAuthor, который содержит информацию об отдельных авторах: имя автора, его инициалы, комментарии, связанные с именем автора, и т.д.

Добавление комментариев к слайдам

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

// Создает экземпляр класса Presentation
using (Presentation presentation = new Presentation())
{
    // Добавляет пустой слайд
    presentation.Slides.AddEmptySlide(presentation.LayoutSlides[0]);

    // Добавляет автора
    ICommentAuthor author = presentation.CommentAuthors.AddAuthor("Jawad", "MF");

    // Устанавливает позицию для комментариев
    PointF point = new PointF();
    point.X = 0.2f;
    point.Y = 0.2f;

    // Добавляет комментарий к слайду для автора на слайде 1
    author.Comments.AddComment("Hello Jawad, this is slide comment", presentation.Slides[0], point, DateTime.Now);

    // Добавляет комментарий к слайду для автора на слайде 2
    author.Comments.AddComment("Hello Jawad, this is second slide comment", presentation.Slides[1], point, DateTime.Now);

    // Доступ к ISlide 1
    ISlide slide = presentation.Slides[0];

    // Когда в качестве аргумента передается null, комментарии от всех авторов добавляются к выбранному слайду
    IComment[] Comments = slide.GetSlideComments(author);

    // Доступ к комментарию с индексом 0 для слайда 1
    String str = Comments[0].Text;

    presentation.Save("Comments_out.pptx", SaveFormat.Pptx);

    if (Comments.GetLength(0) > 0)
    {
        // Выбирает коллекцию комментариев автора с индексом 0
        ICommentCollection commentCollection = Comments[0].Author.Comments;
        String Comment = commentCollection[0].Text;
    }
}

Получение комментариев со слайда

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

// Создает экземпляр класса Presentation
using (Presentation presentation = new Presentation("Comments1.pptx"))
{
    foreach (var commentAuthor in presentation.CommentAuthors)
    {
        var author = (CommentAuthor) commentAuthor;
        foreach (var comment1 in author.Comments)
        {
            var comment = (Comment) comment1;
            Console.WriteLine("ISlide :" + comment.Slide.SlideNumber + " has comment: " + comment.Text + " with Author: " + comment.Author.Name + " posted on time :" + comment.CreatedTime + "\n");
        }
    }
}

Ответы на комментарии

Родительский комментарий — это верхний или исходный комментарий в иерархии комментариев или ответов. С помощью свойства ParentComment (из интерфейса IComment) можно установить или получить родительский комментарий.

Этот код на C# показывает, как добавить комментарии и получить ответы на них:

using (Presentation pres = new Presentation())
{
    // Добавляет комментарий
    ICommentAuthor author1 = pres.CommentAuthors.AddAuthor("Author_1", "A.A.");
    IComment comment1 = author1.Comments.AddComment("comment1", pres.Slides[0], new PointF(10, 10), DateTime.Now);

    // Добавляет ответ к comment1
    ICommentAuthor author2 = pres.CommentAuthors.AddAuthor("Autror_2", "B.B.");
    IComment reply1 = author2.Comments.AddComment("reply 1 for comment 1", pres.Slides[0], new PointF(10, 10), DateTime.Now);
    reply1.ParentComment = comment1;

    // Добавляет ещё один ответ к comment1
    IComment reply2 = author2.Comments.AddComment("reply 2 for comment 1", pres.Slides[0], new PointF(10, 10), DateTime.Now);
    reply2.ParentComment = comment1;

    // Добавляет ответ к существующему ответу
    IComment subReply = author1.Comments.AddComment("subreply 3 for reply 2", pres.Slides[0], new PointF(10, 10), DateTime.Now);
    subReply.ParentComment = reply2;

    IComment comment2 = author2.Comments.AddComment("comment 2", pres.Slides[0], new PointF(10, 10), DateTime.Now);
    IComment comment3 = author2.Comments.AddComment("comment 3", pres.Slides[0], new PointF(10, 10), DateTime.Now);

    IComment reply3 = author1.Comments.AddComment("reply 4 for comment 3", pres.Slides[0], new PointF(10, 10), DateTime.Now);
    reply3.ParentComment = comment3;

    // Выводит иерархию комментариев в консоль
    ISlide slide = pres.Slides[0];
    var comments = slide.GetSlideComments(null);
    for (int i = 0; i < comments.Length; i++)
    {
        IComment comment = comments[i];
        while (comment.ParentComment != null)
        {
            Console.Write("\t");
            comment = comment.ParentComment;
        }

        Console.Write("{0} : {1}", comments[i].Author.Name, comments[i].Text);
        Console.WriteLine();
    }

    pres.Save("parent_comment.pptx",SaveFormat.Pptx);

    // Удаляет comment1 и все ответы к нему
    comment1.Remove();

    pres.Save("remove_comment.pptx", SaveFormat.Pptx);
}

Добавление современных комментариев

В 2021 году Microsoft внедрила современные комментарии в PowerPoint. Функция современных комментариев существенно улучшает совместную работу в PowerPoint. С помощью современных комментариев пользователи PowerPoint могут разрешать комментарии, привязывать их к объектам и тексту, а также взаимодействовать гораздо проще, чем раньше.

В Aspose Slides for .NET 21.11, мы реализовали поддержку современных комментариев, добавив класс ModernComment. В класс CommentCollection были добавлены методы AddModernComment и InsertModernComment.

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

using (Presentation pres = new Presentation())
{
     ICommentAuthor newAuthor = pres.CommentAuthors.AddAuthor("Some Author", "SA");
     IModernComment modernComment = newAuthor.Comments.AddModernComment("This is a modern comment", pres.Slides[0], null, new PointF(100, 100), DateTime.Now);
 
     pres.Save("pres.pptx", SaveFormat.Pptx);
}

Удаление комментариев

Удалить все комментарии и авторов

Этот код на C# показывает, как удалить все комментарии и авторов в презентации:

using (var presentation = new Presentation("example.pptx"))
{
    // Удаляет все комментарии из презентации
    foreach (var author in presentation.CommentAuthors)
    {
        author.Comments.Clear();
    }

    // Удаляет всех авторов
    presentation.CommentAuthors.Clear();

    presentation.Save("example_out.pptx", SaveFormat.Pptx);
}

Удалить отдельные комментарии

Этот код на C# показывает, как удалить конкретные комментарии на слайде:

using (var presentation = new Presentation())
{
    ISlide slide = presentation.Slides[0];
    
    // добавить комментарии...
    ICommentAuthor author = presentation.CommentAuthors.AddAuthor("Author", "A");
    author.Comments.AddComment("comment 1", slide, new PointF(0.2f, 0.2f), DateTime.Now);
    author.Comments.AddComment("comment 2", slide, new PointF(0.3f, 0.2f), DateTime.Now);
    
    // удалить все комментарии, содержащие текст "comment 1"
    foreach (ICommentAuthor commentAuthor in presentation.CommentAuthors)
    {
        List<IComment> toRemove = new List<IComment>();
        foreach (IComment comment in slide.GetSlideComments(commentAuthor))
        {
            if (comment.Text == "comment 1")
            {
                toRemove.Add(comment);
            }
        }
        
        foreach (IComment comment in toRemove)
        {
            commentAuthor.Comments.Remove(comment);
        }
    }
    
    presentation.Save("pres.pptx", SaveFormat.Pptx);
}

FAQ

Поддерживает ли Aspose.Slides статус, например «resolved», для современных комментариев?

Да. Современные комментарии предоставляют свойство Status; вы можете читать и задавать состояние комментария (например, пометить его как «resolved»), и это состояние сохраняется в файле и распознаётся PowerPoint.

Поддерживаются ли цепочки обсуждений (ответов) и существует ли ограничение вложенности?

Да. Каждый комментарий может ссылаться на свой родительский комментарий, что позволяет создавать произвольные цепочки ответов. API не задаёт конкретного ограничения глубины вложенности.

В какой системе координат определяется позиция маркера комментария на слайде?

Позиция хранится как точка с плавающей запятой в системе координат слайда. Это позволяет разместить маркер комментария точно в нужном месте.