Filigrane

À propos des Filigranes

Un filigrane dans une présentation est une empreinte textuelle ou image utilisée sur une diapositive ou sur l’ensemble des diapositives de la présentation. En général, un filigrane est utilisé pour indiquer que la présentation est un brouillon (par exemple, un filigrane “Brouillon”), qu’elle contient des informations confidentielles (par exemple, un filigrane “Confidentiel”), pour spécifier à quelle entreprise cela appartient (par exemple, un filigrane “Nom de l’Entreprise”), pour identifier l’auteur de la présentation, etc. Un filigrane aide à prévenir les violations de droits d’auteur en indiquant que la présentation ne doit pas être copiée. Les filigranes sont utilisés à la fois dans les formats de présentation PowerPoint et OpenOffice. Dans Aspose.Slides, vous pouvez ajouter un filigrane aux formats de fichiers PowerPoint PPT, PPTX et OpenOffice ODP.

Dans Aspose.Slides, il existe diverses façons de créer des filigranes dans les documents PowerPoint ou OpenOffice et de modifier leur conception et leur comportement. L’aspect commun est que pour ajouter des filigranes texte, vous devez utiliser l’interface ITextFrame, et pour ajouter des filigranes image, utilisez la classe PictureFrame ou remplissez une forme de filigrane avec une image. PictureFrame implémente l’interface IShape, vous permettant d’utiliser tous les paramètres flexibles de l’objet forme. Étant donné que ITextFrame n’est pas une forme et que ses paramètres sont limités, il est encapsulé dans un objet IShape.

Il existe deux façons d’appliquer un filigrane : à une seule diapositive ou à toutes les diapositives de la présentation. Le Master Slide est utilisé pour appliquer un filigrane à toutes les diapositives de la présentation — le filigrane est ajouté au Master Slide, entièrement conçu là-bas, et appliqué à toutes les diapositives sans affecter la permission de modifier le filigrane sur les diapositives individuelles.

Un filigrane est généralement considéré comme non modifiable par d’autres utilisateurs. Pour empêcher que le filigrane (ou plutôt la forme parente du filigrane) soit modifié, Aspose.Slides fournit une fonctionnalité de verrouillage des formes. Une forme spécifique peut être verrouillée sur une diapositive normale ou sur un Master Slide. Lorsque la forme du filigrane est verrouillée sur le Master Slide, elle sera verrouillée sur toutes les diapositives de présentation.

Vous pouvez définir un nom pour le filigrane afin qu’à l’avenir, si vous souhaitez le supprimer, vous puissiez le trouver dans les formes de la diapositive par son nom.

Vous pouvez concevoir le filigrane de n’importe quelle manière ; cependant, il existe généralement des caractéristiques communes dans les filigranes, telles que l’alignement central, la rotation, la position devant, etc. Nous allons examiner comment utiliser ces caractéristiques dans les exemples ci-dessous.

Filigrane Texte

Ajouter un Filigrane Texte à une Diapositive

Pour ajouter un filigrane texte dans PPT, PPTX ou ODP, vous pouvez d’abord ajouter une forme à la diapositive, puis ajouter un cadre de texte à cette forme. Le cadre de texte est représenté par l’interface ITextFrame. Ce type n’est pas hérité de IShape, qui dispose d’un ensemble large de propriétés pour positionner le filigrane de manière flexible. Par conséquent, l’objet ITextFrame est encapsulé dans un objet IAutoShape. Pour ajouter le texte de filigrane à la forme, utilisez la méthode AddTextFrame comme montré ci-dessous.

string watermarkText = "CONFIDENTIEL";

using Presentation presentation = new Presentation();
ISlide slide = presentation.Slides[0];

IAutoShape watermarkShape = slide.Shapes.AddAutoShape(ShapeType.Rectangle, 100, 100, 400, 40);
ITextFrame watermarkFrame = watermarkShape.AddTextFrame(watermarkText);

Ajouter un Filigrane Texte à une Présentation

Si vous souhaitez ajouter un filigrane texte à l’ensemble de la présentation (c’est-à-dire toutes les diapositives en une seule fois), ajoutez-le au MasterSlide. Le reste de la logique est le même que lorsque vous ajoutez un filigrane à une seule diapositive — créez un objet IAutoShape et ajoutez-lui le filigrane à l’aide de la méthode AddTextFrame.

string watermarkText = "CONFIDENTIEL";

using Presentation presentation = new Presentation();
IMasterSlide masterSlide = presentation.Masters[0];

IAutoShape watermarkShape = masterSlide.Shapes.AddAutoShape(ShapeType.Rectangle, 100, 100, 400, 40);
ITextFrame watermarkFrame = watermarkShape.AddTextFrame(watermarkText);

Définir la Transparence de la Forme de Filigrane

Par défaut, la forme rectangle est stylée avec des couleurs de remplissage et de ligne. Les lignes de code suivantes rendent la forme transparente.

watermarkShape.FillFormat.FillType = FillType.NoFill;
watermarkShape.LineFormat.FillFormat.FillType = FillType.NoFill;

Définir la Police pour un Filigrane Texte

Vous pouvez changer la police du filigrane texte comme montré ci-dessous.

IPortionFormat textFormat = watermarkFrame.Paragraphs[0].ParagraphFormat.DefaultPortionFormat;
textFormat.LatinFont = new FontData("Arial");
textFormat.FontHeight = 50;

Définir la Couleur du Texte du Filigrane

Pour définir la couleur du texte du filigrane, utilisez ce code :

int alpha = 150, red = 200, green = 200, blue = 200;

IFillFormat fillFormat = watermarkFrame.Paragraphs[0].ParagraphFormat.DefaultPortionFormat.FillFormat;
fillFormat.FillType = FillType.Solid;
fillFormat.SolidFillColor.Color = Color.FromArgb(alpha, red, green, blue);

Centrer un Filigrane Texte

Il est possible de centrer le filigrane sur une diapositive, et pour cela, vous pouvez faire ce qui suit :

SizeF slideSize = presentation.SlideSize.Size;

float watermarkWidth = 400;
float watermarkHeight = 40;
float watermarkX = (slideSize.Width - watermarkWidth) / 2;
float watermarkY = (slideSize.Height - watermarkHeight) / 2;

IAutoShape watermarkShape = slide.Shapes.AddAutoShape(
    ShapeType.Rectangle, watermarkX, watermarkY, watermarkWidth, watermarkHeight);

ITextFrame watermarkFrame = watermarkShape.AddTextFrame(watermarkText);

L’image ci-dessous montre le résultat final.

Le filigrane texte

Filigrane Image

Ajouter un Filigrane Image à une Présentation

Pour ajouter un filigrane image à une diapositive de présentation, vous pouvez faire ce qui suit :

using FileStream imageStream = File.OpenRead("watermark.png");
IPPImage image = presentation.Images.AddImage(imageStream);

watermarkShape.FillFormat.FillType = FillType.Picture;
watermarkShape.FillFormat.PictureFillFormat.Picture.Image = image;
watermarkShape.FillFormat.PictureFillFormat.PictureFillMode = PictureFillMode.Stretch;

Verrouiller un Filigrane contre les Modifications

S’il est nécessaire d’empêcher qu’un filigrane soit modifié, utilisez la propriété IAutoShape.ShapeLock sur la forme. Avec cette propriété, vous pouvez protéger la forme contre la sélection, le redimensionnement, le repositionnement, le regroupement avec d’autres éléments, verrouiller son texte contre l’édition, et bien plus encore :

// Verrouiller la forme du filigrane contre les modifications
watermarkShape.ShapeLock.SelectLocked = true;
watermarkShape.ShapeLock.SizeLocked = true;
watermarkShape.ShapeLock.TextLocked = true;
watermarkShape.ShapeLock.PositionLocked = true;
watermarkShape.ShapeLock.GroupingLocked = true;

Amener un Filigrane au Premier Plan

Dans Aspose.Slides, l’ordre Z des formes peut être défini via la méthode IShapeCollection.Reorder. Pour ce faire, vous devez appeler cette méthode à partir de la liste des diapositives de présentation et passer la référence de la forme et son numéro d’ordre à la méthode. De cette manière, il est possible d’amener une forme au premier plan ou de l’envoyer à l’arrière-plan de la diapositive. Cette fonctionnalité est particulièrement utile si vous devez placer un filigrane devant la présentation :

int shapeCount = slide.Shapes.Count;
slide.Shapes.Reorder(shapeCount - 1, watermarkShape);

Définir la Rotation du Filigrane

Voici un exemple de code sur la façon d’ajuster la rotation du filigrane afin qu’il soit positionné en diagonale à travers la diapositive :

double diagonalAngle = Math.Atan((slideSize.Height / slideSize.Width)) * 180 / Math.PI;

watermarkShape.Rotation = (float)diagonalAngle;

Définir un Nom pour un Filigrane

Aspose.Slides vous permet de définir le nom d’une forme. En utilisant le nom de la forme, vous pouvez y accéder à l’avenir pour la modifier ou la supprimer. Pour définir le nom de la forme de filigrane, assignez-le à la propriété IAutoShape.Name :

watermarkShape.Name = "filigrane";

Supprimer un Filigrane

Pour supprimer la forme de filigrane, utilisez la propriété IAutoShape.Name pour la trouver dans les formes de la diapositive. Ensuite, passez la forme de filigrane à la méthode IShapeCollection.Remove :

List<IShape> slideShapes = slide.Shapes.ToList();
foreach (IShape shape in slideShapes)
{
    if (string.Compare(shape.Name, "filigrane", StringComparison.Ordinal) == 0)
    {
        slide.Shapes.Remove(watermarkShape);
    }
}

Un Exemple en Direct

Vous pouvez consulter les outils en ligne gratuits Aspose.Slides Ajouter un Filigrane et Supprimer un Filigrane.

Outils en ligne pour ajouter et supprimer des filigranes