Πώς να φορτώσετε παρουσιάσεις σε C++

Πώς να φορτώσετε παρουσιάσεις σε C++

Aspose.Slides FOSS for C++ σας επιτρέπει να ανοίξετε οποιοδήποτε αρχείο .pptx, να ελέγξετε το περιεχόμενό του και είτε να το αποθηκεύσετε ξανά σε PPTX είτε να εξάγετε δεδομένα από αυτό. Αυτός ο οδηγός καλύπτει το άνοιγμα ενός αρχείου, την επανάληψη των διαφανειών, την ανάγνωση του κειμένου σχήματος και την αποθήκευση με round‑tripping.

Οδηγός βήμα-βήμα

Βήμα 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: Άνοιγμα υπάρχουσας παρουσίασης

Περάστε τη διαδρομή του αρχείου στον κατασκευαστή Presentation. Ο καταστροφέας διαχειρίζεται τον καθαρισμό.

#include <Aspose/Slides/Foss/presentation.h>
#include <iostream>

int main() {
    namespace asf = Aspose::Slides::Foss;

    asf::Presentation prs("input.pptx");
    std::cout << "Slide count: " << prs.slides().size() << "\n";
    prs.save("output.pptx", asf::SaveFormat::PPTX);
    return 0;
}

Άγνωστα τμήματα XML στο αρχείο προέλευσης διατηρούνται ακριβώς όπως είναι: η βιβλιοθήκη δεν αφαιρεί ποτέ περιεχόμενο που δεν έχει ακόμη καταλάβει.


Βήμα 3: Εξέταση διαφανειών

Επανάληψη σε όλες τις διαφάνειες και εκτύπωση του αριθμού των σχημάτων τους:

#include <Aspose/Slides/Foss/presentation.h>
#include <iostream>

int main() {
    namespace asf = Aspose::Slides::Foss;

    asf::Presentation prs("deck.pptx");
    for (size_t i = 0; i < prs.slides().size(); ++i) {
        auto& slide = prs.slides()[i];
        std::cout << "Slide " << i << ": "
                  << slide.shapes().size() << " shapes\n";
    }
    return 0;
}

Βήμα 4: Ανάγνωση κειμένου σχήματος

Επανάληψη πάνω από σχήματα και ανάγνωση κειμένου από σχήματα που έχουν ένα TextFrame:

#include <Aspose/Slides/Foss/presentation.h>
#include <iostream>

int main() {
    namespace asf = Aspose::Slides::Foss;

    asf::Presentation prs("deck.pptx");
    for (size_t i = 0; i < prs.slides().size(); ++i) {
        auto& slide = prs.slides()[i];
        for (size_t j = 0; j < slide.shapes().size(); ++j) {
            auto& shape = slide.shapes()[j];
            if (shape.has_text_frame()) {
                auto text = shape.text_frame()->text();
                if (!text.empty()) {
                    std::cout << "  Shape text: " << text << "\n";
                }
            }
        }
    }
    return 0;
}

Βήμα 5: Ανάγνωση Ιδιοτήτων Εγγράφου

Πρόσβαση στις βασικές ιδιότητες του εγγράφου από prs.document_properties():

#include <Aspose/Slides/Foss/presentation.h>
#include <iostream>

int main() {
    namespace asf = Aspose::Slides::Foss;

    asf::Presentation prs("deck.pptx");
    auto& props = prs.document_properties();
    std::cout << "Title:   " << props.title() << "\n";
    std::cout << "Author:  " << props.author() << "\n";
    std::cout << "Subject: " << props.subject() << "\n";
    return 0;
}

Βήμα 6: Αποθήκευση κυκλικής διαδρομής

Αφού ελέγξετε ή τροποποιήσετε την παρουσίαση, αποθηκεύστε την ξανά σε μορφή PPTX:

prs.save("output.pptx", asf::SaveFormat::PPTX);

Η αποθήκευση σε διαφορετική διαδρομή δημιουργεί ένα νέο αρχείο. Η αποθήκευση στην ίδια διαδρομή αντικαθιστά το αρχικό.


Κοινά προβλήματα και διορθώσεις

Το αρχείο δεν βρέθηκε ή δεν μπορεί να ανοιχτεί

Ελέγξτε ότι η διαδρομή προς το αρχείο .pptx είναι σωστή σε σχέση με τον τρέχοντα φάκελο εργασίας. Χρησιμοποιήστε το std::filesystem::path για αξιόπιστη κατασκευή διαδρομής:

#include <filesystem>
auto path = std::filesystem::path(__FILE__).parent_path() / "assets" / "deck.pptx";
asf::Presentation prs(path.string());

Εξαίρεση: Η μορφή αρχείου δεν υποστηρίζεται

Η βιβλιοθήκη υποστηρίζει μόνο .pptx (Office Open XML). Τα παλαιά .ppt (δυαδικά PowerPoint 97-2003) αρχεία δεν υποστηρίζονται.

Το σχήμα δεν έχει text_frame

Ορισμένα σχήματα (Connectors, PictureFrames, GroupShapes) δεν έχουν πλαίσιο κειμένου. Προστατέψτε με shape.has_text_frame() πριν την πρόσβαση στο κείμενο.


Συχνές Ερωτήσεις

Διατηρεί η φόρτωση όλο το αρχικό περιεχόμενο;

Ναι. Τα άγνωστα τμήματα XML διατηρούνται ακριβώς όπως είναι κατά την αποθήκευση σε κυκλική διαδρομή. Η βιβλιοθήκη σειριοποιεί μόνο τα τμήματα του μοντέλου εγγράφου που καταλαβαίνει και περνάει διαμέσου οποιοδήποτε XML δεν αναγνωρίζει.

Μπορώ να φορτώσω ένα PPTX με προστασία κωδικού;

Οι παρουσιάσεις με προστασία κωδικού (κρυπτογραφημένες) δεν υποστηρίζονται σε αυτήν την έκδοση.

Μπορώ να εξάγω ενσωματωμένες εικόνες;

Πρόσβαση στη συλλογή εικόνων: prs.images() επιστρέφει το ImageCollection. Κάθε εικόνα διαθέτει τις μεθόδους width(), height() και binary_data() για την ανάγνωση των ακατέργαστων δεδομένων εικόνας.

Υποστηρίζεται η φόρτωση από buffer μνήμης;

Η φόρτωση από ένα std::vector<uint8_t> ή std::istream δεν εκτίθεται στο τρέχον API. Γράψτε τα bytes σε ένα προσωρινό αρχείο πρώτα, έπειτα περάστε τη διαδρομή στον Presentation κατασκευαστή.


Δείτε επίσης

 Ελληνικά