Vormen renderen Los van een document
Bij het verwerken van documenten is het een gemeenschappelijke taak om alle afbeeldingen uit het document te halen en naar een externe locatie te exporteren. Deze taak wordt eenvoudig met de Aspose.Words API, die al de functionaliteit biedt voor het extraheren en opslaan van afbeeldingsgegevens. Echter, soms wilt u misschien ook andere soorten grafische inhoud die worden vertegenwoordigd door een ander type tekenobject, bijvoorbeeld een tekstvak met paragrafen, pijlvormen en een kleine afbeelding. Er is geen eenvoudige manier om dit object te renderen omdat het een combinatie is van individuele inhoudselementen. U kunt ook een geval tegenkomen wanneer de inhoud is gegroepeerd in het object dat lijkt op een enkele afbeelding.
Aspose.Words biedt functionaliteit voor het extraheren van dit type inhoud op dezelfde manier als u een eenvoudige afbeelding uit vorm kunt halen als weergegeven inhoud. Dit artikel beschrijft hoe u deze functionaliteit kunt gebruiken om vormen onafhankelijk van het document te maken.
Vormtypes in Aspose.Words
Alle inhoud in een document tekening laag wordt weergegeven door de Shape of GroupShape knooppunt in de Aspose.Words Documentobjectmodule (DOM). Dergelijke inhoud kunnen tekstvakjes, afbeeldingen, AutoShapes, OLE objecten, enz. zijn. Sommige velden worden ook geïmporteerd als vormen, bijvoorbeeld de INCLUDEPICTURE
veld.
Een eenvoudige afbeelding wordt weergegeven door een Shape knooppunt van ShapeType.Image. Deze vorm knooppunt heeft geen dochter knooppunten, maar de afbeelding gegevens in deze vorm knooppunt kan worden benaderd door de Shape.ImageData eigendom. Aan de andere kant kan een vorm ook worden opgebouwd uit vele kindknooppunten. Bijvoorbeeld, een tekst box vorm, die wordt vertegenwoordigd door de ShapeType.TextBox eigendom, kan bestaan uit vele knooppunten, zoals Paragraph en Table. De meeste vormen kunnen de Paragraph en Table blok-level knooppunten. Dit zijn dezelfde knooppunten als die in het hoofdlichaam. Vormen zijn altijd onderdelen van een alinea, ofwel direct in de lijn of verankerd aan de Paragraaf maar op de documentpagina.
Een document kan ook vormen bevatten die gegroepeerd zijn. Groupkan worden ingeschakeld in Microsoft Word door meerdere objecten te selecteren en te klikkenGroupIn het rechterklikmenu.
In Aspose.Words, Deze groepen vormen worden vertegenwoordigd door de GroupShape Node. Deze kunnen ook op dezelfde manier worden aangeroepen om de hele groep aan de afbeelding te geven.
Het DOCX-formaat kan speciale soorten afbeeldingen bevatten, zoals diagrammen of grafieken. Deze vormen zijn ook vertegenwoordigd door de Shape knooppunt in Aspose.Words, die ook een vergelijkbare methode voor het renderen van hen als beelden biedt. Door ontwerp kan een vorm geen andere vorm als kind bevatten, tenzij die vorm een afbeelding is (ShapeType.Image). Bijvoorbeeld, Microsoft Word staat niet toe dat u een tekstvak in een ander tekstvak plaatst.
De hierboven beschreven vormen bieden een speciale methode om de vormen door de ShapeRenderer Klasse. Een voorbeeld van de ShapeRenderer klasse is opgehaald voor een Shape of GroupShape door de GetShapeRenderer methode of door de Shape aan de constructeur van de ShapeRenderer Klasse. Deze klasse biedt toegang tot leden, die het mogelijk maken een vorm te geven aan het volgende:
- Bestand op de schijf met behulp van de Save methode overbelasting
- Stream met de Save methode overbelasting
- Graphics Object door de RenderToSize en RenderToScale methoden
Renderen naar bestand of stroom
De Save methode biedt overbelasting die een vorm direct aan een bestand of stroom. Beide overbelasting accepteren een geval van de ImageSaveOptions klasse, die het definiëren van opties voor het renderen van de vorm mogelijk maakt. Dit werkt op dezelfde manier als de Document.Save methode. Hoewel deze parameter vereist is, kunt u een nulwaarde doorgeven, waarbij wordt aangegeven dat er geen aangepaste opties zijn.
De vorm kan worden geëxporteerd in elk afbeeldingsformaat dat in de SaveFormat Samenvatting. Bijvoorbeeld, de afbeelding kan worden weergegeven als een raster afbeelding, zoals JPEG door het specificeren van de SaveFormat.Jpeg opsomming, of als vectorbeeld, zoals EMF door het specificeren van de SaveFormat.Emf.
Het onderstaande codevoorbeeld illustreert het renderen van een vorm naar een EMF-afbeelding apart van het document, en opslaan naar schijf:
Het onderstaande voorbeeld illustreert het renderen van een vorm naar een JPEG-afbeelding apart van het document, en opslaan naar een stroom:
De ImageSaveOptions klasse kunt u een verscheidenheid aan opties die bepalen hoe de afbeelding wordt weergegeven. De hierboven beschreven functionaliteit kan op dezelfde wijze worden toegepast op de GroupShape en Shape knooppunten.
Renderen naar een Graphics
Object
Direct naar een Graphics object kunt u uw eigen instellingen en de status voor de Graphics object. Een gemeenschappelijk scenario houdt in dat een vorm direct in een Graphics object opgehaald uit a Windows Vorm of een Bitmap. Wanneer de Shape knooppunt wordt weergegeven, de instellingen zullen invloed hebben op het uiterlijk van de vorm. U kunt bijvoorbeeld de vorm draaien of schalen door gebruik te maken van de RotateTransform of ScaleTransform methoden voor de Graphics object.
Het voorbeeld hieronder laat zien hoe een vorm aan een Graphics object apart van het document en draai op de weergegeven afbeelding:
De Voorzitter. - Aan de orde is het gecombineerd debat over RenderToSize methode, de RenderToSizemethode geërfd van de NodeRendererBase is nuttig voor het maken van miniaturen van documentinhoud. De vormgrootte wordt gespecificeerd door de constructeur. De RenderToSize methode accepteert de Graphics object, de X en Y coördinaten van de afbeelding positie, en de grootte van de afbeelding (breedte en hoogte) die zal worden getrokken op de Graphics object.
De Shape kan met behulp van de ShapeRenderer.RenderToScale methode geërfd van de NodeRendererBase Klasse. Dit is vergelijkbaar met de Document.RenderToScale methode die dezelfde belangrijke parameters accepteert. Het verschil tussen deze twee methoden is dat met de ShapeRenderer.RenderToScale methode, in plaats van een letterlijke grootte, kies je een float waarde die de vorm schalen tijdens de weergave. Als de floatwaarde gelijk is aan 1.0 zorgt ervoor dat de vorm wordt weergegeven op 100% van de oorspronkelijke grootte. Een floatwaarde van 0,5 zal de afbeeldingsgrootte met de helft verminderen.
Een vormafbeelding renderen
De Shape klasse representeert objecten in de tekenlaag, zoals een AutoShape, tekstvak, vrije vorm, OLE-object, ActiveX-besturing of een afbeelding. Gebruik van de Shape klasse, kunt u vormen maken of wijzigen in een Microsoft Word document. Een belangrijke eigenschap van een vorm is zijn ShapeType. Vormen van verschillende soorten kunnen verschillende mogelijkheden hebben in een Word-document. Bijvoorbeeld, alleen afbeeldingen en OLE-vormen kunnen beelden in zich hebben, terwijl de meeste vormen alleen tekst kunnen hebben.
Het volgende voorbeeld laat zien hoe je een vormafbeelding apart van het document naar een JPEG-afbeelding kunt renderen en opslaan op de schijf:
Een vormgrootte ophalen
De ShapeRenderer klasse biedt ook functionaliteit om de grootte van de vorm in pixels op te halen via de GetSizeInPixels methode. Deze methode accepteert twee float (Single) parameters, de schaal en DPI, die worden gebruikt bij de berekening van de vormgrootte wanneer de vorm wordt weergegeven. De methode geeft de Size object, dat de breedte en hoogte van de berekende grootte bevat. Dit is handig wanneer het nodig is om de grootte van de weergegeven vorm van tevoren te weten, bijvoorbeeld bij het maken van een nieuwe Bitmap van de weergegeven uitvoer.
Het onderstaande voorbeeld laat zien hoe je een nieuw Bitmap en Graphics object kunt maken met de breedte en hoogte van de te renderen vorm:
Bij gebruik van de RenderToSize of RenderToScale methoden, de weergegeven afbeelding grootte wordt ook teruggegeven in de SizeF object. Dit kan aan een variabele worden toegewezen en indien nodig worden gebruikt.
De SizeInPoints eigenschap geeft de vormgrootte terug gemeten in punten (zie ShapeRenderer). Het resultaat is een SizeF
object met de breedte en hoogte.