Praca z obrazami

Aspose.Words pozwala użytkownikom pracować z obrazami w bardzo elastyczny sposób. W tym artykule możesz poznać tylko niektóre możliwości pracy z obrazami.

Jak wstawić obraz

DocumentBuilder zapewnia kilka przeciążeń metody InsertImage, które umożliwiają wstawienie obrazu wbudowanego lub pływającego. Jeśli obraz jest metaplikiem EMF lub WMF, zostanie wstawiony do dokumentu w formacie metapliku. Wszystkie pozostałe obrazy będą przechowywane w formacie PNG. Metoda InsertImage może wykorzystywać obrazy z różnych źródeł:

  • Z pliku lub URL, przekazując parametr String InsertImage
  • Ze strumienia poprzez przekazanie parametru Stream InsertImage
  • Z obiektu Image poprzez przekazanie parametru Image InsertImage
  • Z tablicy bajtów poprzez przekazanie parametru tablicy bajtów InsertImage

Dla każdej z metod InsertImage istnieją dalsze przeciążenia, które umożliwiają wstawienie obrazu z następującymi opcjami:

  • Inline lub pływający w określonej pozycji, na przykład InsertImage
  • Skala procentowa lub rozmiar niestandardowy, np. InsertImage; ponadto metoda InsertImage zwraca obiekt Shape, który właśnie został utworzony i wstawiony, dzięki czemu można dalej modyfikować właściwości kształtu

Jak wstawić obraz śródliniowy

Przekaż pojedynczy ciąg reprezentujący plik zawierający obraz do InsertImage, aby wstawić obraz do dokumentu jako grafikę wstawioną

Poniższy przykład kodu pokazuje, jak wstawić obraz osadzony w pozycji kursora do dokumentu:

Jak wstawić pływający obraz

Poniższy przykład kodu pokazuje, jak wstawić pływający obraz z pliku lub URL w określonej pozycji i rozmiarze:

Jak wyodrębnić obrazy z dokumentu

Wszystkie obrazy są przechowywane w węzłach Shape w formacie Document. Aby wyodrębnić z dokumentu wszystkie obrazy lub obrazy określonego typu, wykonaj następujące kroki:

  • Użyj metody GetChildNodes, aby wybrać wszystkie węzły Shape.
  • Iteruj po wynikowych kolekcjach węzłów.
  • Sprawdź właściwość logiczną HasImage.
  • Wyodrębnij dane obrazu za pomocą właściwości ImageData.
  • Zapisz dane obrazu w pliku.

Poniższy przykład kodu pokazuje, jak wyodrębnić obrazy z dokumentu i zapisać je jako pliki:

Jak wstawić kod kreskowy na każdej stronie dokumentu

Ten przykład pokazuje, jak dodać te same lub różne kody kreskowe na wszystkich lub określonych stronach dokumentu programu Word. Nie ma bezpośredniego sposobu dodawania kodów kreskowych na wszystkich stronach dokumentu, ale można użyć metod MoveToSection, MoveToHeaderFooter i InsertImage, aby przejść do dowolnej sekcji lub nagłówka/stopki i wstawić obrazy kodów kreskowych, jak widać w poniższym kodzie.

Poniższy przykład kodu pokazuje, jak wstawić obraz kodu kreskowego na każdej stronie dokumentu:

Zablokuj współczynnik proporcji obrazu

Proporcje kształtu geometrycznego to stosunek jego rozmiarów w różnych wymiarach. Możesz zablokować proporcje obrazu za pomocą AspectRatioLocked. Domyślna wartość współczynnika proporcji kształtu zależy od ShapeType. Jest to true dla ShapeType.Image i false dla innych typów kształtów.

Poniższy przykład kodu pokazuje, jak pracować ze współczynnikiem proporcji:

Jak uzyskać rzeczywiste granice kształtu w punktach

Jeśli chcesz, aby rzeczywista ramka ograniczająca kształt była renderowana na stronie, możesz to osiągnąć za pomocą właściwości BoundsInPoints.

Poniższy przykład kodu pokazuje, jak używać tej właściwości:

Przytnij obrazy

Kadrowanie obrazu zwykle oznacza usunięcie niepożądanych zewnętrznych części obrazu w celu poprawy kadrowania. Służy również do usuwania niektórych części obrazu w celu zwiększenia ostrości na określonym obszarze.

Poniższy przykład kodu pokazuje, jak to osiągnąć za pomocą Aspose.Words API:

Zapisz obrazy jako WMF

Aspose.Words zapewnia funkcję zapisywania wszystkich dostępnych obrazów w dokumencie do formatu WMF podczas konwersji DOCX do RTF.

Poniższy przykład kodu pokazuje, jak zapisywać obrazy w formacie WMF z opcjami zapisywania w formacie RTF: