Получить границы абзаца из презентаций в PHP

Получить координаты абзаца и части в TextFrame

С помощью Aspose.Slides for PHP via Java разработчики теперь могут получить прямоугольные координаты Paragraph внутри коллекции абзацев TextFrame. Это также позволяет получить координаты части внутри коллекции частей абзаца. В этой статье мы покажем на примере, как получить прямоугольные координаты абзаца вместе с позицией части внутри абзаца.

  $shape = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);
  $textFrame = $shape->getTextFrame();
  foreach($textFrame->getParagraphs() as $paragraph) {
    foreach($paragraph->getPortions() as $portion) {
      $point = $portion->getCoordinates();
    }
  }

Получить прямоугольные координаты абзаца

С помощью метода getRect() разработчики могут получить прямоугольник ограничений абзаца.

  $pres = new Presentation("HelloWorld.pptx");
  try {
    $shape = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);
    $textFrame = $shape->getTextFrame();
    $rect = $textFrame->getParagraphs()->get_Item(0)->getRect();
    echo("X: " . $rect->$x . " Y: " . $rect->$y . " Width: " . $rect->$width . " Height: " . $rect->$height);
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

Получить размер абзаца и части внутри TextFrame ячейки таблицы

Чтобы получить размер и координаты Portion или Paragraph в TextFrame ячейки таблицы, можно использовать методы Portion::getRect и Paragraph::getRect. Этот пример кода демонстрирует описанную операцию:

  $pres = new Presentation("source.pptx");
  try {
    $tbl = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);
    $cell = $tbl->getRows()->get_Item(1)->get_Item(1);
    $x = $tbl->getX() + $tbl->getRows()->get_Item(1)->get_Item(1)->getOffsetX();
    $y = $tbl->getY() + $tbl->getRows()->get_Item(1)->get_Item(1)->getOffsetY();
    foreach($cell->getTextFrame()->getParagraphs() as $para) {
      if ($para->getText()->equals("")) {
        continue;
      }
      $rect = $para->getRect();
      $shape = $pres->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, $rect->getX() + $x, $rect->getY() + $y, $rect->getWidth(), $rect->getHeight());
      $shape->getFillFormat()->setFillType(FillType::NoFill);
      $shape->getLineFormat()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->YELLOW);
      $shape->getLineFormat()->getFillFormat()->setFillType(FillType::Solid);
      foreach($para->getPortions() as $portion) {
        if ($portion->getText()->contains("0")) {
          $rect = $portion->getRect();
          $shape = $pres->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, $rect->getX() + $x, $rect->getY() + $y, $rect->getWidth(), $rect->getHeight());
          $shape->getFillFormat()->setFillType(FillType::NoFill);
        }
      }
    }
  } finally {
    if (!java_is_null($pres)) {
      $pres->dispose();
    }
  }

FAQ

В каких единицах измеряются координаты, возвращаемые для абзаца и текстовых частей?
В пунктах, где 1 дюйм = 72 пункта. Это относится ко всем координатам и размерам на слайде.

Влияет ли перенос слов на границы абзаца?
Да. Если wrapping включен в TextFrame, текст переносится, чтобы вписаться в ширину области, что изменяет фактические границы абзаца.

Можно ли надежно преобразовать координаты абзаца в пиксели в экспортированном изображении?
Да. Преобразуйте пункты в пиксели с помощью формулы: pixels = points × (DPI / 72). Результат зависит от выбранного DPI для рендеринга/экспорта.

Как получить «эффективные» параметры форматирования абзаца с учётом наследования стилей?
Используйте effective paragraph formatting data structure; он возвращает окончательные согласованные значения отступов, интервалов, переноса, RTL и прочего.