C++ を使用したプレゼンテーションでのタグとカスタム データの管理

プレゼンテーション ファイルのデータ保存

PPTX ファイル—.pptx 拡張子のアイテム—は PresentationML 形式で保存されており、これは Office Open XML 仕様の一部です。Office Open XML 形式はプレゼンテーションに含まれるデータの構造を定義します。

スライド はプレゼンテーションの要素のひとつで、スライド パート は単一スライドのコンテンツを保持します。スライド パートは ISO/IEC 29500 で定義された User Defined Tags など、多くのパートへの明示的なリレーションシップを持つことが許可されています。

カスタム データ(プレゼンテーション 固有)やユーザーはタグ(ITagCollection) および CustomXmlParts(ICustomXmlPartCollection) として存在できます。

タグの値を取得する

スライドでは、タグは IDocumentProperties.Keywords プロパティに対応します。このサンプルコードは Aspose.Slides for C++ を使用して Presentation のタグ値を取得する方法を示しています:

auto pres = System::MakeObject<Presentation>(u"pres.pptx");
System::String keywords = pres->get_DocumentProperties()->get_Keywords();

プレゼンテーションにタグを追加する

Aspose.Slides を使用すると、プレゼンテーションにタグを追加できます。タグは通常、次の 2 つの項目で構成されます。

  • カスタム プロパティの名前 - MyTag
  • カスタム プロパティの値 - My Tag Value

特定のルールやプロパティに基づいてプレゼンテーションを分類する必要がある場合、タグを追加すると便利です。たとえば、北米諸国のプレゼンテーションをまとめて分類したい場合、North American タグを作成し、該当する国(米国、メキシコ、カナダ)を値として割り当てることができます。

このサンプルコードは Aspose.Slides for C++ を使用して Presentation にタグを追加する方法を示しています:

auto pres = System::MakeObject<Presentation>(u"pres.pptx");

System::SharedPtr<ITagCollection> tags = pres->get_CustomData()->get_Tags();
pres->get_CustomData()->get_Tags()->idx_set(u"MyTag", u"My Tag Value");

タグは Slide に対しても設定できます:

auto pres = System::MakeObject<Presentation>();

auto slide = pres->get_Slides()->idx_get(0);
slide->get_CustomData()->get_Tags()->idx_set(u"tag", u"value");

また、個々の Shape に対しても設定できます:

auto pres = System::MakeObject<Presentation>();

auto slide = pres->get_Slides()->idx_get(0);
auto shape = slide->get_Shapes()->AddAutoShape(ShapeType::Rectangle, 10.0f, 10.0f, 100.0f, 50.0f);
shape->get_TextFrame()->set_Text(u"My text");
shape->get_CustomData()->get_Tags()->idx_set(u"tag", u"value");

よくある質問

プレゼンテーション、スライド、またはシェイプからすべてのタグを一括で削除できますか?

はい。tag collection は、すべてのキー–バリュー ペアを一度に削除する clear 操作をサポートしています。

コレクション全体を走査せずに、名前で単一のタグを削除するにはどうすればよいですか?

TagCollectionRemove(name) 操作を使用して、キーでタグを削除できます。

分析やフィルタリングのために、タグ名の完全なリストを取得するにはどうすればよいですか?

tag collection 上で GetNamesOfTags を使用すると、すべてのタグ名の配列が返されます。