Управление строками и столбцами в таблицах PowerPoint на Android
Чтобы вы могли управлять строками и столбцами таблицы в презентации PowerPoint, Aspose.Slides предоставляет класс Table , интерфейс ITable , а также многие другие типы.
Установить первую строку как заголовок
- Создайте экземпляр класса Presentation и загрузите презентацию.
- Получите ссылку на слайд по его индексу.
- Создайте объект ITable , установив его в null.
- Пройдите по всем объектам IShape , чтобы найти нужную таблицу.
- Установите первую строку таблицы как её заголовок.
// Создает экземпляр класса Presentation
Presentation pres = new Presentation("table.pptx");
try {
// Получает первый слайд
ISlide sld = pres.getSlides().get_Item(0);
// Инициализирует переменную TableEx со значением null
ITable tbl = null;
// Итерируется по фигурам и устанавливает ссылку на таблицу
for (IShape shp : sld.getShapes())
{
if (shp instanceof ITable)
{
tbl = (ITable)shp;
// Устанавливает первую строку таблицы как заголовок
tbl.setFirstRow(true);
}
}
// Сохраняет презентацию на диск
pres.save("pres.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Клонировать строку или столбец таблицы
- Создайте экземпляр класса Presentation , загрузите презентацию,
- Получите ссылку на слайд по его индексу.
- Определите массив
columnWidth. - Определите массив
rowHeight. - Добавьте объект ITable на слайд с помощью метода addTable .
- Клонируйте строку таблицы.
- Клонируйте столбец таблицы.
- Сохраните изменённую презентацию.
// Создает экземпляр класса Presentation
Presentation pres = new Presentation("Test.pptx");
try {
// Получает первый слайд
ISlide sld = pres.getSlides().get_Item(0);
// Определяет столбцы с ширинами и строки с высотами
double[] dblCols = { 50, 50, 50 };
double[] dblRows = { 50, 30, 30, 30, 30 };
// Добавляет форму таблицы на слайд
ITable table = sld.getShapes().addTable(100, 50, dblCols, dblRows);
// Добавляет текст в ячейку строки 1, столбца 1
table.get_Item(0, 0).getTextFrame().setText("Row 1 Cell 1");
// Добавляет текст в ячейку строки 1, столбца 2
table.get_Item(1, 0).getTextFrame().setText("Row 1 Cell 2");
// Клонирует строку 1 в конец таблицы
table.getRows().addClone(table.getRows().get_Item(0), false);
// Добавляет текст в ячейку строки 2, столбца 1
table.get_Item(0, 1).getTextFrame().setText("Row 2 Cell 1");
// Добавляет текст в ячейку строки 2, столбца 2
table.get_Item(1, 1).getTextFrame().setText("Row 2 Cell 2");
// Клонирует строку 2 как 4‑ю строку таблицы
table.getRows().insertClone(3, table.getRows().get_Item(1), false);
// Клонирует первый столбец в конец
table.getColumns().addClone(table.getColumns().get_Item(0), false);
// Клонирует второй столбец в позицию 4‑го столбца
table.getColumns().insertClone(3,table.getColumns().get_Item(1), false);
// Сохраняет презентацию на диск
pres.save("table_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Удалить строку или столбец из таблицы
- Создайте экземпляр класса Presentation , загрузите презентацию,
- Получите ссылку на слайд по его индексу.
- Определите массив
columnWidth. - Определите массив
rowHeight. - Добавьте объект ITable на слайд с помощью метода addTable .
- Удалите строку таблицы.
- Удалите столбец таблицы.
- Сохраните изменённую презентацию.
Presentation pres = new Presentation();
try {
ISlide slide = pres.getSlides().get_Item(0);
double[] colWidth = { 100, 50, 30 };
double[] rowHeight = { 30, 50, 30 };
ITable table = slide.getShapes().addTable(100, 100, colWidth, rowHeight);
table.getRows().removeAt(1, false);
table.getColumns().removeAt(1, false);
pres.save("TestTable_out.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Установить форматирование текста на уровне строк таблицы
- Создайте экземпляр класса Presentation , загрузите презентацию,
- Получите ссылку на слайд по его индексу.
- Получите соответствующий объект ITable со слайда.
- Установите для ячеек первой строки метод setFontHeight(float value).
- Установите для ячеек первой строки методы setAlignment(int value) и setMarginRight(float value).
- Установите для ячеек второй строки метод setTextVerticalType(byte value).
- Сохраните изменённую презентацию.
// Создает экземпляр класса Presentation
Presentation pres = new Presentation();
try {
// Допустим, что первая фигура на первом слайде — таблица
ITable someTable = (ITable)pres.getSlides().get_Item(0).getShapes().get_Item(0);
// Устанавливает высоту шрифта ячеек первой строки
PortionFormat portionFormat = new PortionFormat();
portionFormat.setFontHeight(25);
someTable.getRows().get_Item(0).setTextFormat(portionFormat);
// Устанавливает выравнивание текста и правый отступ ячеек первой строки
ParagraphFormat paragraphFormat = new ParagraphFormat();
paragraphFormat.setAlignment(TextAlignment.Right);
paragraphFormat.setMarginRight(20);
someTable.getRows().get_Item(0).setTextFormat(paragraphFormat);
// Устанавливает вертикальный тип текста ячеек второй строки
TextFrameFormat textFrameFormat = new TextFrameFormat();
textFrameFormat.setTextVerticalType(TextVerticalType.Vertical);
someTable.getRows().get_Item(1).setTextFormat(textFrameFormat);
// Сохраняет презентацию на диск
pres.save("result.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Установить форматирование текста на уровне столбцов таблицы
- Создайте экземпляр класса Presentation , загрузите презентацию,
- Получите ссылку на слайд по его индексу.
- Получите соответствующий объект ITable со слайда.
- Установите для ячеек первого столбца метод setFontHeight(float value).
- Установите для ячеек первого столбца методы setAlignment(int value) и setMarginRight(float value).
- Установите для ячеек второго столбца метод setTextVerticalType(byte value).
- Сохраните изменённую презентацию.
// Создает экземпляр класса Presentation
Presentation pres = new Presentation();
try {
// Предположим, что первая фигура на первом слайде — таблица
ITable someTable = (ITable)pres.getSlides().get_Item(0).getShapes().get_Item(0)];
// Устанавливает высоту шрифта ячеек первого столбца
PortionFormat portionFormat = new PortionFormat();
portionFormat.setFontHeight(25);
someTable.getColumns().get_Item(0).setTextFormat(portionFormat);
// Устанавливает выравнивание текста и правый отступ ячеек первого столбца одним вызовом
ParagraphFormat paragraphFormat = new ParagraphFormat();
paragraphFormat.setAlignment(TextAlignment.Right);
paragraphFormat.setMarginRight(20);
someTable.getColumns().get_Item(0).setTextFormat(paragraphFormat);
// Устанавливает вертикальный тип текста ячеек второго столбца
TextFrameFormat textFrameFormat = new TextFrameFormat();
textFrameFormat.setTextVerticalType(TextVerticalType.Vertical);
someTable.getColumns().get_Item(1).setTextFormat(textFrameFormat);
pres.save("result.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
Получить свойства стиля таблицы
Aspose.Slides позволяет получить свойства стиля таблицы, чтобы использовать эти детали для другой таблицы или в другом месте. Этот Java‑код показывает, как получить свойства стиля из предустановленного стиля таблицы:
Presentation pres = new Presentation();
try {
ITable table = pres.getSlides().get_Item(0).getShapes().addTable(10, 10, new double[] { 100, 150 }, new double[] { 5, 5, 5 });
table.setStylePreset(TableStylePreset.DarkStyle1); // изменить предустановленную тему стиля по умолчанию
pres.save("table.pptx", SaveFormat.Pptx);
} finally {
if (pres != null) pres.dispose();
}
FAQ
Могу ли я применить темы/стили PowerPoint к уже созданной таблице?
Да. Таблица наследует тему слайда/макета/мастера, но вы по‑прежнему можете переопределять заливки, границы и цвета текста над этой темой.
Могу ли я сортировать строки таблицы, как в Excel?
Нет, таблицы Aspose.Slides не имеют встроенной сортировки или фильтров. Сначала отсортируйте данные в памяти, затем заново заполните строки таблицы в этом порядке.
Могу ли я использовать полосатые (заштрихованные) столбцы, сохранив пользовательские цвета в отдельных ячейках?
Да. Включите полосатые столбцы, затем переопределите отдельные ячейки локальным форматированием; форматирование ячеек имеет приоритет над стилем таблицы.