/* * 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.dml; import java.util.ArrayList; import java.util.List; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlElements; import javax.xml.bind.annotation.XmlType; /** * <p>Java class for CT_Path2D complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="CT_Path2D"> * <complexContent> * <restriction base="{http://www.w3.org/2001/XMLSchema}anyType"> * <choice maxOccurs="unbounded" minOccurs="0"> * <element name="close" type="{http://schemas.openxmlformats.org/drawingml/2006/main}CT_Path2DClose"/> * <element name="moveTo" type="{http://schemas.openxmlformats.org/drawingml/2006/main}CT_Path2DMoveTo"/> * <element name="lnTo" type="{http://schemas.openxmlformats.org/drawingml/2006/main}CT_Path2DLineTo"/> * <element name="arcTo" type="{http://schemas.openxmlformats.org/drawingml/2006/main}CT_Path2DArcTo"/> * <element name="quadBezTo" type="{http://schemas.openxmlformats.org/drawingml/2006/main}CT_Path2DQuadBezierTo"/> * <element name="cubicBezTo" type="{http://schemas.openxmlformats.org/drawingml/2006/main}CT_Path2DCubicBezierTo"/> * </choice> * <attribute name="w" type="{http://schemas.openxmlformats.org/drawingml/2006/main}ST_PositiveCoordinate" default="0" /> * <attribute name="h" type="{http://schemas.openxmlformats.org/drawingml/2006/main}ST_PositiveCoordinate" default="0" /> * <attribute name="fill" type="{http://schemas.openxmlformats.org/drawingml/2006/main}ST_PathFillMode" default="norm" /> * <attribute name="stroke" type="{http://www.w3.org/2001/XMLSchema}boolean" default="true" /> * <attribute name="extrusionOk" type="{http://www.w3.org/2001/XMLSchema}boolean" default="true" /> * </restriction> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "CT_Path2D", propOrder = { "closeOrMoveToOrLnTo" }) public class CTPath2D { @XmlElements({ @XmlElement(name = "lnTo", type = CTPath2DLineTo.class), @XmlElement(name = "quadBezTo", type = CTPath2DQuadBezierTo.class), @XmlElement(name = "arcTo", type = CTPath2DArcTo.class), @XmlElement(name = "close", type = CTPath2DClose.class), @XmlElement(name = "moveTo", type = CTPath2DMoveTo.class), @XmlElement(name = "cubicBezTo", type = CTPath2DCubicBezierTo.class) }) protected List<Object> closeOrMoveToOrLnTo; @XmlAttribute protected Long w; @XmlAttribute protected Long h; @XmlAttribute protected STPathFillMode fill; @XmlAttribute protected Boolean stroke; @XmlAttribute protected Boolean extrusionOk; /** * Gets the value of the closeOrMoveToOrLnTo property. * * <p> * This accessor method returns a reference to the live list, * not a snapshot. Therefore any modification you make to the * returned list will be present inside the JAXB object. * This is why there is not a <CODE>set</CODE> method for the closeOrMoveToOrLnTo property. * * <p> * For example, to add a new item, do as follows: * <pre> * getCloseOrMoveToOrLnTo().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link CTPath2DLineTo } * {@link CTPath2DQuadBezierTo } * {@link CTPath2DArcTo } * {@link CTPath2DClose } * {@link CTPath2DMoveTo } * {@link CTPath2DCubicBezierTo } * * */ public List<Object> getCloseOrMoveToOrLnTo() { if (closeOrMoveToOrLnTo == null) { closeOrMoveToOrLnTo = new ArrayList<Object>(); } return this.closeOrMoveToOrLnTo; } /** * Gets the value of the w property. * * @return * possible object is * {@link Long } * */ public long getW() { if (w == null) { return 0L; } else { return w; } } /** * Sets the value of the w property. * * @param value * allowed object is * {@link Long } * */ public void setW(Long value) { this.w = value; } /** * Gets the value of the h property. * * @return * possible object is * {@link Long } * */ public long getH() { if (h == null) { return 0L; } else { return h; } } /** * Sets the value of the h property. * * @param value * allowed object is * {@link Long } * */ public void setH(Long value) { this.h = value; } /** * Gets the value of the fill property. * * @return * possible object is * {@link STPathFillMode } * */ public STPathFillMode getFill() { if (fill == null) { return STPathFillMode.NORM; } else { return fill; } } /** * Sets the value of the fill property. * * @param value * allowed object is * {@link STPathFillMode } * */ public void setFill(STPathFillMode value) { this.fill = value; } /** * Gets the value of the stroke property. * * @return * possible object is * {@link Boolean } * */ public boolean isStroke() { if (stroke == null) { return true; } else { return stroke; } } /** * Sets the value of the stroke property. * * @param value * allowed object is * {@link Boolean } * */ public void setStroke(Boolean value) { this.stroke = value; } /** * Gets the value of the extrusionOk property. * * @return * possible object is * {@link Boolean } * */ public boolean isExtrusionOk() { if (extrusionOk == null) { return true; } else { return extrusionOk; } } /** * Sets the value of the extrusionOk property. * * @param value * allowed object is * {@link Boolean } * */ public void setExtrusionOk(Boolean value) { this.extrusionOk = value; } }