1 /* 2 * Copyright (c) 1997, 2014, 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.TabbedPaneUI; 29 import javax.swing.JTabbedPane; 30 import java.awt.Rectangle; 31 import javax.swing.plaf.ComponentUI; 32 import javax.swing.JComponent; 33 import java.awt.Graphics; 34 import java.awt.Dimension; 35 import javax.accessibility.Accessible; 36 37 /** 38 * A multiplexing UI used to combine <code>TabbedPaneUI</code>s. 39 * 40 * <p>This file was automatically generated by AutoMulti. 41 * 42 * @author Otto Multey 43 */ 44 public class MultiTabbedPaneUI extends TabbedPaneUI { 45 46 /** 47 * The vector containing the real UIs. This is populated 48 * in the call to <code>createUI</code>, and can be obtained by calling 49 * the <code>getUIs</code> method. The first element is guaranteed to be the real UI 50 * obtained from the default look and feel. 51 */ 52 protected Vector uis = new Vector(); 53 54 //////////////////// 55 // Common UI methods 56 //////////////////// 57 58 /** 59 * Returns the list of UIs associated with this multiplexing UI. This 60 * allows processing of the UIs by an application aware of multiplexing 61 * UIs on components. 62 * 63 * @return an array of the UI delegates 64 */ 65 public ComponentUI[] getUIs() { 66 return MultiLookAndFeel.uisToArray(uis); 67 } 68 69 //////////////////// 70 // TabbedPaneUI methods 71 //////////////////// 72 73 /** 74 * Invokes the <code>tabForCoordinate</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 int tabForCoordinate(JTabbedPane a, int b, int c) { 80 int returnValue = 81 ((TabbedPaneUI) (uis.elementAt(0))).tabForCoordinate(a,b,c); 82 for (int i = 1; i < uis.size(); i++) { 83 ((TabbedPaneUI) (uis.elementAt(i))).tabForCoordinate(a,b,c); 84 } 85 return returnValue; 86 } 87 88 /** 89 * Invokes the <code>getTabBounds</code> method on each UI handled by this object. 90 * 91 * @return the value obtained from the first UI, which is 92 * the UI obtained from the default <code>LookAndFeel</code> 93 */ 94 public Rectangle getTabBounds(JTabbedPane a, int b) { 95 Rectangle returnValue = 96 ((TabbedPaneUI) (uis.elementAt(0))).getTabBounds(a,b); 97 for (int i = 1; i < uis.size(); i++) { 98 ((TabbedPaneUI) (uis.elementAt(i))).getTabBounds(a,b); 99 } 100 return returnValue; 101 } 102 103 /** 104 * Invokes the <code>getTabRunCount</code> method on each UI handled by this object. 105 * 106 * @return the value obtained from the first UI, which is 107 * the UI obtained from the default <code>LookAndFeel</code> 108 */ 109 public int getTabRunCount(JTabbedPane a) { 110 int returnValue = 111 ((TabbedPaneUI) (uis.elementAt(0))).getTabRunCount(a); 112 for (int i = 1; i < uis.size(); i++) { 113 ((TabbedPaneUI) (uis.elementAt(i))).getTabRunCount(a); 114 } 115 return returnValue; 116 } 117 118 //////////////////// 119 // ComponentUI methods 120 //////////////////// 121 122 /** 123 * Invokes the <code>contains</code> method on each UI handled by this object. 124 * 125 * @return the value obtained from the first UI, which is 126 * the UI obtained from the default <code>LookAndFeel</code> 127 */ 128 public boolean contains(JComponent a, int b, int c) { 129 boolean returnValue = 130 ((ComponentUI) (uis.elementAt(0))).contains(a,b,c); 131 for (int i = 1; i < uis.size(); i++) { 132 ((ComponentUI) (uis.elementAt(i))).contains(a,b,c); 133 } 134 return returnValue; 135 } 136 137 /** 138 * Invokes the <code>update</code> method on each UI handled by this object. 139 */ 140 public void update(Graphics a, JComponent b) { 141 for (int i = 0; i < uis.size(); i++) { 142 ((ComponentUI) (uis.elementAt(i))).update(a,b); 143 } 144 } 145 146 /** 147 * Returns a multiplexing UI instance if any of the auxiliary 148 * <code>LookAndFeel</code>s supports this UI. Otherwise, just returns the 149 * UI object obtained from the default <code>LookAndFeel</code>. 150 * 151 * @param a the component to create the UI for 152 * @return the UI delegate created 153 */ 154 public static ComponentUI createUI(JComponent a) { 155 ComponentUI mui = new MultiTabbedPaneUI(); 156 return MultiLookAndFeel.createUIs(mui, 157 ((MultiTabbedPaneUI) mui).uis, 158 a); 159 } 160 161 /** 162 * Invokes the <code>installUI</code> method on each UI handled by this object. 163 */ 164 public void installUI(JComponent a) { 165 for (int i = 0; i < uis.size(); i++) { 166 ((ComponentUI) (uis.elementAt(i))).installUI(a); 167 } 168 } 169 170 /** 171 * Invokes the <code>uninstallUI</code> method on each UI handled by this object. 172 */ 173 public void uninstallUI(JComponent a) { 174 for (int i = 0; i < uis.size(); i++) { 175 ((ComponentUI) (uis.elementAt(i))).uninstallUI(a); 176 } 177 } 178 179 /** 180 * Invokes the <code>paint</code> method on each UI handled by this object. 181 */ 182 public void paint(Graphics a, JComponent b) { 183 for (int i = 0; i < uis.size(); i++) { 184 ((ComponentUI) (uis.elementAt(i))).paint(a,b); 185 } 186 } 187 188 /** 189 * Invokes the <code>getPreferredSize</code> method on each UI handled by this object. 190 * 191 * @return the value obtained from the first UI, which is 192 * the UI obtained from the default <code>LookAndFeel</code> 193 */ 194 public Dimension getPreferredSize(JComponent a) { 195 Dimension returnValue = 196 ((ComponentUI) (uis.elementAt(0))).getPreferredSize(a); 197 for (int i = 1; i < uis.size(); i++) { 198 ((ComponentUI) (uis.elementAt(i))).getPreferredSize(a); 199 } 200 return returnValue; 201 } 202 203 /** 204 * Invokes the <code>getMinimumSize</code> method on each UI handled by this object. 205 * 206 * @return the value obtained from the first UI, which is 207 * the UI obtained from the default <code>LookAndFeel</code> 208 */ 209 public Dimension getMinimumSize(JComponent a) { 210 Dimension returnValue = 211 ((ComponentUI) (uis.elementAt(0))).getMinimumSize(a); 212 for (int i = 1; i < uis.size(); i++) { 213 ((ComponentUI) (uis.elementAt(i))).getMinimumSize(a); 214 } 215 return returnValue; 216 } 217 218 /** 219 * Invokes the <code>getMaximumSize</code> method on each UI handled by this object. 220 * 221 * @return the value obtained from the first UI, which is 222 * the UI obtained from the default <code>LookAndFeel</code> 223 */ 224 public Dimension getMaximumSize(JComponent a) { 225 Dimension returnValue = 226 ((ComponentUI) (uis.elementAt(0))).getMaximumSize(a); 227 for (int i = 1; i < uis.size(); i++) { 228 ((ComponentUI) (uis.elementAt(i))).getMaximumSize(a); 229 } 230 return returnValue; 231 } 232 233 /** 234 * Invokes the <code>getAccessibleChildrenCount</code> method on each UI handled by this object. 235 * 236 * @return the value obtained from the first UI, which is 237 * the UI obtained from the default <code>LookAndFeel</code> 238 */ 239 public int getAccessibleChildrenCount(JComponent a) { 240 int returnValue = 241 ((ComponentUI) (uis.elementAt(0))).getAccessibleChildrenCount(a); 242 for (int i = 1; i < uis.size(); i++) { 243 ((ComponentUI) (uis.elementAt(i))).getAccessibleChildrenCount(a); 244 } 245 return returnValue; 246 } 247 248 /** 249 * Invokes the <code>getAccessibleChild</code> method on each UI handled by this object. 250 * 251 * @return the value obtained from the first UI, which is 252 * the UI obtained from the default <code>LookAndFeel</code> 253 */ 254 public Accessible getAccessibleChild(JComponent a, int b) { 255 Accessible returnValue = 256 ((ComponentUI) (uis.elementAt(0))).getAccessibleChild(a,b); 257 for (int i = 1; i < uis.size(); i++) { 258 ((ComponentUI) (uis.elementAt(i))).getAccessibleChild(a,b); 259 } 260 return returnValue; 261 } 262 }