Home » openjdk-7 » javax » print » attribute » standard » [javadoc | source]

    1   /*
    2    * Copyright (c) 2000, 2004, Oracle and/or its affiliates. All rights reserved.
    3    * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
    4    *
    5    * This code is free software; you can redistribute it and/or modify it
    6    * under the terms of the GNU General Public License version 2 only, as
    7    * published by the Free Software Foundation.  Oracle designates this
    8    * particular file as subject to the "Classpath" exception as provided
    9    * by Oracle in the LICENSE file that accompanied this code.
   10    *
   11    * This code is distributed in the hope that it will be useful, but WITHOUT
   12    * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   13    * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
   14    * version 2 for more details (a copy is included in the LICENSE file that
   15    * accompanied this code).
   16    *
   17    * You should have received a copy of the GNU General Public License version
   18    * 2 along with this work; if not, write to the Free Software Foundation,
   19    * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
   20    *
   21    * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
   22    * or visit www.oracle.com if you need additional information or have any
   23    * questions.
   24    */
   25   package javax.print.attribute.standard;
   26   
   27   import javax.print.attribute.Attribute;
   28   import javax.print.attribute.DocAttribute;
   29   import javax.print.attribute.EnumSyntax;
   30   import javax.print.attribute.PrintRequestAttribute;
   31   import javax.print.attribute.PrintJobAttribute;
   32   
   33   /**
   34    * Class Media is a printing attribute class that specifies the
   35    * medium on which to print.
   36    * <p>
   37    * Media may be specified in different ways.
   38    * <ul>
   39    * <li> it may be specified by paper source - eg paper tray
   40    * <li> it may be specified by a standard size - eg "A4"
   41    * <li> it may be specified by a name - eg "letterhead"
   42    * </ul>
   43    * Each of these corresponds to the IPP "media" attribute.
   44    * The current API does not support describing media by characteristics
   45    * (eg colour, opacity).
   46    * This may be supported in a later revision of the specification.
   47    * <p>
   48    * A Media object is constructed with a value which represents
   49    * one of the ways in which the Media attribute can be specified.
   50    * <p>
   51    * <B>IPP Compatibility:</B>  The category name returned by
   52    * <CODE>getName()</CODE> is the IPP attribute name.  The enumeration's
   53    * integer value is the IPP enum value.  The <code>toString()</code> method
   54    * returns the IPP string representation of the attribute value.
   55    * <P>
   56    *
   57    * @author Phil Race
   58    */
   59   public abstract class Media extends EnumSyntax
   60       implements DocAttribute, PrintRequestAttribute, PrintJobAttribute {
   61   
   62       private static final long serialVersionUID = -2823970704630722439L;
   63   
   64       /**
   65        * Constructs a new media attribute specified by name.
   66        *
   67        * @param value         a value
   68        */
   69       protected Media(int value) {
   70              super (value);
   71       }
   72   
   73       /**
   74        * Returns whether this media attribute is equivalent to the passed in
   75        * object. To be equivalent, all of the following conditions must be true:
   76        * <OL TYPE=1>
   77        * <LI>
   78        * <CODE>object</CODE> is not null.
   79        * <LI>
   80        * <CODE>object</CODE> is of the same subclass of Media as this object.
   81        * <LI>
   82        * The values are equal.
   83        * </OL>
   84        *
   85        * @param  object  Object to compare to.
   86        *
   87        * @return  True if <CODE>object</CODE> is equivalent to this media
   88        *          attribute, false otherwise.
   89        */
   90       public boolean equals(Object object) {
   91           return(object != null && object instanceof Media &&
   92                  object.getClass() == this.getClass() &&
   93                  ((Media)object).getValue() == this.getValue());
   94       }
   95   
   96       /**
   97        * Get the printing attribute class which is to be used as the "category"
   98        * for this printing attribute value.
   99        * <P>
  100        * For class Media and any vendor-defined subclasses, the category is
  101        * class Media itself.
  102        *
  103        * @return  Printing attribute class (category), an instance of class
  104        *          {@link java.lang.Class java.lang.Class}.
  105        */
  106       public final Class<? extends Attribute> getCategory() {
  107           return Media.class;
  108       }
  109   
  110       /**
  111        * Get the name of the category of which this attribute value is an
  112        * instance.
  113        * <P>
  114        * For class Media and any vendor-defined subclasses, the category name is
  115        * <CODE>"media"</CODE>.
  116        *
  117        * @return  Attribute category name.
  118        */
  119       public final String getName() {
  120           return "media";
  121       }
  122   
  123   }

Home » openjdk-7 » javax » print » attribute » standard » [javadoc | source]