Ernte-EPS | API-Lösung für C++

Überblick

In diesem Artikel wird erklärt, wie man EPS mit C++** zuschneidet. Es behandelt die folgenden Themen.

C++-Crop-EPS-Beschreibung

Das Zuschneiden des Bildes ist ein Vorgang, der einen oder mehrere Ränder des Bildes ändert: links, rechts, oben und unten. Mit anderen Worten: Es schneidet den Bildinhalt an den Rändern ab.

Daher ist die resultierende Darstellung des EPS-Bilds immer kleiner als das Original. Das Volumen der Datei wird nicht geändert, da unsere Lösung nicht mit dem Inhalt, sondern mit dem Header der EPS-Datei funktioniert.

Die Ränder des EPS-Bildes werden durch BoundingBox-Metadaten definiert. Um zuzuschneiden, oder mit anderen Worten, einen neuen Begrenzungsrahmen einzurichten, müssen wir den vorhandenen Begrenzungsrahmen des EPS-Bildes kennen. Andernfalls können wir die Werte des neuen Begrenzungsrahmens außerhalb des vorhandenen Begrenzungsrahmens zuweisen, was zu einem Fehler führt. Also die Schritte zum Zuschneiden von EPS-Bildern in C++ folgen:

  1. Initialisieren Sie das Objekt PsDocument mit dem Eingabestream, der die EPS-Datei enthält.
  2. Extrahieren Sie den vorhandenen Begrenzungsrahmen des Bildes mit der statischen Methode ExtractEpsBoundingBox.
  3. Erstellen Sie den Ausgabestream für die resultierende EPS-Datei.
  4. Erstellen Sie einen neuen Begrenzungsrahmen.
  5. Beschneiden Sie das PsDocument-Objekt mit der neuen Begrenzungsbox mit der statischen Methode CropEps.

Sie können die Qualität von Aspose.Page EPS Crop überprüfen und die Ergebnisse mit dem kostenlosen Online-Crop EPS anzeigen und dann die resultierende EPS-Datei mit unserer Webanwendung EPS Viewer anzeigen.

EPS in C++ zuschneiden

Im folgenden C++-Codeausschnitt erhalten wir den vorhandenen Begrenzungsrahmen des Bildes und beschneiden EPS:

 1    // The path to the documents directory.
 2    System::String dataDir = RunExamples::GetDataDir_WorkingWithEPS();
 3    
 4    //Create an input stream for EPS file
 5    {
 6        System::SharedPtr<System::IO::Stream> inputEpsStream = System::MakeObject<System::IO::FileStream>(dataDir + u"input.eps", System::IO::FileMode::Open, System::IO::FileAccess::Read);
 7        // Clearing resources under 'using' statement
 8        System::Details::DisposeGuard<1> __dispose_guard_1({ inputEpsStream});
 9        // ------------------------------------------
10        
11        try
12        {
13            //Initialize PsDocument object with input stream
14            System::SharedPtr<PsDocument> doc = System::MakeObject<PsDocument>(inputEpsStream);
15            
16            //Get initial bounding box of EPS image
17            System::ArrayPtr<int32_t> initialBoundingBox = doc->ExtractEpsBoundingBox();
18            
19            //Create an output stream for resized EPS
20            {
21                System::SharedPtr<System::IO::Stream> outputEpsStream = System::MakeObject<System::IO::FileStream>(dataDir + u"output_crop.eps", System::IO::FileMode::Create, System::IO::FileAccess::Write);
22                // Clearing resources under 'using' statement
23                System::Details::DisposeGuard<1> __dispose_guard_0({ outputEpsStream});
24                // ------------------------------------------
25                
26                try
27                {
28                    //Create new bounding box
29                    //Bounding box is represented by 4 numbers: x0, y0, x, y, where x0 - left margin, y0 - top margin, x - (x0 + width), y - (y0 + height)
30                    System::ArrayPtr<float> newBoundingBox = System::MakeArray<float>({260, 300, 480, 432});
31                    
32                    //Crop EPS image and save to the output stream                    
33                    //Croping of image is changing of its bounding box so that new values of bounding box will be within initial bounding box, that is
34                    //initialBoundingBox[0] <= newBoundingBox[0] <= initialBoundingBox[2]
35                    //initialBoundingBox[1] <= newBoundingBox[1] <= initialBoundingBox[3]
36                    //initialBoundingBox[0] <= newBoundingBox[2] <= initialBoundingBox[2]
37                    //initialBoundingBox[1] <= newBoundingBox[3] <= initialBoundingBox[3]
38                    doc->CropEps(outputEpsStream, newBoundingBox);
39                }
40                catch(...)
41                {
42                    __dispose_guard_0.SetCurrentException(std::current_exception());
43                }
44            }
45        }
46        catch(...)
47        {
48            __dispose_guard_1.SetCurrentException(std::current_exception());
49        }
50    }

Siehe Crop EPS in Java und .NET.

Ursprüngliches EPS-Bild
Erstes Bild
Zugeschnittenes EPS-Bild
Zugeschnittenes Bild

Testen Sie das Zuschneiden von EPS online in unserer Webanwendung zum Zuschneiden von EPS. Sie können die EPS-Datei zuschneiden und das Ergebnis in wenigen Sekunden herunterladen.

Sie können Beispiele und Datendateien herunterladen von GitHub.

Have any questions about Aspose.Page?



Subscribe to Aspose Product Updates

Get monthly newsletters & offers directly delivered to your mailbox.