Präsentationen in C++ öffnen
Übersicht
Neben dem Erstellen von PowerPoint-Präsentationen von Grund auf ermöglicht Aspose.Slides auch das Öffnen vorhandener Präsentationen. Nachdem Sie eine Präsentation geladen haben, können Sie Informationen darüber abrufen, Folieninhalt bearbeiten, neue Folien hinzufügen, vorhandene entfernen und mehr.
Präsentationen öffnen
Um eine vorhandene Präsentation zu öffnen, instanziieren Sie die Presentation Klasse und übergeben den Dateipfad an ihren Konstruktor.
Das folgende C++-Beispiel zeigt, wie man eine Präsentation öffnet und die Folienanzahl ermittelt:
// Instanziieren Sie die Presentation‑Klasse und übergeben Sie einen Dateipfad an ihren Konstruktor.
auto presentation = MakeObject<Presentation>(u"Sample.pptx");
// Geben Sie die Gesamtzahl der Folien in der Präsentation aus.
Console::WriteLine(presentation->get_Slides()->get_Count());
presentation->Dispose();
Passwortgeschützte Präsentationen öffnen
Wenn Sie eine passwortgeschützte Präsentation öffnen müssen, übergeben Sie das Passwort über die set_Password Methode der LoadOptions Klasse, um sie zu entschlüsseln und zu laden. Der folgende C++-Code demonstriert diesen Vorgang:
auto loadOptions = MakeObject<LoadOptions>();
loadOptions->set_Password(u"YOUR_PASSWORD");
auto presentation = MakeObject<Presentation>(u"Sample.pptx", loadOptions);
// Operationen an der entschlüsselten Präsentation durchführen.
presentation->Dispose();
Große Präsentationen öffnen
Aspose.Slides bietet Optionen – insbesondere die get_BlobManagementOptions Methode in der LoadOptions Klasse – um das Laden großer Präsentationen zu unterstützen.
Der folgende C++-Code demonstriert das Laden einer großen Präsentation (zum Beispiel 2 GB):
auto filePath = u"LargePresentation.pptx";
auto loadOptions = MakeObject<LoadOptions>();
// Wählen Sie das KeepLocked‑Verhalten—die Präsentationsdatei bleibt für die Lebensdauer von
// der Presentation‑Instanz gesperrt, muss jedoch nicht in den Speicher geladen oder in eine temporäre Datei kopiert werden.
loadOptions->get_BlobManagementOptions()->set_PresentationLockingBehavior(PresentationLockingBehavior::KeepLocked);
loadOptions->get_BlobManagementOptions()->set_IsTemporaryFilesAllowed(true);
loadOptions->get_BlobManagementOptions()->set_MaxBlobsBytesInMemory(10 * 1024 * 1024); // 10 MB
auto presentation = MakeObject<Presentation>(filePath, loadOptions);
// Die große Präsentation wurde geladen und kann verwendet werden, während der Speicherverbrauch niedrig bleibt.
// Änderungen an der Präsentation vornehmen.
presentation->get_Slide(0)->set_Name(u"Large presentation");
// Speichern Sie die Präsentation in einer anderen Datei. Der Speicherverbrauch bleibt bei diesem Vorgang niedrig.
presentation->Save(u"LargePresentation-copy.pptx", SaveFormat::Pptx);
// Nicht tun! Eine Ein‑/Ausgabe‑Ausnahme wird ausgelöst, weil die Datei gesperrt bleibt, bis das Präsentationsobjekt entsorgt wird.
File::Delete(filePath);
presentation->Dispose();
// Es ist hier in Ordnung. Die Quelldatei ist nicht mehr durch das Präsentationsobjekt gesperrt.
File::Delete(filePath);
Info
Um bestimmte Einschränkungen beim Arbeiten mit Streams zu umgehen, kann Aspose.Slides den Inhalt eines Streams kopieren. Das Laden einer großen Präsentation aus einem Stream führt dazu, dass die Präsentation kopiert wird und das Laden verlangsamen kann. Daher empfehlen wir dringend, beim Laden einer großen Präsentation den Dateipfad der Präsentation anstelle eines Streams zu verwenden.
Beim Erstellen einer Präsentation, die große Objekte (Video, Audio, hochauflösende Bilder usw.) enthält, können Sie BLOB management nutzen, um den Speicherverbrauch zu reduzieren.
Externe Ressourcen steuern
Aspose.Slides stellt das IResourceLoadingCallback Interface bereit, mit dem Sie externe Ressourcen verwalten können. Der folgende C++-Code zeigt, wie das IResourceLoadingCallback Interface verwendet wird:
class ImageLoadingHandler : public IResourceLoadingCallback
{
public:
ResourceLoadingAction ResourceLoading(SharedPtr<IResourceLoadingArgs> args) override
{
if (args->get_OriginalUri().EndsWith(u".jpg"))
{
try
{
// Laden Sie ein Ersatzbild.
auto imageData = File::ReadAllBytes(u"aspose-logo.jpg");
args->SetData(imageData);
return ResourceLoadingAction::UserProvided;
}
catch (Exception&)
{
return ResourceLoadingAction::Skip;
}
}
else if (args->get_OriginalUri().EndsWith(u".png"))
{
// Setzen Sie eine Ersatz-URL.
args->set_Uri(u"http://www.google.com/images/logos/ps_logo2.png");
return ResourceLoadingAction::Default;
}
// Überspringen Sie alle anderen Bilder.
return ResourceLoadingAction::Skip;
}
};
auto loadOptions = MakeObject<LoadOptions>();
loadOptions->set_ResourceLoadingCallback(MakeObject<ImageLoadingHandler>());
auto presentation = MakeObject<Presentation>(u"Sample.pptx", loadOptions);
Präsentationen ohne eingebettete Binärobjekte laden
Eine PowerPoint-Präsentation kann die folgenden Arten von eingebetteten Binärobjekten enthalten:
- VBA-Projekt (zugänglich über IPresentation::get_VbaProject);
- OLE‑Objekt‑eingebettete Daten (zugänglich über IOleEmbeddedDataInfo::get_EmbeddedFileData);
- ActiveX‑Steuerungs‑Binärdaten (zugänglich über IControl::get_ActiveXControlBinary).
Durch die Verwendung der Methode ILoadOptions::set_DeleteEmbeddedBinaryObjects können Sie eine Präsentation ohne eingebettete Binärobjekte laden.
Diese Methode ist nützlich, um potenziell schädliche Binärinhalte zu entfernen. Der folgende C++-Code demonstriert, wie man eine Präsentation ohne eingebettete Binärinhalte lädt:
auto loadOptions = MakeObject<LoadOptions>();
loadOptions->set_DeleteEmbeddedBinaryObjects(true);
auto presentation = MakeObject<Presentation>(u"malware.ppt", loadOptions);
// Vorgänge an der Präsentation ausführen.
presentation->Dispose();
FAQ
Wie kann ich feststellen, dass eine Datei beschädigt ist und nicht geöffnet werden kann?
Beim Laden erhalten Sie eine Parsing-/Formatvalidierungs‑Ausnahme. Solche Fehler erwähnen häufig eine ungültige ZIP‑Struktur oder beschädigte PowerPoint‑Datensätze.
Was passiert, wenn beim Öffnen erforderliche Schriftarten fehlen?
Die Datei wird geöffnet, aber später rendering/export kann Schriftarten ersetzen. Configure font substitutions oder add the required fonts zur Laufzeitumgebung hinzufügen.
Wie verhält es sich mit eingebetteten Medien (Video/Audio) beim Öffnen?
Sie werden als Präsentationsressourcen verfügbar. Wenn Medien über externe Pfade referenziert werden, stellen Sie sicher, dass diese Pfade in Ihrer Umgebung zugänglich sind; andernfalls kann rendering/export die Medien weglassen.