Clonar diapositivas
Clonar diapositivas en una presentación
Clonar es el proceso de crear una copia exacta o réplica de algo. Aspose.Slides for Node.js via Java también permite hacer una copia o clon de cualquier diapositiva y luego insertar esa diapositiva clonada en la presentación actual o en cualquier otra presentación abierta. El proceso de clonación de diapositivas crea una nueva diapositiva que los desarrolladores pueden modificar sin cambiar la diapositiva original. Existen varias formas posibles de clonar una diapositiva:
- Clonar al final dentro de una presentación.
- Clonar en otra posición dentro de la presentación.
- Clonar al final en otra presentación.
- Clonar en otra posición en otra presentación.
- Clonar en una posición específica en otra presentación.
En Aspose.Slides for Node.js via Java, (una colección de Diapositiva objetos) expuesta por el objeto Presentation proporciona los métodos addClone y insertClone para realizar los tipos anteriores de clonación de diapositivas
Clonar al final dentro de una presentación
Si desea clonar una diapositiva y luego usarla dentro del mismo archivo de presentación al final de las diapositivas existentes, utilice el método addClone siguiendo los pasos enumerados a continuación:
- Cree una instancia de la clase Presentation.
- Instancie la clase SlideCollection haciendo referencia a la colección Slides expuesta por el objeto Presentation.
- Llame al método addClone expuesto por el objeto SlideCollection y pase la diapositiva a clonar como parámetro al método addClone.
- Escriba el archivo de presentación modificado.
En el ejemplo a continuación, hemos clonado una diapositiva (situada en la primera posición – índice cero – de la presentación) al final de la presentación.
// Instanciar la clase Presentation que representa un archivo de presentación
var pres = new aspose.slides.Presentation("CloneWithinSamePresentationToEnd.pptx");
try {
// Clonar la diapositiva deseada al final de la colección de diapositivas en la misma presentación
var slds = pres.getSlides();
slds.addClone(pres.getSlides().get_Item(0));
// Guardar la presentación modificada en disco
pres.save("Aspose_CloneWithinSamePresentationToEnd_out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
pres.dispose();
}
Clonar en otra posición dentro de la presentación
Si desea clonar una diapositiva y luego usarla dentro del mismo archivo de presentación pero en una posición diferente, utilice el método insertClone:
- Cree una instancia de la clase Presentation.
- Instancie la clase haciendo referencia a la colección Slides expuesta por el objeto Presentation.
- Llame al método insertClone expuesto por el objeto SlideCollection y pase la diapositiva a clonar junto con el índice para la nueva posición como parámetro al método insertClone.
- Escriba la presentación modificada como un archivo PPTX.
En el ejemplo a continuación, hemos clonado una diapositiva (situada en el índice cero – posición 1 – de la presentación) al índice 1 – Posición 2 – de la presentación.
// Instanciar la clase Presentation que representa un archivo de presentación
var pres = new aspose.slides.Presentation("CloneWithInSamePresentation.pptx");
try {
// Clonar la diapositiva deseada al final de la colección de diapositivas en la misma presentación
var slds = pres.getSlides();
// Clonar la diapositiva deseada al índice especificado en la misma presentación
slds.insertClone(2, pres.getSlides().get_Item(1));
// Guardar la presentación modificada en disco
pres.save("Aspose_CloneWithInSamePresentation_out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
pres.dispose();
}
Clonar al final en otra presentación
Si necesita clonar una diapositiva de una presentación y usarla en otra presentación, al final de las diapositivas existentes:
- Cree una instancia de la clase Presentation que contenga la presentación de la cual se clonará la diapositiva.
- Cree una instancia de la clase Presentation que contenga la presentación de destino a la que se añadirá la diapositiva.
- Instancie la clase SlideCollection haciendo referencia a la colección Slides expuesta por el objeto Presentation de la presentación de destino.
- Llame al método addClone expuesto por el objeto SlideCollection y pase la diapositiva de la presentación origen como parámetro al método addClone.
- Escriba el archivo de presentación de destino modificado.
En el ejemplo a continuación, hemos clonado una diapositiva (del primer índice de la presentación origen) al final de la presentación de destino.
// Instanciar la clase Presentation para cargar el archivo de presentación fuente
var srcPres = new aspose.slides.Presentation("CloneAtEndOfAnother.pptx");
try {
// Instanciar la clase Presentation para el PPTX de destino (donde se clonará la diapositiva)
var destPres = new aspose.slides.Presentation();
try {
// Clonar la diapositiva deseada de la presentación origen al final de la colección de diapositivas en la presentación de destino
var slds = destPres.getSlides();
slds.addClone(srcPres.getSlides().get_Item(0));
// Guardar la presentación de destino en disco
destPres.save("Aspose2_out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
destPres.dispose();
}
} finally {
srcPres.dispose();
}
Clonar en otra posición en otra presentación
Si necesita clonar una diapositiva de una presentación y usarla en otra presentación, en una posición específica:
- Cree una instancia de la clase Presentation que contenga la presentación origen de la cual se clonará la diapositiva.
- Cree una instancia de la clase Presentation que contenga la presentación a la que se añadirá la diapositiva.
- Instancie la clase SlideCollection haciendo referencia a la colección Slides expuesta por el objeto Presentation de la presentación de destino.
- Llame al método insertClone expuesto por el objeto SlideCollection y pase la diapositiva de la presentación origen junto con la posición deseada como parámetro al método insertClone.
- Escriba el archivo de presentación de destino modificado.
En el ejemplo a continuación, hemos clonado una diapositiva (del índice cero de la presentación origen) al índice 1 (posición 2) de la presentación de destino.
// Instanciar la clase Presentation para cargar el archivo de presentación fuente
var srcPres = new aspose.slides.Presentation("CloneAtEndOfAnother.pptx");
try {
// Instanciar la clase Presentation para el PPTX de destino (donde se clonará la diapositiva)
var destPres = new aspose.slides.Presentation();
try {
// Clonar la diapositiva deseada de la presentación origen al final de la colección de diapositivas en la presentación de destino
var slds = destPres.getSlides();
slds.insertClone(2, srcPres.getSlides().get_Item(0));
// Guardar la presentación de destino en disco
destPres.save("Aspose2_out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
destPres.dispose();
}
} finally {
srcPres.dispose();
}
Clonar en una posición específica en otra presentación
Si necesita clonar una diapositiva con una diapositiva maestra de una presentación y usarla en otra presentación, primero debe clonar la diapositiva maestra deseada de la presentación origen a la presentación de destino. Luego debe usar esa diapositiva maestra para clonar la diapositiva con maestra. El método addClone(ISlide, IMasterSlide, boolean) espera una diapositiva maestra de la presentación de destino en lugar de la presentación origen. Para clonar la diapositiva con maestra, siga los pasos a continuación:
- Cree una instancia de la clase Presentation que contenga la presentación origen de la cual se clonará la diapositiva.
- Cree una instancia de la clase Presentation que contenga la presentación de destino a la que se clonará la diapositiva.
- Acceda a la diapositiva a clonar junto con la diapositiva maestra.
- Instancie la clase MasterSlideCollection haciendo referencia a la colección Masters expuesta por el objeto Presentation de la presentación de destino.
- Llame al método addClone expuesto por el objeto MasterSlideCollection y pase la maestra del PPTX origen que se va a clonar como parámetro al método addClone.
- Instancie la clase SlideCollection estableciendo la referencia a la colección Slides expuesta por el objeto Presentation de la presentación de destino.
- Llame al método addClone expuesto por el objeto SlideCollection y pase la diapositiva de la presentación origen que se va a clonar y la diapositiva maestra como parámetros al método addClone.
- Escriba el archivo de presentación de destino modificado.
En el ejemplo a continuación, hemos clonado una diapositiva con una maestra (situada en el índice cero de la presentación origen) al final de la presentación de destino usando una maestra de la diapositiva origen.
// Instanciar la clase Presentation para cargar el archivo de presentación fuente
var srcPres = new aspose.slides.Presentation("CloneToAnotherPresentationWithMaster.pptx");
try {
// Instanciar la clase Presentation para la presentación de destino (donde se clonará la diapositiva)
var destPres = new aspose.slides.Presentation();
try {
// Instanciar ISlide de la colección de diapositivas en la presentación fuente junto con
// diapositiva maestra
var SourceSlide = srcPres.getSlides().get_Item(0);
var SourceMaster = SourceSlide.getLayoutSlide().getMasterSlide();
// Clonar la diapositiva maestra deseada de la presentación fuente a la colección de maestros en la
// presentación de destino
var masters = destPres.getMasters();
var DestMaster = SourceSlide.getLayoutSlide().getMasterSlide();
// Clonar la diapositiva maestra deseada de la presentación fuente a la colección de maestros en la
// presentación de destino
var iSlide = masters.addClone(SourceMaster);
// Clonar la diapositiva deseada de la presentación fuente con la maestra deseada al final de la
// colección de diapositivas en la presentación de destino
var slds = destPres.getSlides();
slds.addClone(SourceSlide, iSlide, true);
// Guardar la presentación de destino en disco
destPres.save("CloneToAnotherPresentationWithMaster_out.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
destPres.dispose();
}
} finally {
srcPres.dispose();
}
Clonar al final en una sección especificada
Si desea clonar una diapositiva y luego usarla dentro del mismo archivo de presentación pero en una sección diferente, utilice el método addClone expuesto por la clase SlideCollection. Aspose.Slides for Node.js via Java permite clonar una diapositiva de la primera sección e insertarla en la segunda sección de la misma presentación.
El siguiente fragmento de código muestra cómo clonar una diapositiva e insertar la diapositiva clonada en una sección especificada.
var presentation = new aspose.slides.Presentation();
try {
presentation.getSlides().get_Item(0).getShapes().addAutoShape(aspose.slides.ShapeType.Rectangle, 200, 50, 300, 100);
presentation.getSections().addSection("Section 1", presentation.getSlides().get_Item(0));
var section2 = presentation.getSections().appendEmptySection("Section 2");
presentation.getSlides().addClone(presentation.getSlides().get_Item(0), section2);
// Guardar la presentación de destino en disco
presentation.save(dataDir + "CloneSlideIntoSpecifiedSection.pptx", aspose.slides.SaveFormat.Pptx);
} finally {
if (presentation != null) {
presentation.dispose();
}
}
FAQ
¿Se clonan las notas del orador y los comentarios del revisor?
Sí. La página de notas y los comentarios de revisión se incluyen en el clon. Si no los desea, elimínelos después de la inserción.
¿Cómo se manejan los gráficos y sus fuentes de datos?
El objeto de gráfico, su formato y los datos incrustados se copian. Si el gráfico estaba vinculado a una fuente externa (por ejemplo, un libro de trabajo OLE incrustado), ese vínculo se conserva como un objeto OLE. Después de moverlo entre archivos, verifique la disponibilidad de los datos y el comportamiento de actualización.
¿Puedo controlar la posición de inserción y las secciones del clon?
Sí. Puede insertar el clon en un índice de diapositiva específico y colocarlo en una sección elegida. Si la sección de destino no existe, créela primero y luego mueva la diapositiva a ella.