1 /* 2 * Copyright (c) 1997, 2001, 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.swing.plaf.multi; 26 27 import java.util.Vector; 28 import javax.swing.plaf.SeparatorUI; 29 import javax.swing.plaf.ComponentUI; 30 import javax.swing.JComponent; 31 import java.awt.Graphics; 32 import java.awt.Dimension; 33 import javax.accessibility.Accessible; 34 35 /** 36 * A multiplexing UI used to combine <code>SeparatorUI</code>s. 37 * 38 * <p>This file was automatically generated by AutoMulti. 39 * 40 * @author Otto Multey 41 */ 42 public class MultiSeparatorUI extends SeparatorUI { 43 44 /** 45 * The vector containing the real UIs. This is populated 46 * in the call to <code>createUI</code>, and can be obtained by calling 47 * the <code>getUIs</code> method. The first element is guaranteed to be the real UI 48 * obtained from the default look and feel. 49 */ 50 protected Vector<ComponentUI> uis = new Vector<>(); 51 52 //////////////////// 53 // Common UI methods 54 //////////////////// 55 56 /** 57 * Returns the list of UIs associated with this multiplexing UI. This 58 * allows processing of the UIs by an application aware of multiplexing 59 * UIs on components. 60 */ 61 public ComponentUI[] getUIs() { 62 return MultiLookAndFeel.uisToArray(uis); 63 } 64 65 //////////////////// 66 // SeparatorUI methods 67 //////////////////// 68 69 //////////////////// 70 // ComponentUI methods 71 //////////////////// 72 73 /** 74 * Invokes the <code>contains</code> method on each UI handled by this object. 75 * 76 * @return the value obtained from the first UI, which is 77 * the UI obtained from the default <code>LookAndFeel</code> 78 */ 79 public boolean contains(JComponent a, int b, int c) { 80 boolean returnValue = 81 uis.elementAt(0).contains(a,b,c); 82 for (int i = 1; i < uis.size(); i++) { 83 uis.elementAt(i).contains(a,b,c); 84 } 85 return returnValue; 86 } 87 88 /** 89 * Invokes the <code>update</code> method on each UI handled by this object. 90 */ 91 public void update(Graphics a, JComponent b) { 92 for (int i = 0; i < uis.size(); i++) { 93 uis.elementAt(i).update(a,b); 94 } 95 } 96 97 /** 98 * Returns a multiplexing UI instance if any of the auxiliary 99 * <code>LookAndFeel</code>s supports this UI. Otherwise, just returns the 100 * UI object obtained from the default <code>LookAndFeel</code>. 101 */ 102 public static ComponentUI createUI(JComponent a) { 103 MultiSeparatorUI mui = new MultiSeparatorUI(); 104 return MultiLookAndFeel.createUIs(mui, mui.uis, a); 105 } 106 107 /** 108 * Invokes the <code>installUI</code> method on each UI handled by this object. 109 */ 110 public void installUI(JComponent a) { 111 for (int i = 0; i < uis.size(); i++) { 112 uis.elementAt(i).installUI(a); 113 } 114 } 115 116 /** 117 * Invokes the <code>uninstallUI</code> method on each UI handled by this object. 118 */ 119 public void uninstallUI(JComponent a) { 120 for (int i = 0; i < uis.size(); i++) { 121 uis.elementAt(i).uninstallUI(a); 122 } 123 } 124 125 /** 126 * Invokes the <code>paint</code> method on each UI handled by this object. 127 */ 128 public void paint(Graphics a, JComponent b) { 129 for (int i = 0; i < uis.size(); i++) { 130 uis.elementAt(i).paint(a,b); 131 } 132 } 133 134 /** 135 * Invokes the <code>getPreferredSize</code> method on each UI handled by this object. 136 * 137 * @return the value obtained from the first UI, which is 138 * the UI obtained from the default <code>LookAndFeel</code> 139 */ 140 public Dimension getPreferredSize(JComponent a) { 141 Dimension returnValue = 142 uis.elementAt(0).getPreferredSize(a); 143 for (int i = 1; i < uis.size(); i++) { 144 uis.elementAt(i).getPreferredSize(a); 145 } 146 return returnValue; 147 } 148 149 /** 150 * Invokes the <code>getMinimumSize</code> method on each UI handled by this object. 151 * 152 * @return the value obtained from the first UI, which is 153 * the UI obtained from the default <code>LookAndFeel</code> 154 */ 155 public Dimension getMinimumSize(JComponent a) { 156 Dimension returnValue = 157 uis.elementAt(0).getMinimumSize(a); 158 for (int i = 1; i < uis.size(); i++) { 159 uis.elementAt(i).getMinimumSize(a); 160 } 161 return returnValue; 162 } 163 164 /** 165 * Invokes the <code>getMaximumSize</code> method on each UI handled by this object. 166 * 167 * @return the value obtained from the first UI, which is 168 * the UI obtained from the default <code>LookAndFeel</code> 169 */ 170 public Dimension getMaximumSize(JComponent a) { 171 Dimension returnValue = 172 uis.elementAt(0).getMaximumSize(a); 173 for (int i = 1; i < uis.size(); i++) { 174 uis.elementAt(i).getMaximumSize(a); 175 } 176 return returnValue; 177 } 178 179 /** 180 * Invokes the <code>getAccessibleChildrenCount</code> method on each UI handled by this object. 181 * 182 * @return the value obtained from the first UI, which is 183 * the UI obtained from the default <code>LookAndFeel</code> 184 */ 185 public int getAccessibleChildrenCount(JComponent a) { 186 int returnValue = 187 uis.elementAt(0).getAccessibleChildrenCount(a); 188 for (int i = 1; i < uis.size(); i++) { 189 uis.elementAt(i).getAccessibleChildrenCount(a); 190 } 191 return returnValue; 192 } 193 194 /** 195 * Invokes the <code>getAccessibleChild</code> method on each UI handled by this object. 196 * 197 * @return the value obtained from the first UI, which is 198 * the UI obtained from the default <code>LookAndFeel</code> 199 */ 200 public Accessible getAccessibleChild(JComponent a, int b) { 201 Accessible returnValue = 202 uis.elementAt(0).getAccessibleChild(a,b); 203 for (int i = 1; i < uis.size(); i++) { 204 uis.elementAt(i).getAccessibleChild(a,b); 205 } 206 return returnValue; 207 } 208 }