Рабочее решение проблемы изменения размера диаграммы в PPTX
Общие сведения
Было замечено, что диаграммы Excel, встроенные как OLE‑объекты в презентацию PowerPoint через компоненты Aspose, после первого активации масштабируются до неопределённого размера. Это приводит к заметной визуальной разнице в презентации между состоянием диаграммы до и после активации. Команда Aspose подробно исследовала проблему и нашла решение. В этой статье описаны причины проблемы и соответствующее исправление.
В предыдущей статье мы объяснили, как создать диаграмму Excel с помощью Aspose.Cells for Java и встроить её в презентацию PowerPoint, используя Aspose.Slides for Java. Чтобы решить проблему предварительного просмотра объекта, мы присвоили изображение диаграммы OLE‑объекту кадра. В полученной презентации, когда вы дважды щёлкните по кадру OLE‑объекта, отображающему изображение диаграммы, диаграмма Excel активируется. Пользователи могут вносить любые изменения в исходную книгу Excel, а затем возвращаться к соответствующему слайду, щёлкнув за пределами активированной книги. Размер кадра OLE‑объекта изменяется при возврате к слайду, и коэффициент изменения размера зависит от исходных размеров как кадра OLE‑объекта, так и встроенной книги Excel.
Причина изменения размера
Так как у книги Excel собственный размер окна, при первой активации она пытается сохранить свой исходный размер. Кадр OLE‑объекта, однако, имеет свой размер. По данным Microsoft, когда книга Excel активируется, Excel и PowerPoint согласовывают размеры и поддерживают правильные пропорции в процессе внедрения. В зависимости от различий между размером окна Excel и размером или позицией кадра OLE‑объекта происходит изменение размера.
Рабочее решение
Существует два возможных сценария создания презентаций PowerPoint с помощью Aspose.Slides for Java.
Сценарий 1: Создание презентации на основе существующего шаблона.
Сценарий 2: Создание презентации с нуля.
Предлагаемое решение применимо к обоим сценариям. Основой всех подходов является одно и то же: размер окна встроенного OLE‑объекта должен совпадать с размером кадра OLE‑объекта в слайде PowerPoint. Далее рассмотрим два подхода к этому решению.
Первый подход
В этом подходе мы узнаем, как установить размер окна встроенной книги Excel так, чтобы он соответствовал размеру кадра OLE‑объекта в слайде PowerPoint.
Сценарий 1
Предположим, что у нас есть шаблон, и мы хотим создавать презентации на его основе. Допустим, в шаблоне существует форма с индексом 2, куда мы хотим поместить кадр OLE, содержащий встроенную книгу Excel. В этом случае размер кадра OLE‑объекта предопределён — он совпадает с размером формы с индексом 2 в шаблоне. Всё, что нам надо сделать, — установить размер окна книги равным размеру этой формы. Следующий фрагмент кода служит этой цели:
// Установите ширину окна рабочей книги в дюймах (делится на 576, так как PowerPoint использует 576 пикселей на дюйм).
workbook.getSettings().setWindowWidthInch(slide.getShapes().get_Item(2).getWidth() / 72f);
// Установите высоту окна рабочей книги в дюймах.
workbook.getSettings().setWindowHeightInch(slide.getShapes().get_Item(2).getHeight() / 72f);
// Сохраните рабочую книгу в поток памяти.
ByteArrayOutputStream workbookStream = new ByteArrayOutputStream();
workbook.save(workbookStream, com.aspose.cells.SaveFormat.EXCEL_97_TO_2003);
// Создайте кадр OLE‑объекта с встроенными данными Excel.
IOleObjectFrame oleFrame = slide.getShapes().addOleObjectFrame(
slide.getShapes().get_Item(2).getX(),
slide.getShapes().get_Item (2).getY(),
slide.getShapes().get_Item (2).getWidth(),
slide.getShapes().get_Item (2).getHeight(),
"Excel.Sheet.8",
workbookStream.toByteArray());
Сценарий 2
Предположим, что мы хотим создать презентацию с нуля и добавить кадр OLE‑объекта произвольного размера с встроенной книгой Excel. В следующем фрагменте кода мы создаём кадр OLE‑объекта высотой 4 дюйма и шириной 9,5 дюйма, расположенный в точке x = 0,5 дюйма и y = 1 дюйм на слайде. Затем мы задаём окну книги Excel тот же размер — 4 дюйма в высоту и 9,5 дюйма в ширину.
// Желаемая высота.
int desiredHeight = 288; // 4 дюйма (4 * 72)
// Желаемая ширина.
int desiredWidth = 684; // 9.5 дюйма (9.5 * 72)
// Задать размер диаграммы с окном.
chart.setSizeWithWindow(true);
// Установить ширину окна рабочей книги в дюймах (делится на 576, так как PowerPoint использует 576 пикселей на дюйм).
workbook.getSettings().setWindowWidthInch(desiredHeight / 72f);
// Установить высоту окна рабочей книги в дюймах.
workbook.getSettings().setWindowHeightInch(desiredWidth / 72f);
// Сохранить рабочую книгу в поток памяти.
ByteArrayOutputStream workbookStream = new ByteArrayOutputStream();
workbook.save(workbookStream, com.aspose.cells.SaveFormat.EXCEL_97_TO_2003);
// Создать кадр OLE‑объекта с встроенными данными Excel.
IOleObjectFrame oleFrame = slide.getShapes().addOleObjectFrame(
288,
576,
desiredWidth,
desiredHeight,
"Excel.Sheet.8",
workbookStream.toByteArray());
Второй подход
В этом подходе мы узнаем, как установить размер диаграммы во встроенной книге Excel так, чтобы он соответствовал размеру кадра OLE‑объекта в слайде PowerPoint. Этот подход полезен, когда размер диаграммы известен заранее и не будет изменяться.
Сценарий 1
Предположим, что у нас есть шаблон, и мы хотим создавать презентации на его основе. Допустим, в шаблоне существует форма с индексом 2, куда мы планируем поместить кадр OLE, содержащий встроенную книгу Excel. В этом случае размер кадра OLE‑объекта предопределён — совпадает с размером формы с индексом 2 в шаблоне. Всё, что нам нужно, — установить размер диаграммы в книге, равный размеру этой формы. Следующий фрагмент кода служит этой цели:
// Определить размер диаграммы без окна.
chart.setSizeWithWindow(false);
// Задать ширину диаграммы в пикселях (умножить на 96, так как Excel использует 96 пикселей на дюйм).
chart.getChartObject().setWidth((int)((slide.getShapes().get_Item(2).getWidth() / 72f) * 96f));
// Задать высоту диаграммы в пикселях.
chart.getChartObject().setHeight((int)((slide.getShapes().get_Item(2).getHeight() / 72f) * 96f));
// Определить размер печати диаграммы.
chart.setPrintSize(PrintSizeType.CUSTOM);
// Сохранить рабочую книгу в поток памяти.
ByteArrayOutputStream workbookStream = new ByteArrayOutputStream();
workbook.save(workbookStream, com.aspose.cells.SaveFormat.EXCEL_97_TO_2003);
// Создать кадр OLE‑объекта с вложенными данными Excel.
IOleObjectFrame oleFrame = slide.getShapes().addOleObjectFrame(
slide.getShapes().get_Item(2).getX(),
slide.getShapes().get_Item (2).getY(),
slide.getShapes().get_Item (2).getWidth(),
slide.getShapes().get_Item (2).getHeight(),
"Excel.Sheet.8",
workbookStream.toByteArray());
Сценарий 2
Предположим, что мы хотим создать презентацию с нуля и добавить кадр OLE‑объекта произвольного размера с встроенной книгой Excel. В следующем фрагменте кода мы создаём кадр OLE‑объекта высотой 4 дюйма и шириной 9,5 дюйма, расположенный в точке x = 0,5 дюйма и y = 1 дюйм на слайде. Мы также задаём размер диаграммы такие же параметры: высота = 4 дюйма, ширина = 9,5 дюйма.
// Желаемая высота.
int desiredHeight = 288; // 4 дюйма (4 * 72)
// Желаемая ширина.
int desiredWidth = 684; // 9.5 дюйма (9.5 * 72)
// Определить размер диаграммы без окна.
chart.setSizeWithWindow(false);
// Задать ширину диаграммы в пикселях (умножить на 96, так как Excel использует 96 пикселей на дюйм).
chart.getChartObject().setWidth((int)((slide.getShapes().get_Item(2).getWidth() / 576f) * 96f));
// Задать высоту диаграммы в пикселях.
chart.getChartObject().setHeight((int)((slide.getShapes().get_Item(2).getHeight() / 576f) * 96f));
// Сохранить рабочую книгу в поток памяти.
ByteArrayOutputStream workbookStream = new ByteArrayOutputStream();
workbook.save(workbookStream, com.aspose.cells.SaveFormat.EXCEL_97_TO_2003);
// Создать кадр OLE‑объекта с встроенными данными Excel.
IOleObjectFrame oleFrame = slide.getShapes().addOleObjectFrame(
288,
576,
desiredWidth,
desiredHeight,
"Excel.Sheet.8",
workbookStream.toByteArray());
Заключение
Существует два подхода к исправлению проблемы изменения размера диаграммы. Выбор подхода зависит от требований и сценария использования. Оба подхода работают одинаково, независимо от того, создаются ли презентации из шаблона или с нуля. Кроме того, в этом решении нет ограничения на размер кадра OLE‑объекта.
Часто задаваемые вопросы
Почему моя встроенная диаграмма Excel меняет размер после активации в PowerPoint?
Это происходит потому, что Excel пытается восстановить исходный размер окна при первой активации, тогда как кадр OLE‑объекта в PowerPoint имеет свои собственные размеры. PowerPoint и Excel согласовывают размеры, чтобы сохранить соотношение сторон, что может привести к изменению размера.
Можно ли полностью предотвратить эту проблему с изменением размера?
Да. Согласовав размер окна книги Excel или размер диаграммы с размером кадра OLE‑объекта перед внедрением, вы сохраняете постоянный размер диаграммы.
Какой подход выбрать: задавать размер окна книги или размер диаграммы?
Используйте Подход 1 (размер окна), если хотите сохранить соотношение сторон книги и, возможно, позже изменить размер. Используйте Подход 2 (размер диаграммы), если размеры диаграммы фиксированы и не будут изменяться после внедрения.
Будут ли эти методы работать как с шаблонными презентациями, так и с новыми презентациями?
Да. Оба подхода работают одинаково для презентаций, созданных из шаблонов, и для новых презентаций.
Есть ли ограничение на размер кадра OLE‑объекта?
Нет. Вы можете задать кадр OLE любого размера, пока он адекватно масштабируется к размеру книги или диаграммы.
Можно ли использовать эти методы с диаграммами, созданными в других табличных программах?
Примеры рассчитаны на диаграммы Excel, созданные с помощью Aspose.Cells, но принципы применимы к другим OLE‑совместимым табличным программам, если они поддерживают аналогичные параметры размеров.