Macros/Writer/003/fr

Description
On souhaite gérer par programme la définition des bordures d'un tableau ou d'une cellule.

Les bordures sont accessibles via la propriété ''' com.sun.star. table.TableBorder'''.

Les éléments de cette structure sont de deux types :
 * Des bordures (haut, bas, gauche, droite, horizontale, verticale) ; les bordures sont des structures  com.sun.star. table.BorderLine2 qui "ajoutent" les éléments de style à la structure  com.sun.star. table.BorderLine.
 * Des booléens (IsLeftLineValid, IsRightLineValid, IsTopLineValid, etc.). En écriture, les définir à True pour modifier la ligne correspondante et à False pour l'ignorer, autrement dit pour garder sa valeur actuelle.

La définition de l'espacement avec le contenu se fait via la propriété ''' com.sun.star. table.TableBorderDistances''' de la table. Là encore il s'agit d'une structure bâtie selon le même principe : BottomDistance, LeftDistance, etc. et des booléens pour gérer la modification ou non.

La procédure suivante s'applique au tableau courant :
 * On commence par tester que le curseur figure bien dans un tableau.
 * L'objectif est de remplacer les bordures actuelles (les paramètres Is... sont définis à True) pour obtenir un encadrement extérieur et des lignes horizontales doubles. En revanche on ne veut pas de lignes verticales. Il faut en conséquence .IsVerticalLineValid = true et VerticalLine = LibONoLine, une structure définie pour appliquer une ligne "vide". On ne peut simplement utiliser .IsVerticalLineValid = false car le tableau courant peut avoir des lignes verticales définies et on désire les supprimer. Avec le paramètre false les lignes existantes seraient laissées dans leur état actuel.
 * L'espacement avec le contenu désiré est 0,30cm.
 * Le paramètre Fusionner les styles de ligne adjacents se définit par la propriété CollapsingBorders de la table.

Code
En LibreOffice Basic:

Fichier ODT pour tester la macro

 * [[Media:FR.MACROS Writer 003 GererBordures.odt|Télécharger un document exemple]]