Cloner les diapositives d'une présentation en PHP

Cloner des diapositives dans une présentation

Le clonage est le processus de création d’une copie exacte ou d’un replica de quelque chose. Aspose.Slides for PHP via Java rend également possible de créer une copie ou un clone de n’importe quelle diapositive, puis d’insérer cette diapositive clonée dans la présentation actuelle ou toute autre présentation ouverte. Le processus de clonage de diapositive crée une nouvelle diapositive qui peut être modifiée par les développeurs sans changer la diapositive d’origine. Il existe plusieurs façons possibles de cloner une diapositive :

  • Cloner à la fin dans une présentation.
  • Cloner à une autre position dans la présentation.
  • Cloner à la fin dans une autre présentation.
  • Cloner à une autre position dans une autre présentation.
  • Cloner à une position spécifique dans une autre présentation.

Dans Aspose.Slides for PHP via Java, (une collection d'Slide d’objets) exposée par l’objet Presentation fournit les méthodes addClone et insertClone pour effectuer les types de clonage de diapositive ci‑dessus.

Cloner une diapositive à la fin d’une présentation

Si vous souhaitez cloner une diapositive puis l’utiliser dans le même fichier de présentation à la fin des diapositives existantes, utilisez la méthode addClone selon les étapes ci‑dessous :

  1. Créez une instance de la classe Presentation.
  2. Obtenez l’objet SlideCollection en référencant la collection de diapositives exposée par l’objet Presentation.
  3. Appelez la méthode addClone exposée par l’objet SlideCollection et transmettez la diapositive à cloner en tant que paramètre à la méthode addClone.
  4. Enregistrez le fichier de présentation modifié.

Dans l’exemple ci‑dessous, nous avons cloné une diapositive (située à la première position – indice zéro – de la présentation) à la fin de la présentation.

  # Instancier la classe Presentation qui représente un fichier de présentation
  $pres = new Presentation("CloneWithinSamePresentationToEnd.pptx");
  try {
    # Cloner la diapositive souhaitée à la fin de la collection de diapositives dans la même présentation
    $slds = $pres->getSlides();
    $slds->addClone($pres->getSlides()->get_Item(0));
    # Enregistrer la présentation modifiée sur le disque
    $pres->save("Aspose_CloneWithinSamePresentationToEnd_out.pptx", SaveFormat::Pptx);
  } finally {
    $pres->dispose();
  }

Cloner une diapositive à une autre position dans une présentation

Si vous souhaitez cloner une diapositive puis l’utiliser dans le même fichier de présentation mais à une position différente, utilisez la méthode insertClone :

  1. Créez une instance de la classe Presentation.
  2. Obtenez l’objet SlideCollection en référencant la collection Slides exposée par l’objet Presentation.
  3. Appelez la méthode insertClone exposée par l’objet SlideCollection et transmettez la diapositive à cloner ainsi que l’indice de la nouvelle position en tant que paramètres à la méthode insertClone.
  4. Enregistrez la présentation modifiée au format PPTX.

Dans l’exemple ci‑dessous, nous avons cloné une diapositive (située à l’indice zéro – position 1 – de la présentation) à l’indice 1 – Position 2 – de la présentation.

  # Instancier la classe Presentation qui représente un fichier de présentation
  $pres = new Presentation("CloneWithInSamePresentation.pptx");
  try {
    # Cloner la diapositive souhaitée à la fin de la collection de diapositives dans la même présentation
    $slds = $pres->getSlides();
    # Cloner la diapositive souhaitée à l'index spécifié dans la même présentation
    $slds->insertClone(2, $pres->getSlides()->get_Item(1));
    # Enregistrer la présentation modifiée sur le disque
    $pres->save("Aspose_CloneWithInSamePresentation_out.pptx", SaveFormat::Pptx);
  } finally {
    $pres->dispose();
  }

Cloner une diapositive à la fin d’une autre présentation

Si vous devez cloner une diapositive d’une présentation et l’utiliser dans un autre fichier de présentation, à la fin des diapositives existantes :

  1. Créez une instance de la classe Presentation contenant la présentation dont la diapositive sera clonée.
  2. Créez une instance de la classe Presentation contenant la présentation de destination à laquelle la diapositive sera ajoutée.
  3. Obtenez l’objet SlideCollection en référencant la collection Slides exposée par l’objet Presentation de la présentation de destination.
  4. Appelez la méthode addClone exposée par l’objet SlideCollection et transmettez la diapositive de la présentation source en tant que paramètre à la méthode addClone.
  5. Enregistrez le fichier de présentation de destination modifié.

Dans l’exemple ci‑dessous, nous avons cloné une diapositive (à partir du premier indice de la présentation source) à la fin de la présentation de destination.

  # Instancier la classe Presentation pour charger le fichier de présentation source
  $srcPres = new Presentation("CloneAtEndOfAnother.pptx");
  try {
    # Instancier la classe Presentation pour le PPTX de destination (où la diapositive doit être clonée)
    $destPres = new Presentation();
    try {
      # Cloner la diapositive souhaitée de la présentation source à la fin de la collection de diapositives de la présentation de destination
      $slds = $destPres->getSlides();
      $slds->addClone($srcPres->getSlides()->get_Item(0));
      # Enregistrer la présentation de destination sur le disque
      $destPres->save("Aspose2_out.pptx", SaveFormat::Pptx);
    } finally {
      $destPres->dispose();
    }
  } finally {
    $srcPres->dispose();
  }

Cloner une diapositive à une autre position dans une autre présentation

Si vous devez cloner une diapositive d’une présentation et l’utiliser dans un autre fichier de présentation, à une position spécifique :

  1. Créez une instance de la classe Presentation contenant la présentation source dont la diapositive sera clonée.
  2. Créez une instance de la classe Presentation contenant la présentation de destination à laquelle la diapositive sera ajoutée.
  3. Obtenez la classe SlideCollection en référencant la collection Slides exposée par l’objet Presentation de la présentation de destination.
  4. Appelez la méthode insertClone exposée par l’objet SlideCollection et transmettez la diapositive de la présentation source ainsi que la position souhaitée en tant que paramètres à la méthode insertClone.
  5. Enregistrez le fichier de présentation de destination modifié.

Dans l’exemple ci‑dessus, nous avons cloné une diapositive (à partir de l’indice zéro de la présentation source) à l’indice 1 (position 2) de la présentation de destination.

  # Instancier la classe Presentation pour charger le fichier de présentation source
  $srcPres = new Presentation("CloneAtEndOfAnother.pptx");
  try {
    # Instancier la classe Presentation pour le PPTX de destination (où la diapositive doit être clonée)
    $destPres = new Presentation();
    try {
      # Cloner la diapositive souhaitée de la présentation source à la fin de la collection de diapositives de la présentation de destination
      $slds = $destPres->getSlides();
      $slds->insertClone(2, $srcPres->getSlides()->get_Item(0));
      # Enregistrer la présentation de destination sur le disque
      $destPres->save("Aspose2_out.pptx", SaveFormat::Pptx);
    } finally {
      $destPres->dispose();
    }
  } finally {
    $srcPres->dispose();
  }

Cloner une diapositive à une position spécifique dans une autre présentation

Si vous devez cloner une diapositive avec une diapositive maître d’une présentation et l’utiliser dans une autre présentation, vous devez d’abord cloner la diapositive maître souhaitée de la présentation source vers la présentation de destination. Ensuite, vous devez utiliser cette diapositive maître pour cloner la diapositive avec maître. La méthode addClone(Slide, MasterSlide, boolean) attend une diapositive maître de la présentation de destination plutôt que de la présentation source. Pour cloner la diapositive avec maître, suivez les étapes ci‑dessous :

  1. Créez une instance de la classe Presentation contenant la présentation source dont la diapositive sera clonée.
  2. Créez une instance de la classe Presentation contenant la présentation de destination vers laquelle la diapositive sera clonée.
  3. Accédez à la diapositive à cloner ainsi qu’à la diapositive maître.
  4. Instanciez la classe MasterSlideCollection en référencant la collection Masters exposée par l’objet Presentation de la présentation de destination.
  5. Appelez la méthode addClone exposée par l’objet MasterSlideCollection et transmettez le maître du PPTX source à cloner en tant que paramètre à la méthode addClone.
  6. Instanciez la classe SlideCollection en définissant la référence à la collection Slides exposée par l’objet Presentation de la présentation de destination.
  7. Appelez la méthode addClone exposée par l’objet SlideCollection et transmettez la diapositive de la présentation source à cloner ainsi que la diapositive maître en tant que paramètres à la méthode addClone.
  8. Enregistrez le fichier de présentation de destination modifié.

Dans l’exemple ci‑dessous, nous avons cloné une diapositive avec maître (située à l’indice zéro de la présentation source) à la fin de la présentation de destination en utilisant le maître de la diapositive source.

  # Instancier la classe Presentation pour charger le fichier de présentation source
  $srcPres = new Presentation("CloneToAnotherPresentationWithMaster.pptx");
  try {
    # Instancier la classe Presentation pour la présentation de destination (où la diapositive doit être clonée)
    $destPres = new Presentation();
    try {
      # Instancier ISlide à partir de la collection de diapositives de la présentation source ainsi que
      # Diapositive maître
      $SourceSlide = $srcPres->getSlides()->get_Item(0);
      $SourceMaster = $SourceSlide->getLayoutSlide()->getMasterSlide();
      # Cloner la diapositive maître souhaitée de la présentation source vers la collection de maîtres dans la
      # présentation de destination
      $masters = $destPres->getMasters();
      $DestMaster = $SourceSlide->getLayoutSlide()->getMasterSlide();
      # Cloner la diapositive maître souhaitée de la présentation source vers la collection de maîtres dans la
      # présentation de destination
      $iSlide = $masters->addClone($SourceMaster);
      # Cloner la diapositive souhaitée de la présentation source avec le maître souhaité à la fin de la
      # collection de diapositives de la présentation de destination
      $slds = $destPres->getSlides();
      $slds->addClone($SourceSlide, $iSlide, true);
      # Enregistrer la présentation de destination sur le disque
      $destPres->save("CloneToAnotherPresentationWithMaster_out.pptx", SaveFormat::Pptx);
    } finally {
      $destPres->dispose();
    }
  } finally {
    $srcPres->dispose();
  }

Cloner une diapositive à la fin d’une section spécifiée

Si vous souhaitez cloner une diapositive puis l’utiliser dans le même fichier de présentation mais dans une section différente, utilisez la méthode addClone exposée par la classe SlideCollection. Aspose.Slides for PHP via Java permet de cloner une diapositive de la première section puis d’insérer cette diapositive clonée dans la deuxième section de la même présentation.

Le fragment de code suivant montre comment cloner une diapositive et insérer la diapositive clonée dans une section spécifiée.

  $presentation = new Presentation();
  try {
    $presentation->getSlides()->get_Item(0)->getShapes()->addAutoShape(ShapeType::Rectangle, 200, 50, 300, 100);
    $presentation->getSections()->addSection("Section 1", $presentation->getSlides()->get_Item(0));
    $section2 = $presentation->getSections()->appendEmptySection("Section 2");
    $presentation->getSlides()->addClone($presentation->getSlides()->get_Item(0), $section2);
    # Enregistrer la présentation de destination sur le disque
    $presentation->save($dataDir . "CloneSlideIntoSpecifiedSection.pptx", SaveFormat::Pptx);
  } finally {
    if (!java_is_null($presentation)) {
      $presentation->dispose();
    }
  }

FAQ

Les notes du présentateur et les commentaires des réviseurs sont-ils clonés ?

Oui. La page de notes et les commentaires de révision sont inclus dans le clone. Si vous ne les voulez pas, supprimez‑les après l’insertion.

Comment les graphiques et leurs sources de données sont‑ils gérés ?

L’objet graphique, son formatage et les données intégrées sont copiés. Si le graphique était lié à une source externe (par ex., un classeur OLE intégré), ce lien est conservé sous forme d'objet OLE. Après le déplacement entre fichiers, vérifiez la disponibilité des données et le comportement de rafraîchissement.

Puis‑je contrôler la position d’insertion et les sections du clone ?

Oui. Vous pouvez insérer le clone à un indice de diapositive spécifique et le placer dans une section choisie. Si la section cible n’existe pas, créez‑la d’abord puis déplacez la diapositive dedans.