Trabalhando com formas

Este tópico discute como trabalhar programaticamente com formas usando Aspose.Words.

As formas em Aspose.Words representam um objeto na camada de desenho, como uma AutoForma, caixa de texto, forma livre, objeto OLE, controle ActiveX ou imagem. Um documento do Word pode conter uma ou mais formas diferentes. As formas do documento são representadas pela classe Shape.

Inserindo formas usando o Document Builder

Você pode inserir uma forma embutida com tipo e tamanho especificados e uma forma flutuante com a posição, tamanho e tipo de quebra de texto especificados em um documento usando o método insert_shape. O método insert_shape permite inserir formato DML no modelo do documento. O documento deve ser salvo no formato que suporta formas DML, caso contrário, tais nós serão convertidos para a forma VML, durante o salvamento do documento.

O exemplo de código a seguir mostra como inserir esses tipos de formas no documento:

Definir proporção de aspecto bloqueada

Usando Aspose.Words, você pode especificar se a proporção da forma está bloqueada por meio da propriedade aspect_ratio_locked.

O exemplo de código a seguir mostra como trabalhar com a propriedade AspectRatioLocked:

Definir layout de forma na célula

Você também pode especificar se a forma será exibida dentro ou fora de uma tabela usando a propriedade is_layout_in_cell.

O exemplo de código a seguir mostra como trabalhar com a propriedade IsLayoutInCell:

Criar retângulo de canto de recorte

Você pode criar um retângulo de canto de recorte usando Aspose.Words. Os tipos de forma são SINGLE_CORNER_SNIPPED, TOP_CORNERS_SNIPPED, DIAGONAL_CORNERS_SNIPPED, TOP_CORNERS_ONE_ROUNDED_ONE_SNIPPED, SINGLE_CORNER_ROUNDED, TOP_CORNERS_ROUNDED e DIAGONAL_CORNERS_ROUNDED.

A forma DML é criada usando o método insert_shape com esses tipos de forma. Esses tipos não podem ser usados para criar formas VML. A tentativa de criar uma forma usando o construtor público da classe Shape gera a exceção “NotSupportedException”.

O exemplo de código a seguir mostra como inserir esses tipos de formas no documento:

Obtenha pontos reais de limites de forma

Usando Aspose.Words API, você pode obter a localização e o tamanho da forma que contém o bloco em pontos, em relação à âncora da forma superior. Para fazer isso, use a propriedade bounds_in_points.

O exemplo de código a seguir mostra como trabalhar com a propriedade BoundsInPoints:

Especifique a âncora vertical

Você pode especificar o alinhamento vertical do texto dentro de uma forma usando a propriedade vertical_anchor.

O exemplo de código a seguir mostra como trabalhar com a propriedade VerticalAnchor:

Detectar forma SmartArt

Aspose.Words também permite detectar se o Shape possui um objeto SmartArt. Para fazer isso, use a propriedade propriedade has_smart_art.

O exemplo de código a seguir mostra como trabalhar com a propriedade HasSmartArt:

Inserir regra horizontal no documento

Você pode inserir uma forma de regra horizontal em um documento usando o método insert_horizontal_rule.

O exemplo de código a seguir mostra como fazer isso:

Aspose.Words API fornece a propriedade horizontal_rule_format para acessar as propriedades da forma da regra horizontal. A classe HorizontalRuleFormat expõe propriedades básicas como height, color, no_shade etc. para a formatação de uma regra horizontal.

O exemplo de código a seguir demonstra como definir HorizontalRuleFormat:

Insira objeto OLE como um ícone

Aspose.Words API fornece função Forma.insert_ole_object_as_icon para inserir um objeto OLE incorporado ou vinculado como um ícone no documento. Esta função permite especificar o arquivo do ícone e a legenda. O tipo de objeto OLE deve ser detectado usando a extensão do arquivo.

O exemplo de código a seguir demonstra como definir a inserção do objeto OLE como um ícone no documento:

Importe formas com Math XML como formas para DOM

Você pode usar a propriedade convert_shape_to_office_math para converter as formas com EquationXML em objetos Office Math. O valor padrão desta propriedade corresponde ao comportamento do MS Word, ou seja, formas com equação XML não são convertidas em objetos matemáticos do Office.

O exemplo de código a seguir mostra como converter formas em objetos do Office Math: