Obtenir tous les liens hypertexte dans une présentation
Cette rubrique montre comment utiliser les classes du Kit de développement logiciel (SDK) Open XML pour Office pour obtenir tous les liens hypertexte externes d’une présentation par programmation.
Obtention d’un objet PresentationDocument
Dans le Kit de développement logiciel (SDK) Open XML, la PresentationDocument classe représente un package de document de présentation. Pour utiliser un document de présentation, commencez par créer un instance de la PresentationDocument
classe, puis utilisez cette instance. Pour créer la classe instance à partir du document, appelez la Open méthode qui utilise un chemin d’accès de fichier et une valeur booléenne comme deuxième paramètre pour spécifier si un document est modifiable. Définissez ce deuxième paramètre sur false
pour ouvrir le fichier pour un accès en lecture seule, ou true
si vous souhaitez ouvrir le fichier pour l’accès en lecture/écriture. Dans cette rubrique, il est préférable d’ouvrir le fichier pour un accès en lecture seule afin de le protéger contre toute tentative d’écriture accidentelle. L’instruction suivante using
ouvre le fichier pour un accès en lecture seule. Dans ce segment de code, le fileName
paramètre est une chaîne qui représente le chemin du fichier à partir duquel vous souhaitez ouvrir le document.
// Open the presentation file as read-only.
using (PresentationDocument document = PresentationDocument.Open(fileName, false))
Avec v3.0.0+ la Close() méthode a été supprimée au profit de l’instruction using.
Cela garantit que la Dispose() méthode est appelée automatiquement lorsque l’accolade fermante est atteinte. Le bloc qui suit l’instruction using
établit une étendue pour l’objet créé ou nommé dans l’instruction using
, dans ce cas document
.
Structure de document de présentation de base
La structure de base d’un PresentationML
document se compose d’un certain nombre de parties, parmi lesquelles la partie main qui contient la définition de présentation. Le texte suivant de la spécification ISO/IEC 29500 présente la forme globale d’un PresentationML
package.
La partie main d’un
PresentationML
package commence par un élément racine de présentation. Cet élément contient une présentation qui, à son tour, fait référence à une liste de diapositives, à une liste de diapositives master, à une liste de notes master et à un document master liste. La liste des diapositives référence toutes les diapositives de la présentation ; la liste de masques de diapositive référence tous les masques de diapositive utilisés dans la présentation ; le masque de pages de note contient des informations sur la mise en forme des pages de notes et le masque de document décrit comment un document se présente.Un document à distribuer est un ensemble imprimé de diapositives qui peut être distribué aux personnes de l’audience.
En plus de textes et de graphiques, chaque diapositive peut contenir des commentaires et des notes, peut avoir une disposition et peut faire partie d’une ou plusieurs présentations personnalisées. Un commentaire est une annotation destinée à la personne qui gère le jeu de diapositives de la présentation. Une note est un rappel ou un élément de texte destiné au présentateur ou à l’audience.
Les autres fonctionnalités qu’un
PresentationML
document peut inclure les suivantes : animation, audio, vidéo et transitions entre les diapositives.Un
PresentationML
document n’est pas stocké sous la forme d’un corps volumineux dans une seule partie. Au lieu de cela, les éléments qui implémentent certains groupes de fonctionnalités sont stockés dans des composants distincts. Par exemple, tous les auteurs d’un document sont stockés dans une partie d’auteurs, tandis que chaque diapositive a sa propre partie.ISO/IEC 29500 : 2016
L’exemple de code XML suivant représente une présentation qui contient deux diapositives ayant les numéros d’identification 267 et 256.
<p:presentation xmlns:p="…" … >
<p:sldMasterIdLst>
<p:sldMasterId
xmlns:rel="https://…/relationships" rel:id="rId1"/>
</p:sldMasterIdLst>
<p:notesMasterIdLst>
<p:notesMasterId
xmlns:rel="https://…/relationships" rel:id="rId4"/>
</p:notesMasterIdLst>
<p:handoutMasterIdLst>
<p:handoutMasterId
xmlns:rel="https://…/relationships" rel:id="rId5"/>
</p:handoutMasterIdLst>
<p:sldIdLst>
<p:sldId id="267"
xmlns:rel="https://…/relationships" rel:id="rId2"/>
<p:sldId id="256"
xmlns:rel="https://…/relationships" rel:id="rId3"/>
</p:sldIdLst>
<p:sldSz cx="9144000" cy="6858000"/>
<p:notesSz cx="6858000" cy="9144000"/>
</p:presentation>
À l’aide du Kit de développement logiciel (SDK) Open XML, vous pouvez créer une structure de document et du contenu à l’aide de classes fortement typées qui correspondent aux éléments PresentationML. Vous trouverez ces classes dans l’espace de noms . Le tableau suivant répertorie les noms de classes des classes qui correspondent aux sld
éléments , sldLayout
, sldMaster
et notesMaster
.
Élément PresentationML | Classe du Kit de développement logiciel (SDK) Open XML | Description |
---|---|---|
<sld/> |
Slide | Diapositive de présentation. Il s’agit de l’élément racine de SlidePart. |
<sldLayout/> |
SlideLayout | Mise en page des diapositives. Il s’agit de l’élément racine de SlideLayoutPart. |
<sldMaster/> |
SlideMaster | Masque des diapositives. Il s’agit de l’élément racine de SlideMasterPart. |
<notesMaster/> |
NotesMaster | Masque des pages de notes (ou handoutMaster). Il s’agit de l’élément racine de NotesMasterPart. |
Structure de l’élément hyperlink
Dans l’exemple de code de cette procédure, vous allez utiliser des liens hypertexte externes. Par conséquent, il convient de vous familiariser avec l’élément hyperlink. Le texte suivant de la spécification ISO/IEC 29500 présente la id
(cible de lien hypertexte).
Spécifie l’ID de la relation dont la cible doit être utilisée comme cible de ce lien hypertexte.
Si cet attribut est omis, cela signifie qu’il n’existe aucune cible de lien hypertexte externe pour le lien hypertexte actuel ; toutefois, un emplacement au sein du document actif peut représenter une cible via l’attribut anchor. Si cet attribut existe, il remplace la valeur de l’attribut anchor.
[Exemple : Considérez le fragment suivant
PresentationML
pour un lien hypertexte :
<w:hyperlink r:id="rId9">
<w:r>
<w:t>https://www.example.com</w:t>
</w:r>
</w:hyperlink>
La
id
valeur d’attribut derId9
spécifie que la relation dans l’élément de partie de relation associé avec une valeur d’attribut Id correspondante doit être parcourue lorsque ce lien hypertexte est appelé. Par exemple, si le code XML suivant est présent dans l’élément du composant Relation associé :
<Relationships xmlns="…">
<Relationship Id="rId9" Mode="External" Target="https://www.example.com" />
</Relationships>
La cible de ce lien hypertexte serait donc la cible de la relation
rId9
: dans ce cas, https://www.example.com. Fin de l’exemple]Les valeurs possibles de cet attribut sont définies par le type simple ST_RelationshipId (§22.8.2.1).
© ISO/IEC 29500 : 2016
Fonctionnement de l’exemple de code
L’exemple de code de cette rubrique comprend une méthode qui accepte le chemin d’accès complet du fichier de présentation en tant que paramètre. Il effectue une itération au sein de l’ensemble des diapositives de la présentation et retourne une liste des chaînes qui représentent les URI (Universal Resource Identifier) de tous les liens hypertexte externes de la présentation.
// Iterate through all the slide parts in the presentation part.
foreach (SlidePart slidePart in document.PresentationPart.SlideParts)
{
IEnumerable<Drawing.HyperlinkType> links = slidePart.Slide.Descendants<Drawing.HyperlinkType>();
// Iterate through all the links in the slide part.
foreach (Drawing.HyperlinkType link in links)
{
// Iterate through all the external relationships in the slide part.
foreach (HyperlinkRelationship relation in slidePart.HyperlinkRelationships)
{
// If the relationship ID matches the link ID…
if (relation.Id.Equals(link.Id))
{
// Add the URI of the external relationship to the list of strings.
ret.Add(relation.Uri.AbsoluteUri);
}
}
}
}
Exemple de code
Voici l’exemple de code complet qui vous permet de retourner la liste de tous les liens externes d’une présentation. Vous pouvez utiliser la boucle suivante dans votre programme pour appeler la GetAllExternalHyperlinksInPresentation
méthode afin d’obtenir la liste des URI de votre présentation.
if (args is [{ } fileName])
{
foreach (string link in GetAllExternalHyperlinksInPresentation(fileName))
{
Console.WriteLine(link);
}
}
Voici un exemple de code complet en C# et Visual Basic.
// Returns all the external hyperlinks in the slides of a presentation.
static IEnumerable<String> GetAllExternalHyperlinksInPresentation(string fileName)
{
// Declare a list of strings.
List<string> ret = new List<string>();
// Open the presentation file as read-only.
using (PresentationDocument document = PresentationDocument.Open(fileName, false))
{
// If there is no PresentationPart then there are no hyperlinks
if (document.PresentationPart is null)
{
return ret;
}
// Iterate through all the slide parts in the presentation part.
foreach (SlidePart slidePart in document.PresentationPart.SlideParts)
{
IEnumerable<Drawing.HyperlinkType> links = slidePart.Slide.Descendants<Drawing.HyperlinkType>();
// Iterate through all the links in the slide part.
foreach (Drawing.HyperlinkType link in links)
{
// Iterate through all the external relationships in the slide part.
foreach (HyperlinkRelationship relation in slidePart.HyperlinkRelationships)
{
// If the relationship ID matches the link ID…
if (relation.Id.Equals(link.Id))
{
// Add the URI of the external relationship to the list of strings.
ret.Add(relation.Uri.AbsoluteUri);
}
}
}
}
}
// Return the list of strings.
return ret;
}