如何在 C++ 中使用表格
Aspose.Slides FOSS for C++ 支持在幻灯片上创建具有可配置列宽和行高的表格。本指南展示了如何添加表格、填充数据以及对单元格应用基本的文本格式设置。
分步指南
步骤 1:构建并链接库
git clone https://github.com/aspose-slides-foss/Aspose.Slides-FOSS-for-Cpp.git
cd Aspose.Slides-FOSS-for-Cpp && mkdir build && cd build
cmake . && cmake --build .步骤 2:创建或打开演示文稿
#include <Aspose/Slides/Foss/presentation.h>
int main() {
namespace asf = Aspose::Slides::Foss;
asf::Presentation prs;
auto& slide = prs.slides()[0];
// ... add table ...
prs.save("table.pptx", asf::SaveFormat::PPTX);
return 0;
}步骤 3:定义列宽和行高
表格需要以点为单位明确指定列宽和行高(1 点 = 1/72 英寸)。标准幻灯片的宽度为 720 点,高度为 540 点。
std::vector<double> col_widths = {200.0, 150.0, 150.0}; // 3 columns
std::vector<double> row_heights = {45.0, 40.0, 40.0}; // 3 rows
步骤 4:添加表格
slide.shapes().add_table(x, y, col_widths, row_heights) 在位置 (x, y) 创建表格:
#include <Aspose/Slides/Foss/presentation.h>
#include <vector>
int main() {
namespace asf = Aspose::Slides::Foss;
asf::Presentation prs;
auto& slide = prs.slides()[0];
std::vector<double> col_widths = {200.0, 150.0, 150.0};
std::vector<double> row_heights = {45.0, 40.0, 40.0};
auto& table = slide.shapes().add_table(50, 100, col_widths, row_heights);
prs.save("table.pptx", asf::SaveFormat::PPTX);
return 0;
}步骤 5:设置单元格文本
通过 table.rows()[row_index][col_index] 访问单元格,并通过 .text_frame()->set_text() 分配文本:
#include <Aspose/Slides/Foss/presentation.h>
#include <vector>
#include <string>
int main() {
namespace asf = Aspose::Slides::Foss;
asf::Presentation prs;
auto& slide = prs.slides()[0];
std::vector<double> col_widths = {200.0, 150.0, 150.0};
std::vector<double> row_heights = {45.0, 40.0, 40.0};
auto& table = slide.shapes().add_table(50, 100, col_widths, row_heights);
// Header row (row 0)
std::vector<std::string> headers = {"Product", "Units Sold", "Revenue"};
for (size_t col = 0; col < headers.size(); ++col) {
table.rows()[0][col].text_frame()->set_text(headers[col]);
}
// Data rows
std::vector<std::vector<std::string>> data = {
{"Widget A", "1,200", "$24,000"},
{"Widget B", "850", "$17,000"},
};
for (size_t r = 0; r < data.size(); ++r) {
for (size_t c = 0; c < data[r].size(); ++c) {
table.rows()[r + 1][c].text_frame()->set_text(data[r][c]);
}
}
prs.save("sales-table.pptx", asf::SaveFormat::PPTX);
return 0;
}步骤 6:格式化标题单元格文本
使用 PortionFormat 对标题单元格应用粗体格式:
for (size_t col = 0; col < headers.size(); ++col) {
auto& cell = table.rows()[0][col];
auto& portions = cell.text_frame()->paragraphs()[0].portions();
if (portions.size() > 0) {
auto& fmt = portions[0].portion_format();
fmt.set_font_bold(asf::NullableBool::TRUE);
fmt.fill_format().set_fill_type(asf::FillType::SOLID);
fmt.fill_format().solid_fill_color().set_color(
asf::Color::from_argb(255, 255, 255, 255));
}
}完整工作示例
#include <Aspose/Slides/Foss/presentation.h>
#include <vector>
#include <string>
#include <iostream>
int main() {
namespace asf = Aspose::Slides::Foss;
std::vector<std::vector<std::string>> data_rows = {
{"North", "$1.2M", "+8%"},
{"South", "$0.9M", "+4%"},
{"East", "$1.5M", "+12%"},
{"West", "$0.7M", "+2%"},
};
std::vector<std::string> headers = {"Region", "Revenue", "Growth"};
asf::Presentation prs;
auto& slide = prs.slides()[0];
std::vector<double> col_widths = {180.0, 140.0, 120.0};
std::vector<double> row_heights(1 + data_rows.size(), 38.0);
row_heights[0] = 45.0;
auto& table = slide.shapes().add_table(60, 80, col_widths, row_heights);
// Header row
for (size_t col = 0; col < headers.size(); ++col) {
auto& cell = table.rows()[0][col];
cell.text_frame()->set_text(headers[col]);
auto& portions = cell.text_frame()->paragraphs()[0].portions();
if (portions.size() > 0) {
portions[0].portion_format().set_font_bold(asf::NullableBool::TRUE);
}
}
// Data rows
for (size_t r = 0; r < data_rows.size(); ++r) {
for (size_t c = 0; c < data_rows[r].size(); ++c) {
table.rows()[r + 1][c].text_frame()->set_text(data_rows[r][c]);
}
}
prs.save("regional-revenue.pptx", asf::SaveFormat::PPTX);
std::cout << "Saved regional-revenue.pptx\n";
return 0;
}常见问题及解决方案
std::out_of_range 访问 table.rows()[row][col] 时
行和列索引是从零开始的。如果您使用 3 个元素定义了 row_heights,有效的行索引为 0、1、2。
单元格文本未出现在保存的文件中
始终通过 .text_frame()->set_text() 进行分配,而不要直接在单元格对象上通过 .set_text()。
表格位置偏离幻灯片
检查标准幻灯片的 x + sum(col_widths) <= 720 和 y + sum(row_heights) <= 540。
常见问题
我可以合并表格单元格吗?
此版本不支持单元格合并。
我可以为整个表格应用背景颜色吗?
对每个单元格应用填充格式:
for (size_t r = 0; r < table.rows().size(); ++r) {
for (size_t c = 0; c < table.rows()[r].size(); ++c) {
auto& cell = table.rows()[r][c];
cell.fill_format().set_fill_type(asf::FillType::SOLID);
cell.fill_format().solid_fill_color().set_color(
asf::Color::from_argb(255, 240, 248, 255));
}
}我可以设置单元格边框样式吗?
单元格边框属性可通过单元格格式的边框方法访问。请参阅 API 参考以获取完整的边框格式属性列表。