1 /* 2 * Copyright (c) 2000, 2017, 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 26 package javax.print.attribute.standard; 27 28 import javax.print.attribute.Attribute; 29 import javax.print.attribute.EnumSyntax; 30 31 /** 32 * Class {@code MediaName} is a subclass of {@code Media}, a printing attribute 33 * class (an enumeration) that specifies the media for a print job as a name. 34 * <p> 35 * This attribute can be used instead of specifying {@code MediaSize} or 36 * {@code MediaTray}. 37 * <p> 38 * Class {@code MediaName} currently declares a few standard media names. 39 * Implementation- or site-defined names for a media name attribute may also be 40 * created by defining a subclass of class {@code MediaName}. 41 * <p> 42 * <b>IPP Compatibility:</b> {@code MediaName} is a representation class for 43 * values of the IPP "media" attribute which names media. 44 */ 45 public class MediaName extends Media implements Attribute { 46 47 /** 48 * Use serialVersionUID from JDK 1.4 for interoperability. 49 */ 50 private static final long serialVersionUID = 4653117714524155448L; 51 52 /** 53 * white letter paper. 54 */ 55 public static final MediaName NA_LETTER_WHITE = new MediaName(0); 56 57 /** 58 * letter transparency. 59 */ 60 public static final MediaName NA_LETTER_TRANSPARENT = new MediaName(1); 61 62 /** 63 * white A4 paper. 64 */ 65 public static final MediaName ISO_A4_WHITE = new MediaName(2); 66 67 /** 68 * A4 transparency. 69 */ 70 public static final MediaName ISO_A4_TRANSPARENT= new MediaName(3); 71 72 /** 73 * Constructs a new media name enumeration value with the given integer 74 * value. 75 * 76 * @param value Integer value 77 */ 78 protected MediaName(int value) { 79 super (value); 80 } 81 82 /** 83 * The string table for class {@code MediaTray}. 84 */ 85 private static final String[] myStringTable = { 86 "na-letter-white", 87 "na-letter-transparent", 88 "iso-a4-white", 89 "iso-a4-transparent" 90 }; 91 92 /** 93 * The enumeration value table for class {@code MediaTray}. 94 */ 95 private static final MediaName[] myEnumValueTable = { 96 NA_LETTER_WHITE, 97 NA_LETTER_TRANSPARENT, 98 ISO_A4_WHITE, 99 ISO_A4_TRANSPARENT 100 }; 101 102 /** 103 * Returns the string table for class {@code MediaTray}. 104 * 105 * @return the string table 106 */ 107 protected String[] getStringTable() 108 { 109 return myStringTable.clone(); 110 } 111 112 /** 113 * Returns the enumeration value table for class {@code MediaTray}. 114 * 115 * @return the enumeration value table 116 */ 117 protected EnumSyntax[] getEnumValueTable() { 118 return (EnumSyntax[])myEnumValueTable.clone(); 119 } 120 }