Clonar diapositivas de presentación en Android

Clonar diapositivas en una presentación

Clonar es el proceso de crear una copia exacta o réplica de algo. Aspose.Slides para Android mediante Java también permite crear 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 para Android mediante Java, (una colección de ISlide objetos) expuesta por el objeto Presentation proporciona los métodos addClone y insertClone para realizar los tipos de clonación de diapositivas mencionados anteriormente

Clonar una diapositiva al final 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:

  1. Cree una instancia de la clase Presentation.
  2. Instancie la clase ISlideCollection haciendo referencia a la colección Slides expuesta por el objeto Presentation.
  3. Llame al método addClone expuesto por el objeto ISlideCollection y pase la diapositiva que se va a clonar como parámetro al método addClone.
  4. Escriba el archivo de presentación modificado.

En el ejemplo que se muestra 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
Presentation pres = new Presentation("CloneWithinSamePresentationToEnd.pptx");
try {
    // Clonar la diapositiva deseada al final de la colección de diapositivas en la misma presentación
    ISlideCollection slds = pres.getSlides();

    slds.addClone(pres.getSlides().get_Item(0));

    // Escribir la presentación modificada en disco
    pres.save("Aspose_CloneWithinSamePresentationToEnd_out.pptx", SaveFormat.Pptx);
} finally {
    pres.dispose();
}

Clonar una diapositiva a otra posición dentro de una 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:

  1. Cree una instancia de la clase Presentation.
  2. Instancie la clase haciendo referencia a la colección Slides expuesta por el objeto Presentation.
  3. Llame al método insertClone expuesto por el objeto ISlideCollection y pase la diapositiva que se va a clonar junto con el índice para la nueva posición como parámetro al método insertClone.
  4. Escriba la presentación modificada como un archivo PPTX.

En el ejemplo que se muestra 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
Presentation pres = new Presentation("CloneWithInSamePresentation.pptx");
try {
    // Clonar la diapositiva deseada al final de la colección de diapositivas en la misma presentación
    ISlideCollection slds = pres.getSlides();

    // Clonar la diapositiva deseada al índice especificado en la misma presentación
    slds.insertClone(2, pres.getSlides().get_Item(1));

    // Escribir la presentación modificada en disco
    pres.save("Aspose_CloneWithInSamePresentation_out.pptx", SaveFormat.Pptx);
} finally {
    pres.dispose();
}

Clonar una diapositiva al final de otra presentación

Si necesita clonar una diapositiva de una presentación y usarla en otra presentación, al final de las diapositivas existentes:

  1. Cree una instancia de la clase Presentation que contenga la presentación de la cual se clonará la diapositiva.
  2. Cree una instancia de la clase Presentation que contenga la presentación de destino a la que se añadirá la diapositiva.
  3. Instancie la clase ISlideCollection haciendo referencia a la colección Slides expuesta por el objeto Presentation de la presentación de destino.
  4. Llame al método addClone expuesto por el objeto ISlideCollection y pase la diapositiva de la presentación origen como parámetro al método addClone.
  5. Escriba el archivo de presentación de destino modificado.

En el ejemplo que se muestra 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 de origen
Presentation srcPres = new Presentation("CloneAtEndOfAnother.pptx");
try {
    // Instanciar la clase Presentation para el PPTX de destino (donde se clonará la diapositiva)
    Presentation destPres = new Presentation();
    try {
        // Clonar la diapositiva deseada de la presentación de origen al final de la colección de diapositivas en la presentación de destino
        ISlideCollection slds = destPres.getSlides();

        slds.addClone(srcPres.getSlides().get_Item(0));

        // Guardar la presentación de destino en disco
        destPres.save("Aspose2_out.pptx", SaveFormat.Pptx);
    } finally {
        destPres.dispose();
    }
} finally {
    srcPres.dispose();
}

Clonar una diapositiva a 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:

  1. Cree una instancia de la clase Presentation que contenga la presentación origen de la cual se clonará la diapositiva.
  2. Cree una instancia de la clase Presentation que contenga la presentación a la que se añadirá la diapositiva.
  3. Instancie la clase ISlideCollection haciendo referencia a la colección Slides expuesta por el objeto Presentation de la presentación de destino.
  4. Llame al método insertClone expuesto por el objeto ISlideCollection y pase la diapositiva de la presentación origen junto con la posición deseada como parámetro al método insertClone.
  5. Escriba el archivo de presentación de destino modificado.

En el ejemplo que se muestra 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 de origen
Presentation srcPres = new Presentation("CloneAtEndOfAnother.pptx");
try {
    // Instanciar la clase Presentation para el PPTX de destino (donde se clonará la diapositiva)
    Presentation destPres = new Presentation();
    try {
        // Clonar la diapositiva deseada de la presentación de origen al final de la colección de diapositivas en la presentación de destino
        ISlideCollection slds = destPres.getSlides();

        slds.insertClone(2, srcPres.getSlides().get_Item(0));

        // Guardar la presentación de destino en disco
        destPres.save("Aspose2_out.pptx", SaveFormat.Pptx);
    } finally {
        destPres.dispose();
    }
} finally {
    srcPres.dispose();
}

Clonar una diapositiva 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 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 destino en lugar de la presentación origen. Para clonar la diapositiva con maestra, siga los pasos a continuación:

  1. Cree una instancia de la clase Presentation que contenga la presentación origen de la cual se clonará la diapositiva.
  2. Cree una instancia de la clase Presentation que contenga la presentación destino a la que se clonará la diapositiva.
  3. Acceda a la diapositiva que se va a clonar junto con la diapositiva maestra.
  4. Instancie la clase IMasterSlideCollection haciendo referencia a la colección Masters expuesta por el objeto Presentation de la presentación destino.
  5. Llame al método addClone expuesto por el objeto IMasterSlideCollection y pase la maestra del PPTX origen que se va a clonar como parámetro al método addClone.
  6. Instancie la clase ISlideCollection estableciendo la referencia a la colección Slides expuesta por el objeto Presentation de la presentación destino.
  7. Llame al método addClone expuesto por el objeto ISlideCollection 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.
  8. Escriba el archivo de presentación de destino modificado.

En el ejemplo que se muestra a continuación, hemos clonado una diapositiva con maestra (situada en el índice cero de la presentación origen) al final de la presentación destino usando una maestra de la diapositiva origen.

// Instanciar la clase Presentation para cargar el archivo de presentación de origen
Presentation srcPres = new Presentation("CloneToAnotherPresentationWithMaster.pptx");
try {
    // Instanciar la clase Presentation para la presentación de destino (donde se clonará la diapositiva)
    Presentation destPres = new Presentation();
    try {
        // Instanciar ISlide a partir de la colección de diapositivas de la presentación de origen junto con
        // diapositiva maestra
        ISlide SourceSlide = srcPres.getSlides().get_Item(0);
        IMasterSlide SourceMaster = SourceSlide.getLayoutSlide().getMasterSlide();

        // Clonar la diapositiva maestra deseada de la presentación de origen a la colección de maestras en la
        // presentación de destino
        IMasterSlideCollection masters = destPres.getMasters();
        IMasterSlide DestMaster = SourceSlide.getLayoutSlide().getMasterSlide();

        // Clonar la diapositiva maestra deseada de la presentación de origen a la colección de maestras en la
        // presentación de destino
        IMasterSlide iSlide = masters.addClone(SourceMaster);

        // Clonar la diapositiva deseada de la presentación de origen con la maestra deseada al final de la
        // colección de diapositivas de la presentación de destino
        ISlideCollection slds = destPres.getSlides();
        slds.addClone(SourceSlide, iSlide, true);

        // Guardar la presentación de destino en disco
        destPres.save("CloneToAnotherPresentationWithMaster_out.pptx", SaveFormat.Pptx);
    } finally {
        destPres.dispose();
    }
} finally {
    srcPres.dispose();
}

Clonar una diapositiva al final de 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 interfaz ISlideCollection. Aspose.Slides para Android mediante Java permite clonar una diapositiva de la primera sección y luego insertar esa diapositiva clonada en la segunda sección de la misma presentación.

El fragmento de código siguiente muestra cómo clonar una diapositiva e insertarla en una sección especificada.

IPresentation 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));

    ISection 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", 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 del 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 incrustado OLE), ese vínculo se conserva como un objeto OLE. Después de mover 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 para el 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.