org.docx4j.openpackaging.parts.PresentationML.MainPresentationPart Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of docx4j Show documentation
Show all versions of docx4j Show documentation
docx4j is a library which helps you to work with the Office Open
XML file format as used in docx
documents, pptx presentations, and xlsx spreadsheets.
/*
* Copyright 2007-2008, Plutext Pty Ltd.
*
* This file is part of docx4j.
docx4j is licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package org.docx4j.openpackaging.parts.PresentationML;
import java.util.List;
import javax.xml.bind.JAXBException;
import org.apache.commons.lang3.NotImplementedException;
import org.docx4j.XmlUtils;
import org.docx4j.dml.CTPositiveSize2D;
import org.docx4j.openpackaging.exceptions.Docx4JException;
import org.docx4j.openpackaging.exceptions.InvalidFormatException;
import org.docx4j.openpackaging.parts.Part;
import org.docx4j.openpackaging.parts.PartName;
import org.docx4j.openpackaging.parts.relationships.Namespaces;
import org.docx4j.openpackaging.parts.relationships.RelationshipsPart.AddPartBehaviour;
import org.docx4j.relationships.Relationship;
import org.pptx4j.Pptx4jException;
import org.pptx4j.jaxb.Context;
import org.pptx4j.model.SlideSizesWellKnown;
import org.pptx4j.pml.ObjectFactory;
import org.pptx4j.pml.Presentation;
import org.pptx4j.pml.Presentation.SldIdLst.SldId;
public final class MainPresentationPart extends JaxbPmlPart {
public MainPresentationPart(PartName partName) throws InvalidFormatException {
super(partName);
init();
}
public MainPresentationPart() throws InvalidFormatException {
super(new PartName("/ppt/presentation.xml"));
init();
}
public void init() {
// Used if this Part is added to [Content_Types].xml
setContentType(new org.docx4j.openpackaging.contenttype.ContentType(
org.docx4j.openpackaging.contenttype.ContentTypes.PRESENTATIONML_MAIN));
// Used when this Part is added to a rels
setRelationshipType(Namespaces.PRESENTATIONML_MAIN);
}
private final static String DEFAULT_SLIDE_SIZE = "";
private final static String DEFAULT_NOTES_SIZE = "";
private CommentAuthorsPart commentAuthorsPart;
public boolean setPartShortcut(Part part) {
if (part == null ){
return false;
} else {
return setPartShortcut(part, part.getRelationshipType() );
}
}
public boolean setPartShortcut(Part part, String relationshipType) {
// Since each part knows its relationshipsType,
// why is this passed in as an arg?
// Answer: where the relationshipType is ascertained
// from the rel itself, it is the most authoritative.
// Note that we normally use the info in [Content_Types]
// to create a part of the correct type. This info
// will not necessary correspond to the info in the rel!
if (relationshipType==null) {
log.warn("trying to set part shortcut against a null relationship type.");
return false;
}
if (relationshipType.equals(Namespaces.PRESENTATIONML_COMMENT_AUTHORS)) {
commentAuthorsPart = (CommentAuthorsPart)part;
return true;
} else {
return false;
}
}
/**
* @since 3.2.0
*/
public CommentAuthorsPart getCommentAuthorsPart() {
return commentAuthorsPart;
}
/**
* @since 2.7
*/
public static Presentation.SldSz createSlideSize(SlideSizesWellKnown sz,
boolean landscape) {
Presentation.SldSz sldSz = Context.getpmlObjectFactory()
.createPresentationSldSz();
if (sz.equals(SlideSizesWellKnown.LETTER)) {
sldSz.setType("letter");
if (landscape) {
sldSz.setCx(9144000);
sldSz.setCy(6858000);
} else {
sldSz.setCx(6858000);
sldSz.setCy(9144000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.A3)) {
sldSz.setType("A3");
if (landscape) {
sldSz.setCx(12801600);
sldSz.setCy(9601200);
} else {
sldSz.setCx(9601200);
sldSz.setCy(12801600);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.A4)) {
sldSz.setType("A4");
if (landscape) {
sldSz.setCx(9906000);
sldSz.setCy(6858000);
} else {
sldSz.setCx(6858000);
sldSz.setCy(9906000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.SCREEN4x3)) {
sldSz.setType("screen4x3");
if (landscape) {
sldSz.setCx(9144000);
sldSz.setCy(6858000);
} else {
sldSz.setCx(6858000);
sldSz.setCy(9144000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.SCREEN16x9)) {
sldSz.setType("screen16x9");
if (landscape) {
sldSz.setCx(9144000);
sldSz.setCy(5143500);
} else {
sldSz.setCx(5143500);
sldSz.setCy(9144000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.SCREEN16x10)) {
sldSz.setType("screen16x10");
if (landscape) {
sldSz.setCx(9144000);
sldSz.setCy(5715000);
} else {
sldSz.setCx(5715000);
sldSz.setCy(9144000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.LEDGER)) {
sldSz.setType("ledger");
if (landscape) {
sldSz.setCx(12179300);
sldSz.setCy(9134475);
} else {
sldSz.setCx(9134475);
sldSz.setCy(12179300);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.B4ISO)) {
sldSz.setType("B4ISO");
if (landscape) {
sldSz.setCx(10826750);
sldSz.setCy(8120063);
} else {
sldSz.setCx(8120063);
sldSz.setCy(10826750);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.B5ISO)) {
sldSz.setType("B5ISO");
if (landscape) {
sldSz.setCx(7169150);
sldSz.setCy(5376863);
} else {
sldSz.setCx(5376863);
sldSz.setCy(7169150);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.MM35)) {
sldSz.setType("35mm");
if (landscape) {
sldSz.setCx(10287000);
sldSz.setCy(6858000);
} else {
sldSz.setCx(6858000);
sldSz.setCy(10287000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.OVERHEAD)) {
sldSz.setType("overhead");
if (landscape) {
sldSz.setCx(9144000);
sldSz.setCy(6858000);
} else {
sldSz.setCx(6858000);
sldSz.setCy(9144000);
}
return sldSz;
}
if (sz.equals(SlideSizesWellKnown.BANNER)) {
sldSz.setType("banner");
if (landscape) {
sldSz.setCx(7315200);
sldSz.setCy(914400);
} else {
sldSz.setCx(914400);
sldSz.setCy(7315200);
}
return sldSz;
}
throw new NotImplementedException("No support for slide size "
+ sz.value());
}
public static Presentation createJaxbPresentationElement() throws JAXBException {
return createJaxbPresentationElement(null, true);
}
/**
* @since 2.7
*/
public static Presentation createJaxbPresentationElement(SlideSizesWellKnown sz, boolean landscape) throws JAXBException {
ObjectFactory factory = Context.getpmlObjectFactory();
Presentation presentation = factory.createPresentation();
// Create empty lists
Presentation.SldMasterIdLst masterIds = factory.createPresentationSldMasterIdLst();
Presentation.SldIdLst slideIds = factory.createPresentationSldIdLst();
presentation.setSldMasterIdLst(masterIds);
presentation.setSldIdLst(slideIds);
presentation.setNotesSz(
(CTPositiveSize2D)XmlUtils.unmarshalString(DEFAULT_NOTES_SIZE, Context.jcPML, CTPositiveSize2D.class) );
if (sz==null) {
presentation.setSldSz(
(Presentation.SldSz)XmlUtils.unmarshalString(DEFAULT_SLIDE_SIZE, Context.jcPML, Presentation.SldSz.class));
} else {
presentation.setSldSz( MainPresentationPart.createSlideSize(sz, landscape) );
}
return presentation;
}
/**
* Add a slide to this presentation.
*
* @param slidePart
* @return
* @throws InvalidFormatException
*/
public Presentation.SldIdLst.SldId addSlideIdListEntry(SlidePart slidePart) throws InvalidFormatException {
return addSlideIdListEntry(slidePart, AddPartBehaviour.OVERWRITE_IF_NAME_EXISTS);
}
/**
* @since 2.8.1
*/
@Deprecated
public Presentation.SldIdLst.SldId addSlideIdListEntry(SlidePart slidePart, AddPartBehaviour mode)
throws InvalidFormatException {
Relationship rel = this.addTargetPart(slidePart, mode);
Presentation.SldIdLst.SldId entry = Context.getpmlObjectFactory().createPresentationSldIdLstSldId();
entry.setId( this.getSlideId() );
entry.setRid(rel.getId());
this.getJaxbElement().getSldIdLst().getSldId().add(entry);
return entry;
}
public Presentation.SldMasterIdLst.SldMasterId addSlideMasterIdListEntry(SlideMasterPart slideMasterPart)
throws InvalidFormatException {
Relationship rel = this.addTargetPart(slideMasterPart);
Presentation.SldMasterIdLst.SldMasterId entry = Context.getpmlObjectFactory().createPresentationSldMasterIdLstSldMasterId();
entry.setId( new Long(this.getSlideLayoutOrMasterId()) );
entry.setRid(rel.getId());
this.getJaxbElement().getSldMasterIdLst().getSldMasterId().add(entry);
return entry;
}
/**
* Append the slide at the end of the presentation.
* @param slidePart
* @throws Pptx4jException
* @since 3.0
*/
public boolean addSlide(SlidePart slidePart) throws Pptx4jException {
/* Powerpoint 2010 can't open a pptx in which a slide appears
* several times, for example:
*
<----- can't use rId2 again
*
* Nor can 2 distinct relIds target the same part.
*/
try {
Relationship rel = this.addTargetPart(slidePart, AddPartBehaviour.RENAME_IF_NAME_EXISTS);
return this.getJaxbElement().getSldIdLst().getSldId().add(createSlideIdListEntry(rel));
} catch (InvalidFormatException e) {
throw new Pptx4jException(e.getMessage(), e);
}
}
/**
* Inserts the slide at the specified position in the presentation.
* Shifts the element currently at that position (if any) and any subsequent elements to the
* right (adds one to their indices).
*
* @param index
* @param slidePart
* @throws Pptx4jException
* @since 3.0
*/
public void addSlide(int index, SlidePart slidePart) throws Pptx4jException {
List sldIds = this.getJaxbElement().getSldIdLst().getSldId();
int zeroBasedCount = sldIds.size();
if (index< 0 || index>zeroBasedCount) {
throw new Pptx4jException("Can't add slide at index " + index + ". (There are " + sldIds.size() + " slides) ");
}
try {
Relationship rel = this.addTargetPart(slidePart, AddPartBehaviour.RENAME_IF_NAME_EXISTS);
sldIds.add(index, createSlideIdListEntry(rel));
} catch (InvalidFormatException e) {
throw new Pptx4jException(e.getMessage(), e);
}
}
private Presentation.SldIdLst.SldId createSlideIdListEntry(Relationship rel) throws InvalidFormatException {
Presentation.SldIdLst.SldId entry = Context.getpmlObjectFactory().createPresentationSldIdLstSldId();
entry.setId( this.getSlideId() );
entry.setRid(rel.getId());
return entry;
}
/**
* @param index
* @throws Pptx4jException
* @since 3.0
*/
public void removeSlide(int index) throws Pptx4jException {
List sldIds = this.getJaxbElement().getSldIdLst().getSldId();
int zeroBasedCount = sldIds.size() -1;
if (index< 0 || index>zeroBasedCount) {
throw new Pptx4jException("No slide at index " + index + ". (There are " + sldIds.size() + " slides) ");
}
Presentation.SldIdLst.SldId entry = this.getJaxbElement().getSldIdLst().getSldId().remove(index);
Relationship rel = this.getRelationshipsPart().getRelationshipByID(entry.getRid());
Part part = this.getRelationshipsPart().getPart(rel);
this.getPackage().getParts().remove(part.getPartName());
this.getRelationshipsPart().removeRelationship(rel);
}
/**
* @param rel
* @throws Pptx4jException
* @since 3.0
*/
public void removeSlide(Relationship rel) throws Pptx4jException {
if (rel==null) throw new Pptx4jException("Null relationship.");
int index = -1;
int i=0;
for (Presentation.SldIdLst.SldId entry : this.getJaxbElement().getSldIdLst().getSldId()) {
if (entry.getRid().equals(rel.getId())) {
index = i;
break;
}
i++;
}
if (index>-1) {
removeSlide(index);
} else {
throw new Pptx4jException("No slide is the target of that relationship.");
}
}
/**
* @param index
* @throws Pptx4jException
* @since 3.0.1
*/
public SlidePart getSlide(int index) throws Pptx4jException {
ensureContent();
ensureSldIdLst();
List sldIds = this.getJaxbElement().getSldIdLst().getSldId();
int zeroBasedCount = sldIds.size() -1;
if (index< 0 || index>zeroBasedCount) {
throw new Pptx4jException("No slide at index " + index + ". (There are " + sldIds.size() + " slides) ");
}
try {
Presentation.SldIdLst.SldId entry = this.getJaxbElement().getSldIdLst().getSldId().get(index);
return (SlidePart)this.getRelationshipsPart().getPart(entry.getRid());
} catch (Exception e) {
throw new Pptx4jException("Slide " + index + " not found", e);
}
}
private void ensureContent() throws Pptx4jException {
try {
if (this.getContents()==null ) {
throw new Pptx4jException("MainPresentationPart has no content");
}
} catch (Docx4JException e) {
throw new Pptx4jException(e.getMessage(), e);
}
}
private void ensureSldIdLst() throws Pptx4jException {
try {
if (this.getContents().getSldIdLst()==null) {
throw new Pptx4jException("SldIdLst missing from MainPresentationPart");
}
} catch (Docx4JException e) {
throw new Pptx4jException(e.getMessage(), e);
}
}
/**
* @param index
* @throws Pptx4jException
* @since 3.2.0
*/
public int getSlideCount() throws Pptx4jException {
ensureContent();
ensureSldIdLst();
List sldIds = this.getJaxbElement().getSldIdLst().getSldId();
return sldIds.size();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy