Convertir PPT y PPTX a PDF en Android [Funciones avanzadas incluidas]
Visión general
Convertir presentaciones de PowerPoint (PPT, PPTX, ODP, etc.) a formato PDF en Android ofrece varias ventajas, entre ellas la compatibilidad con distintos dispositivos y la preservación del diseño y formato de su presentación. Esta guía muestra cómo convertir presentaciones a documentos PDF, usar distintas opciones para controlar la calidad de imagen, incluir diapositivas ocultas, proteger con contraseña los archivos PDF, detectar sustituciones de fuentes, seleccionar diapositivas específicas para la conversión y aplicar normas de cumplimiento a los documentos resultantes.
Conversiones de PowerPoint a PDF
Con Aspose.Slides, puede convertir presentaciones en los siguientes formatos a PDF:
- PPT
- PPTX
- ODP
Para convertir una presentación a PDF, pase el nombre del archivo como argumento a la clase Presentation y luego guarde la presentación como PDF usando un método save. La clase Presentation expone el método save que se utiliza típicamente para convertir una presentación a PDF.
NOTE
Aspose.Slides for Android via Java inserta su información de API y el número de versión en los documentos de salida. Por ejemplo, al convertir una presentación a PDF, Aspose.Slides rellena el campo Application con “Aspose.Slides” y el campo PDF Producer con un valor en formato “Aspose.Slides v XX.XX”. Note que no puede indicarle a Aspose.Slides que cambie o elimine esta información de los documentos de salida.Aspose.Slides le permite convertir:
- Presentaciones completas a PDF
- Diapositivas específicas de una presentación a PDF
Aspose.Slides exporta presentaciones a PDF, asegurando que los PDFs resultantes coincidan estrechamente con las presentaciones originales. Los elementos y atributos se renderizan con precisión en la conversión, incluyendo:
- Imágenes
- Cajas de texto y formas
- Formato de texto
- Formato de párrafo
- Hipervínculos
- Encabezados y pies de página
- Viñetas
- Tablas
Convertir PowerPoint a PDF
El proceso estándar de conversión de PowerPoint a PDF utiliza opciones predeterminadas. En este caso, Aspose.Slides intenta convertir la presentación proporcionada a PDF usando configuraciones óptimas en los niveles máximos de calidad.
Este código muestra cómo convertir una presentación (PPT, PPTX, ODP, etc.) a PDF:
// Instanciar la clase Presentation que representa un archivo PowerPoint o OpenDocument.
Presentation presentation = new Presentation("PowerPoint.ppt");
try {
// Guardar la presentación como PDF.
presentation.save("PPT-to-PDF.pdf", SaveFormat.Pdf);
} finally {
presentation.dispose();
}
Convertir PowerPoint a PDF con opciones
Aspose.Slides proporciona opciones personalizadas —propiedades bajo la clase PdfOptions— que le permiten personalizar el PDF resultante, bloquear el PDF con una contraseña o especificar cómo debe proceder el proceso de conversión.
Convertir PowerPoint a PDF con opciones personalizadas
Con opciones de conversión personalizadas, puede definir su configuración de calidad preferida para imágenes raster, especificar cómo se deben manejar los metarchivos, establecer un nivel de compresión para texto, configurar DPI para imágenes y más.
El ejemplo de código a continuación muestra cómo convertir una presentación de PowerPoint a PDF con varias opciones personalizadas.
// Instanciar la clase PdfOptions.
PdfOptions pdfOptions = new PdfOptions();
// Set the quality for JPG images.
// Establecer la calidad para imágenes JPG.
pdfOptions.setJpegQuality((byte)90);
// Set DPI for images.
// Establecer DPI para imágenes.
pdfOptions.setSufficientResolution(300);
/// Set the behavior for metafiles.
/// Establecer el comportamiento para metarchivos.
pdfOptions.setSaveMetafilesAsPng(true);
// Set the text compression level for textual content.
// Establecer el nivel de compresión de texto para el contenido textual.
pdfOptions.setTextCompression(PdfTextCompression.Flate);
// Define the PDF compliance mode.
// Definir el modo de cumplimiento PDF.
pdfOptions.setCompliance(PdfCompliance.Pdf15);
// Instantiate the Presentation class that represents a PowerPoint or OpenDocument file.
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// Save the presentation as a PDF document.
// Guardar la presentación como documento PDF.
presentation.save("PowerPoint-to-PDF.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
Convertir PowerPoint a PDF con diapositivas ocultas
Si una presentación contiene diapositivas ocultas, puede usar el método setShowHiddenSlides de la clase PdfOptions para incluir las diapositivas ocultas como páginas en el PDF resultante.
Este código muestra cómo convertir una presentación de PowerPoint a PDF incluyendo las diapositivas ocultas:
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// Instanciar la clase PdfOptions.
PdfOptions pdfOptions = new PdfOptions();
// Añadir diapositivas ocultas.
pdfOptions.setShowHiddenSlides(true);
// Guardar la presentación como PDF.
presentation.save("PowerPoint-to-PDF.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
Convertir PowerPoint a PDF protegido con contraseña
Este código demuestra cómo convertir una presentación de PowerPoint en un PDF protegido con contraseña usando los parámetros de protección de la clase PdfOptions:
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// Instanciar la clase PdfOptions.
PdfOptions pdfOptions = new PdfOptions();
// Establecer una contraseña PDF y permisos de acceso.
pdfOptions.setPassword("password");
pdfOptions.setAccessPermissions(PdfAccessPermissions.PrintDocument | PdfAccessPermissions.HighQualityPrint);
// Guardar la presentación como PDF.
presentation.save("PPTX-to-PDF.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
Detectar sustituciones de fuentes
Aspose.Slides proporciona el método setWarningCallback bajo la clase PdfOptions, lo que le permite detectar sustituciones de fuentes durante el proceso de conversión de presentación a PDF.
Este código muestra cómo detectar sustituciones de fuentes:
public static void main(String[] args) {
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("sample.pptx");
// Establecer la devolución de llamada de advertencia en las opciones PDF.
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.setWarningCallback(new FontSubstitutionHandler());
// Guardar la presentación como PDF.
presentation.save("output.pdf", SaveFormat.Pdf, pdfOptions);
}
// Implementación de la devolución de llamada de advertencia.
private static class FontSubstitutionHandler implements IWarningCallback {
public int warning(IWarningInfo warning) {
if (warning.getWarningType() == WarningType.DataLoss &&
warning.getDescription().startsWith("Font will be substituted")) {
System.out.println("Font substitution warning: " + warning.getDescription());
}
return ReturnAction.Continue;
}
}
Convertir diapositivas seleccionadas de PowerPoint a PDF
Este código demuestra cómo convertir solo diapositivas específicas de una presentación de PowerPoint a PDF:
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("PowerPoint.pptx");
try {
// Establecer la matriz de números de diapositivas.
int[] slides = { 1, 3 };
// Guardar la presentación como PDF.
presentation.save("PPTX-to-PDF.pdf", slides, SaveFormat.Pdf);
} finally {
presentation.dispose();
}
Convertir PowerPoint a PDF con tamaño de diapositiva personalizado
Este código demuestra cómo convertir una presentación de PowerPoint a PDF con un tamaño de diapositiva especificado:
float slideWidth = 612;
float slideHeight = 792;
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("SelectedSlides.pptx");
// Crear una nueva presentación con un tamaño de diapositiva ajustado.
Presentation resizedPresentation = new Presentation();
try {
// Establecer el tamaño de diapositiva personalizado.
resizedPresentation.getSlideSize().setSize(slideWidth, slideHeight, SlideSizeScaleType.EnsureFit);
// Clonar la primera diapositiva de la presentación original.
ISlide slide = presentation.getSlides().get_Item(0);
resizedPresentation.getSlides().insertClone(0, slide);
// Guardar la presentación redimensionada como PDF con notas.
resizedPresentation.save("PDF_with_notes.pdf", SaveFormat.Pdf);
} finally {
resizedPresentation.dispose();
presentation.dispose();
}
Convertir PowerPoint a PDF en vista de notas de diapositiva
Este código demuestra cómo convertir una presentación de PowerPoint a un PDF que incluye notas:
// Instanciar la clase Presentation que representa un archivo PowerPoint u OpenDocument.
Presentation presentation = new Presentation("SelectedSlides.pptx");
try {
// Configurar las opciones PDF con diseño de notas.
NotesCommentsLayoutingOptions notesOptions = new NotesCommentsLayoutingOptions();
notesOptions.setNotesPosition(NotesPositions.BottomFull);
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.setSlidesLayoutOptions(notesOptions);
// Guardar la presentación como PDF con notas.
presentation.save("PDF_with_notes.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
Accesibilidad y normas de cumplimiento para PDF
Aspose.Slides le permite usar un procedimiento de conversión que cumple con las Directrices de Accesibilidad al Contenido Web (WCAG). Puede exportar un documento de PowerPoint a PDF utilizando cualquiera de estas normas de cumplimiento: PDF/A1a, PDF/A1b y PDF/UA.
Este código muestra un proceso de conversión de PowerPoint a PDF que produce varios PDFs basados en diferentes normas de cumplimiento:
Presentation presentation = new Presentation("pres.pptx");
try {
PdfOptions pdfOptions = new PdfOptions();
pdfOptions.setCompliance(PdfCompliance.PdfA1a);
presentation.save("pres-a1a-compliance.pdf", SaveFormat.Pdf, pdfOptions);
pdfOptions.setCompliance(PdfCompliance.PdfA1b);
presentation.save("pres-a1b-compliance.pdf", SaveFormat.Pdf, pdfOptions);
pdfOptions.setCompliance(PdfCompliance.PdfUa);
presentation.save("pres-ua-compliance.pdf", SaveFormat.Pdf, pdfOptions);
} finally {
presentation.dispose();
}
Note
Aspose.Slides admite operaciones de conversión a PDF, lo que permite convertir archivos PDF a formatos de archivo populares. Puede realizar conversiones de PDF a HTML, PDF a imagen, PDF a JPG y PDF a PNG. Otras operaciones de conversión de PDF a formatos especializados —PDF a SVG, PDF a TIFF, y PDF a XML— también están soportadas.Note: Al exportar a PDF/UA, Aspose.Slides trata los gráficos complejos como SmartArt, diagramas y fórmulas como una única figura. Los elementos de ruta individuales no se conservan como contenido separado y pueden marcarse como artefactos; el texto alternativo se proporciona solo para la figura completa.
Preguntas frecuentes
¿Puedo convertir varios archivos de PowerPoint a PDF en lote?
Sí, Aspose.Slides admite la conversión por lotes de varios archivos PPT o PPTX a PDF. Puede iterar a través de sus archivos y aplicar el proceso de conversión programáticamente.
¿Es posible proteger con contraseña el PDF convertido?
Absolutamente. Use la clase PdfOptions para establecer una contraseña y definir permisos de acceso durante el proceso de conversión.
¿Cómo incluyo diapositivas ocultas en el PDF?
Utilice el método setShowHiddenSlides en la clase PdfOptions para incluir las diapositivas ocultas en el PDF resultante.
¿Puede Aspose.Slides mantener alta calidad de imagen en el PDF?
Sí, puede controlar la calidad de imagen usando métodos como setJpegQuality y setSufficientResolution en la clase PdfOptions para garantizar imágenes de alta calidad en su PDF.
¿Aspose.Slides admite normas de cumplimiento PDF/A?
Sí, Aspose.Slides le permite exportar PDFs que cumplen con varias normas, incluyendo PDF/A1a, PDF/A1b y PDF/UA, asegurando que sus documentos cumplan con requisitos de accesibilidad y archivado.