Як додати форми до PowerPoint у Java
Aspose.Slides FOSS for Java підтримує додавання AutoShapes, Tables, Connectors та PictureFrames до слайдів презентації. Усі типи фігур додаються через колекцію slide.getShapes().
Покроковий посібник
Крок 1: Додайте залежність Maven
<dependency>
<groupId>org.aspose.slides.foss</groupId>
<artifactId>aspose-slides-foss</artifactId>
<version>1.0.0</version>
</dependency>Крок 2: Створити презентацію
Завжди використовуйте try-with-resources для керування ресурсами.
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.IConnector;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.IPPImage;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
ISlide slide = prs.getSlides().get(0);
// ... add shapes ...
prs.save("output.pptx", SaveFormat.PPTX);
}Крок 3: Додати AutoShape
slide.getShapes().addAutoShape(shapeType, x, y, width, height) розміщує форму у заданій позиції та розмірі (всі у пунктах). Використовуйте константи ShapeType для вибору форми.
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.IConnector;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.IPPImage;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
ISlide slide = prs.getSlides().get(0);
// Rectangle
IAutoShape rect = slide.getShapes().addAutoShape(
ShapeType.RECTANGLE, 50, 50, 300, 100
);
rect.addTextFrame("Rectangle shape");
// Ellipse
IAutoShape ellipse = slide.getShapes().addAutoShape(
ShapeType.ELLIPSE, 400, 50, 200, 100
);
ellipse.addTextFrame("Ellipse shape");
prs.save("autoshapes.pptx", SaveFormat.PPTX);
}Крок 4: Додати таблицю
slide.getShapes().addTable(x, y, colWidths, rowHeights) створює таблицю у вказаній позиції. Ширини стовпців та висоти рядків є масивами значень у пунктах.
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.IConnector;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.IPPImage;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
ISlide slide = prs.getSlides().get(0);
double[] colWidths = {150.0, 150.0, 150.0};
double[] rowHeights = {40.0, 40.0, 40.0};
ITable table = slide.getShapes().addTable(50, 200, colWidths, rowHeights);
// Set header row text
String[] headers = {"Product", "Units", "Revenue"};
for (int col = 0; col < headers.length; col++) {
table.getRows().get(0).get(col).getTextFrame().setText(headers[col]);
}
// Set data rows
String[][] rows = {
{"Widget A", "120", "$2,400"},
{"Widget B", "85", "$1,700"},
};
for (int row = 0; row < rows.length; row++) {
for (int col = 0; col < rows[row].length; col++) {
table.getRows().get(row + 1).get(col)
.getTextFrame().setText(rows[row][col]);
}
}
prs.save("table.pptx", SaveFormat.PPTX);
}Крок 5: Додати з’єднувач
З’єднувачі візуально з’єднують дві форми. Спочатку створіть форми, потім додайте з’єднувач і встановіть його початкову та кінцеву точки підключення.
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.IConnector;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.IPPImage;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
try (Presentation prs = new Presentation()) {
ISlide slide = prs.getSlides().get(0);
IAutoShape box1 = slide.getShapes().addAutoShape(
ShapeType.RECTANGLE, 50, 100, 150, 60
);
box1.addTextFrame("Start");
IAutoShape box2 = slide.getShapes().addAutoShape(
ShapeType.RECTANGLE, 350, 100, 150, 60
);
box2.addTextFrame("End");
IConnector conn = slide.getShapes().addConnector(
ShapeType.BENT_CONNECTOR3, 0, 0, 10, 10
);
conn.setStartShapeConnectedTo(box1);
conn.setStartShapeConnectionSiteIndex(3); // right side of box1
conn.setEndShapeConnectedTo(box2);
conn.setEndShapeConnectionSiteIndex(1); // left side of box2
prs.save("connector.pptx", SaveFormat.PPTX);
}Індекси точок підключення нумеруються від 0 до 3 для прямокутника: верх=0, ліво=1, низ=2, право=3.
Крок 6: Додати рамку для зображення
Вставте зображення та додайте його до слайду як PictureFrame. Спочатку прочитайте байти зображення, додайте їх до колекції зображень презентації, потім створіть кадр.
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.IConnector;
import org.aspose.slides.foss.ITable;
import org.aspose.slides.foss.IPPImage;
import org.aspose.slides.foss.ILayoutSlide;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;
import java.nio.file.Files;
import java.nio.file.Paths;
try (Presentation prs = new Presentation()) {
byte[] imageData = Files.readAllBytes(Paths.get("logo.png"));
IPPImage image = prs.getImages().addImage(imageData);
ISlide slide = prs.getSlides().get(0);
slide.getShapes().addPictureFrame(
ShapeType.RECTANGLE, // bounding shape type
50, 50, // x, y in points
200, 150, // width, height in points
image
);
prs.save("with-image.pptx", SaveFormat.PPTX);
}Поширені проблеми та виправлення
Форма з’являється за межами видимої області слайду
Слайди за замовчуванням мають розмір 720 × 540 пунктів. Значення x або y, що виходять за ці межі, розташовують форму поза слайдом. Залиште x < 720 і y < 540, і забезпечте x + width <= 720 і y + height <= 540.
NullPointerException при читанні тексту форми
addAutoShape() повертає об’єкт форми безпосередньо. Якщо ви бачите null, перевірте, що ви не відкидаєте повернене значення. Також переконайтеся, що getTextFrame() не є null перед читанням тексту.
Текст клітинки таблиці порожній після присвоєння
Правильний метод — .getTextFrame().setText(value). Отримуйте доступ до клітинок як table.getRows().get(rowIndex).get(colIndex).getTextFrame().setText("value").
Часті запитання
Скільки фігур я можу додати до слайду?
Немає обмеження, накладеного бібліотекою. Практичні обмеження залежать від розміру файлу та можливостей рендерингу вашого цільового переглядача PPTX.
Чи можу я змінити позицію форми після її додавання?
Так. Об’єкт форми, який повертається addAutoShape(), має властивості позиції та розміру через getShapeFrame().
Чи підтримуються діаграми?
Ні. Діаграми, SmartArt та OLE‑об’єкти не реалізовані в цьому випуску та викликають UnsupportedOperationException.