セルの管理
Contents
[
Hide
]
統合されたテーブルセルの特定
- Presentation クラスのインスタンスを作成します。
- 最初のスライドからテーブルを取得します。
- テーブルの行と列を繰り返して、統合されたセルを見つけます。
- 統合セルが見つかったときにメッセージを印刷します。
この PHP コードは、プレゼンテーション内の統合されたテーブルセルを特定する方法を示しています。
$pres = new Presentation("SomePresentationWithTable.pptx");
try {
$table = $pres->getSlides()->get_Item(0)->getShapes()->get_Item(0);// assuming that Slide#0.Shape#0 is a table
for($i = 0; $i < java_values($table->getRows()->size()) ; $i++) {
for($j = 0; $j < java_values($table->getColumns()->size()) ; $j++) {
$currentCell = $table->getRows()->get_Item($i)->get_Item($j);
if ($currentCell->isMergedCell()) {
echo(sprintf("セル %d;%d は RowSpan=%d、ColSpan=%d の統合セルの一部です。最初のセルは %d;%d です。", $i, $j, $currentCell->getRowSpan(), $currentCell->getColSpan(), $currentCell->getFirstRowIndex(), $currentCell->getFirstColumnIndex()));
}
}
}
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
テーブルセルの境界線を削除
- Presentation クラスのインスタンスを作成します。
- インデックスを介してスライドの参照を取得します。
- 幅のある列の配列を定義します。
- 高さのある行の配列を定義します。
- addTable メソッドを介してスライドにテーブルを追加します。
- 各セルを繰り返して、上、下、右、左の境界をクリアします。
- 修正されたプレゼンテーションを PPTX ファイルとして保存します。
この PHP コードは、テーブルセルから境界を削除する方法を示しています。
# PPTXファイルを表すPresentationクラスをインスタンス化
$pres = new Presentation();
try {
# 最初のスライドにアクセス
$sld = $pres->getSlides()->get_Item(0);
# 幅を持つ列と高さを持つ行を定義
$dblCols = array(50, 50, 50, 50 );
$dblRows = array(50, 30, 30, 30, 30 );
# スライドにテーブルシェイプを追加
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 各セルの境界の書式を設定
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::NoFill);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::NoFill);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::NoFill);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::NoFill);
}
}
# PPTXをディスクに書き込む
$pres->save("table_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
統合セルの番号付け
もし、セル (1, 1) x (2, 1) と (1, 2) x (2, 2) を統合すると、結果として得られるテーブルには番号が付けられます。この PHP コードは、そのプロセスを示しています。
# PPTXファイルを表すPresentationクラスをインスタンス化
$pres = new Presentation();
try {
# 最初のスライドにアクセス
$sld = $pres->getSlides()->get_Item(0);
# 幅を持つ列と高さを持つ行を定義
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# スライドにテーブルシェイプを追加
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 各セルの境界の書式を設定
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderRight()->setWidth(5);
}
}
# セル (1, 1) x (2, 1) を統合
$tbl->mergeCells($tbl->get_Item(1, 1), $tbl->get_Item(2, 1), false);
# セル (1, 2) x (2, 2) を統合
$tbl->mergeCells($tbl->get_Item(1, 2), $tbl->get_Item(2, 2), false);
$pres->save("MergeCells_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
さらに、セル (1, 1) と (1, 2) を統合することにより、結果として中央に大きな統合セルを持つテーブルが得られます。
# PPTXファイルを表すPresentationクラスをインスタンス化
$pres = new Presentation();
try {
# 最初のスライドにアクセス
$sld = $pres->getSlides()->get_Item(0);
# 幅を持つ列と高さを持つ行を定義
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# スライドにテーブルシェイプを追加
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 各セルの境界の書式を設定
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderRight()->setWidth(5);
}
}
# セル (1, 1) x (2, 1) を統合
$tbl->mergeCells($tbl->get_Item(1, 1), $tbl->get_Item(2, 1), false);
# セル (1, 2) x (2, 2) を統合
$tbl->mergeCells($tbl->get_Item(1, 2), $tbl->get_Item(2, 2), false);
# セル (1, 1) x (1, 2) を統合
$tbl->mergeCells($tbl->get_Item(1, 1), $tbl->get_Item(1, 2), true);
# PPTXファイルをディスクに書き込む
$pres->save("MergeCells_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
分割セルの番号付け
以前の例では、テーブルセルが統合されたとき、他のセルの番号付けや番号システムは変更されませんでした。
今回は、通常のテーブル(統合セルのないテーブル)を取り、セル (1,1) を分割して特別なテーブルを作成しようとします。このテーブルの番号付けに注意を払うことをお勧めします。これは奇妙に見えるかもしれませんが、これは Microsoft PowerPoint がテーブルセルを番号付けする方法であり、Aspose.Slides も同じことを行います。
この PHP コードは、前述のプロセスを示しています。
# PPTXファイルを表すPresentationクラスをインスタンス化
$pres = new Presentation();
try {
# 最初のスライドにアクセス
$sld = $pres->getSlides()->get_Item(0);
# 幅を持つ列と高さを持つ行を定義
$dblCols = array(70, 70, 70, 70 );
$dblRows = array(70, 70, 70, 70 );
# スライドにテーブルシェイプを追加
$tbl = $sld->getShapes()->addTable(100, 50, $dblCols, $dblRows);
# 各セルの境界の書式を設定
foreach($tbl->getRows() as $row) {
foreach($row as $cell) {
$cell->getCellFormat()->getBorderTop()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderTop()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderTop()->setWidth(5);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderBottom()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderBottom()->setWidth(5);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderLeft()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderLeft()->setWidth(5);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getBorderRight()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$cell->getCellFormat()->getBorderRight()->setWidth(5);
}
}
# セル (1, 1) x (2, 1) を統合
$tbl->mergeCells($tbl->get_Item(1, 1), $tbl->get_Item(2, 1), false);
# セル (1, 2) x (2, 2) を統合
$tbl->mergeCells($tbl->get_Item(1, 2), $tbl->get_Item(2, 2), false);
# セル (1, 1) を分割
$tbl->get_Item(1, 1)->splitByWidth($tbl->get_Item(2, 1)->getWidth() / 2);
# PPTXファイルをディスクに書き込む
$pres->save("SplitCells_out.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}
テーブルセルの背景色を変更
この PHP コードは、テーブルセルの背景色を変更する方法を示しています。
$presentation = new Presentation();
try {
$slide = $presentation->getSlides()->get_Item(0);
$dblCols = array(150, 150, 150, 150 );
$dblRows = array(50, 50, 50, 50, 50 );
# 新しいテーブルを作成
$table = $slide->getShapes()->addTable(50, 50, $dblCols, $dblRows);
# セルの背景色を設定
$cell = $table->get_Item(2, 3);
$cell->getCellFormat()->getFillFormat()->setFillType(FillType::Solid);
$cell->getCellFormat()->getFillFormat()->getSolidFillColor()->setColor(java("java.awt.Color")->RED);
$presentation->save("cell_background_color.pptx", SaveFormat::Pptx);
} finally {
if (!java_is_null($presentation)) {
$presentation->dispose();
}
}
テーブルセル内に画像を追加
- Presentation クラスのインスタンスを作成します。
- インデックスを介してスライドの参照を取得します。
- 幅のある列の配列を定義します。
- 高さのある行の配列を定義します。
- AddTable メソッドを介してスライドにテーブルを追加します。
- 画像ファイルを保持するための
Images
オブジェクトを作成します。 IPPImage
オブジェクトにIImage
画像を追加します。- テーブルセルの
FillFormat
をPicture
に設定します。 - 画像をテーブルの最初のセルに追加します。
- 修正されたプレゼンテーションを PPTX ファイルとして保存します。
この PHP コードは、テーブルを作成するときにテーブルセル内に画像を配置する方法を示しています。
# PPTXファイルを表すPresentationクラスをインスタンス化
$pres = new Presentation();
try {
# 最初のスライドにアクセス
$islide = $pres->getSlides()->get_Item(0);
# 幅を持つ列と高さを持つ行を定義
$dblCols = array(150, 150, 150, 150 );
$dblRows = array(100, 100, 100, 100, 90 );
# スライドにテーブルシェイプを追加
$tbl = $islide->getShapes()->addTable(50, 50, $dblCols, $dblRows);
# 画像ファイルを使用してIPPImageオブジェクトを作成
$picture;
$image = Images->fromFile("image.jpg");
try {
$picture = $pres->getImages()->addImage($image);
} finally {
if (!java_is_null($image)) {
$image->dispose();
}
}
# 最初のテーブルセルに画像を追加
$cellFormat = $tbl->get_Item(0, 0)->getCellFormat();
$cellFormat::getFillFormat()->setFillType(FillType::Picture);
$cellFormat::getFillFormat()->getPictureFillFormat()->setPictureFillMode(PictureFillMode->Stretch);
$cellFormat::getFillFormat()->getPictureFillFormat()->getPicture()->setImage($picture);
# PPTXファイルをディスクに保存
$pres->save("Image_In_TableCell_out.pptx", SaveFormat::Pptx);
} catch (JavaException $e) {
} finally {
if (!java_is_null($pres)) {
$pres->dispose();
}
}