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

Текст на слайдах обычно находится в текстовых полях или фигурах. Поэтому, чтобы добавить текст на слайд, сначала нужно добавить текстовое поле, а затем поместить текст внутрь этого поля.

Чтобы добавить форму, способную содержать текст, Aspose.Slides для .NET предоставляет интерфейс IAutoShape .

Создание текстового поля на слайде

  1. Создайте экземпляр класса Presentation .
  2. Получите ссылку на первый слайд по его индексу.
  3. Добавьте объект IAutoShape с параметром ShapeType , установленным в Rectangle , в указанную позицию на слайде и получите ссылку на только что добавленный объект IAutoShape .
  4. Добавьте свойство TextFrame к объекту IAutoShape, которое будет содержать текст. В приведённом ниже примере мы добавили такой текст: Aspose TextBox
  5. Наконец, запишите файл PPTX через объект Presentation .

Этот код C# — реализация вышеописанных шагов — показывает, как добавить текст на слайд:

    // Создаёт экземпляр PresentationEx
    using (Presentation pres = new Presentation())
    {
        // Получает первый слайд в презентации
        ISlide sld = pres.Slides[0];

        // Добавляет AutoShape с типом Rectangle
        IAutoShape ashp = sld.Shapes.AddAutoShape(ShapeType.Rectangle, 150, 75, 150, 50);

        // Добавляет TextFrame к прямоугольнику
        ashp.AddTextFrame(" ");

        // Получает доступ к текстовому фрейму
        ITextFrame txtFrame = ashp.TextFrame;

        // Создаёт объект Paragraph для текстового фрейма
        IParagraph para = txtFrame.Paragraphs[0];

        // Создаёт объект Portion для абзаца
        IPortion portion = para.Portions[0];

        // Устанавливает текст
        portion.Text = "Aspose TextBox";

        // Сохраняет презентацию на диск
        pres.Save("TextBox_out.pptx", Aspose.Slides.Export.SaveFormat.Pptx);
    }

Проверка наличия формы текстового поля

Aspose.Slides предоставляет свойство IsTextBox интерфейса IAutoShape , позволяющее проверять фигуры и определять текстовые поля.

Текстовое поле и фигура

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

using (Presentation presentation = new Presentation("sample.pptx"))
{
    Aspose.Slides.LowCode.ForEach.Shape(presentation, (shape, slide, index) =>
    {
        if (shape is IAutoShape autoShape)
        {
            Console.WriteLine(autoShape.IsTextBox ? "shape is a text box" : "shape is not a text box");
        }
    });
}

Обратите внимание, что если вы просто добавите автографику с помощью метода AddAutoShape интерфейса IShapeCollection , свойство IsTextBox автографики вернёт false. Однако после добавления текста в автографику через метод AddTextFrame или свойство Text, свойство IsTextBox вернёт true.

using (Presentation presentation = new Presentation())
{
    ISlide slide = presentation.Slides[0];

    IAutoShape shape1 = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 10, 10, 100, 40);
    // shape1.IsTextBox равно false
    shape1.AddTextFrame("shape 1");
    // shape1.IsTextBox равно true

    IAutoShape shape2 = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 10, 110, 100, 40);
    // shape2.IsTextBox равно false
    shape2.TextFrame.Text = "shape 2";
    // shape2.IsTextBox равно true

    IAutoShape shape3 = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 10, 210, 100, 40);
    // shape3.IsTextBox равно false
    shape3.AddTextFrame("");
    // shape3.IsTextBox равно false

    IAutoShape shape4 = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 10, 310, 100, 40);
    // shape4.IsTextBox равно false
    shape4.TextFrame.Text = "";
    // shape4.IsTextBox равно false
}

Добавление столбцов в текстовое поле

Aspose.Slides предоставляет свойства ColumnCount и ColumnSpacing (из интерфейса ITextFrameFormat и класса TextFrameFormat) , позволяющие добавлять столбцы в текстовые поля. Вы можете указать количество столбцов в текстовом поле и задать расстояние в пунктах между столбцами.

Этот код на C# демонстрирует описанную операцию:

using (Presentation presentation = new Presentation())
{
	// Получает первый слайд в презентации
	ISlide slide = presentation.Slides[0];

	// Добавляет AutoShape с типом Rectangle
	IAutoShape aShape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 100, 100, 300, 300);

	// Добавляет TextFrame к прямоугольнику
	aShape.AddTextFrame("All these columns are limited to be within a single text container -- " +
	"you can add or delete text and the new or remaining text automatically adjusts " +
	"itself to flow within the container. You cannot have text flow from one container " +
	"to other though -- we told you PowerPoint's column options for text are limited!");

	// Получает формат текста TextFrame
	ITextFrameFormat format = aShape.TextFrame.TextFrameFormat;

	// Задает количество колонок в TextFrame
	format.ColumnCount = 3;

	// Задает расстояние между колонками
	format.ColumnSpacing = 10;

	// Сохраняет презентацию
	presentation.Save("ColumnCount.pptx", SaveFormat.Pptx);
}

Добавление столбцов в текстовый фрейм

Aspose.Slides для .NET предоставляет свойство ColumnCount , из интерфейса [ITextFrameFormat] , которое позволяет добавлять столбцы в текстовые фреймы. С помощью этого свойства можно задать желаемое количество столбцов в текстовом фрейме.

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

string outPptxFileName = "ColumnsTest.pptx";
using (Presentation pres = new Presentation())
{
    IAutoShape shape1 = pres.Slides[0].Shapes.AddAutoShape(ShapeType.Rectangle, 100, 100, 300, 300);
    TextFrameFormat format = (TextFrameFormat)shape1.TextFrame.TextFrameFormat;

    format.ColumnCount = 2;
    shape1.TextFrame.Text = "All these columns are forced to stay within a single text container -- " +
                                "you can add or delete text - and the new or remaining text automatically adjusts " +
                                "itself to stay within the container. You cannot have text spill over from one container " +
                                "to other, though -- because PowerPoint's column options for text are limited!";
    pres.Save(outPptxFileName, SaveFormat.Pptx);

    using (Presentation test = new Presentation(outPptxFileName))
    {
        Debug.Assert(2 == ((AutoShape)test.Slides[0].Shapes[0]).TextFrame.TextFrameFormat.ColumnCount);
        Debug.Assert(double.NaN == ((AutoShape)test.Slides[0].Shapes[0]).TextFrame.TextFrameFormat.ColumnSpacing);
    }

    format.ColumnSpacing = 20;
    pres.Save(outPptxFileName, SaveFormat.Pptx);

    using (Presentation test = new Presentation(outPptxFileName))
    {
        Debug.Assert(2 == ((AutoShape)test.Slides[0].Shapes[0]).TextFrame.TextFrameFormat.ColumnCount);
        Debug.Assert(20 == ((AutoShape)test.Slides[0].Shapes[0]).TextFrame.TextFrameFormat.ColumnSpacing);
    }

    format.ColumnCount = 3;
    format.ColumnSpacing = 15;
    pres.Save(outPptxFileName, SaveFormat.Pptx);

    using (Presentation test = new Presentation(outPptxFileName))
    {
        Debug.Assert(3 == ((AutoShape)test.Slides[0].Shapes[0]).TextFrame.TextFrameFormat.ColumnCount);
        Debug.Assert(15 == ((AutoShape)test.Slides[0].Shapes[0]).TextFrame.TextFrameFormat.ColumnSpacing);
    }
}

Обновление текста

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

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

using(Presentation pres = new Presentation("text.pptx"))
{
   foreach (ISlide slide in pres.Slides)
   {
       foreach (IShape shape in slide.Shapes)
       {
           if (shape is IAutoShape autoShape) //Проверяет, поддерживает ли фигура текстовый фрейм (IAutoShape). 
           {
              foreach (IParagraph paragraph in autoShape.TextFrame.Paragraphs) //Итерирует абзацы в текстовом фрейме
               {
                   foreach (IPortion portion in paragraph.Portions) //Итерирует каждую часть в абзаце
                   {
                       portion.Text = portion.Text.Replace("years", "months"); //Изменяет текст
                       portion.PortionFormat.FontBold = NullableBool.True; //Изменяет форматирование
                   }
               }
           }
       }
   }
  
   //Сохраняет изменённую презентацию
   pres.Save("text-changed.pptx", SaveFormat.Pptx);
}

Добавление текстового поля с гиперссылкой

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

  1. Создайте экземпляр класса Presentation .
  2. Получите ссылку на первый слайд по его индексу.
  3. Добавьте объект AutoShape с ShapeType, установленным в Rectangle , в указанную позицию на слайде и получите ссылку на только что добавленный объект AutoShape .
  4. Добавьте TextFrame к объекту AutoShape, содержащий Aspose TextBox в качестве текста по умолчанию.
  5. Создайте экземпляр класса IHyperlinkManager .
  6. Назначьте объект IHyperlinkManager свойству HyperlinkClick , связанному с выбранной частью TextFrame .
  7. Наконец, запишите файл PPTX через объект Presentation .

Этот код C# — реализация вышеописанных шагов — показывает, как добавить текстовое поле с гиперссылкой на слайд:

// Создаёт экземпляр класса Presentation, представляющего PPTX
Presentation pptxPresentation = new Presentation();

// Получает первый слайд в презентации
ISlide slide = pptxPresentation.Slides[0];

// Добавляет объект AutoShape с типом Rectangle
IShape pptxShape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 150, 150, 150, 50);

// Приводит форму к AutoShape
IAutoShape pptxAutoShape = (IAutoShape)pptxShape;

// Получает свойство ITextFrame, связанное с AutoShape
pptxAutoShape.AddTextFrame("");

ITextFrame ITextFrame = pptxAutoShape.TextFrame;

// Добавляет текст в фрейм
ITextFrame.Paragraphs[0].Portions[0].Text = "Aspose.Slides";

// Устанавливает гиперссылку для текста части
IHyperlinkManager HypMan = ITextFrame.Paragraphs[0].Portions[0].PortionFormat.HyperlinkManager;
HypMan.SetExternalHyperlinkClick("http://www.aspose.com");

// Сохраняет PPTX-презентацию
pptxPresentation.Save("hLinkPPTX_out.pptx", Aspose.Slides.Export.SaveFormat.Pptx);

FAQ

В чём разница между текстовым полем и текстовым заполнителем при работе с главными слайдами?

Заполнитель (placeholder) наследует стиль/позицию от главного шаблона и может быть переопределён на макетах, тогда как обычное текстовое поле является самостоятельным объектом на конкретном слайде и не меняется при переключении макетов.

Как выполнить массовую замену текста во всей презентации, не затрагивая текст в диаграммах, таблицах и SmartArt?

Ограничьте перебор автографикой, имеющей текстовые фреймы, и исключите вложенные объекты (диаграммы, таблицы, SmartArt) , проходя их коллекции отдельно или пропуская такие типы объектов.