Introducció
Aspose.Slides FOSS for Java is now available on Maven Central: a free, MIT-licensed library for creating, reading, and editing PowerPoint .pptx fitxers completament en Java, sense cap dependència de Microsoft Office ni cap entorn d’execució propietari.
La biblioteca està dissenyada per a desenvolupadors que necessiten generar o manipular fitxers de presentació de manera programàtica: automatitzar conjunts de diapositives a partir de dades, extreure text i metadades de fitxers PPTX pujats, construir canals de reportatge basats en presentacions, o incrustar la creació de presentacions en aplicacions Spring Boot. Perquè aspose-slides-foss és pur Java, es desplega de manera idèntica a Windows, macOS, Linux i contenidors Docker.
Funcionalitats clau
- Suport complet de viatge d’anada i tornada per a PPTX: Obre qualsevol
.pptxfitxer, modifica’n el contingut i desa’l de nou sense perdre les parts XML desconegudes que la biblioteca encara no entén. - Gestió de diapositives: Afegeix, elimina i itera diapositives utilitzant
prs.getSlides(); la presentació comença amb una diapositiva en blanc després denew Presentation(). - AutoShapes, Taules i Connectors: Insereix formes via
slide.getShapes().addAutoShape(), dades tabulars viaslide.getShapes().addTable(), i connectors visuals entre formes viaslide.getShapes().addConnector(). - Format de text enriquit: Formata el text a nivell de caràcter amb
PortionFormat: mida de la lletra, negreta, cursiva, subratllat i color ARGB viaFillType.SOLIDiColorFormat. - Tipus d’emplenament: Aplica
FillType.SOLID,GRADIENT,PATTERN, oPICTUREemplenaments a qualsevol forma. - Efectes visuals: Ombra exterior, resplendor, vora suau, difuminat, reflexió i ombra interior via
shape.getEffectFormat(). - 3D formatting: Bisel, càmera, equip de llum, material i profunditat d’extrusió via
shape.getThreeDFormat(). - Notes del presentador: Adjunta el text de les notes a cada diapositiva via
getNotesSlideManager().addNotesSlide(). - Comentaris en fil: Afegeix comentaris amb metadades d’autor i posició de la diapositiva.
- Imatges incrustades: Incrusta des del camí del fitxer, bytes o
InputStream. - Propietats del document: Llegeix i escriu propietats del nucli, de l’aplicació i personalitzades.
Començar
Afegeix la dependència Maven. Es requereix Java 21 o posterior.
<dependency>
<groupId>org.aspose.slides.foss</groupId>
<artifactId>aspose-slides-foss</artifactId>
<version>1.0.0</version>
</dependency>
Creeu la vostra primera presentació amb una forma i deseu-la:
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;
public class HelloSlides {
public static void main(String[] args) {
try (Presentation prs = new Presentation()) {
ISlide slide = prs.getSlides().get(0);
IAutoShape shape = slide.getShapes().addAutoShape(
ShapeType.RECTANGLE, 50, 50, 400, 120
);
shape.addTextFrame("Hello from Aspose.Slides FOSS!");
prs.save("hello.pptx");
}
}
}
Utilitza sempre Presentation dins d’un bloc try-with-resources; això assegura que tots els recursos interns es alliberen quan el bloc surt.
Exemple de formatatge de text
import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ITextFrame;
import org.aspose.slides.foss.IPortionFormat;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.FillType;
import org.aspose.slides.foss.NullableBool;
import org.aspose.slides.foss.export.SaveFormat;
import org.aspose.slides.foss.drawing.Color;
try (Presentation prs = new Presentation()) {
IAutoShape shape = prs.getSlides().get(0).getShapes().addAutoShape(
ShapeType.RECTANGLE, 50, 50, 500, 150
);
ITextFrame tf = shape.addTextFrame("Bold heading in corporate blue");
IPortionFormat fmt = tf.getParagraphs().get(0).getPortions().get(0).getPortionFormat();
fmt.setFontHeight(28);
fmt.setFontBold(NullableBool.TRUE);
fmt.getFillFormat().setFillType(FillType.SOLID);
fmt.getFillFormat().getSolidFillColor().setColor(new Color(0, 70, 127));
prs.save("formatted.pptx");
}
Limitacions actuals
Les àrees següents generen UnsupportedOperationException en aquesta versió:
- Gràfics, SmartArt i objectes OLE
- Animacions i transicions de diapositives
- Exportació a PDF, HTML, SVG o formats d’imatge
- Enllaços, configuracions d’acció, macros VBA i signatures digitals
Les parts XML desconegudes trobades durant la càrrega es conserven literalment en desar, de manera que els fitxers PPTX generats per altres eines es tornen a processar de manera segura.