author | alanb |
Thu, 17 Mar 2016 19:04:16 +0000 | |
changeset 36511 | 9d0388c6b336 |
parent 25859 | 3317bb8137f4 |
child 40707 | 8b0d53520355 |
permissions | -rw-r--r-- |
12047 | 1 |
/* |
20835 | 2 |
* Copyright (c) 2011, 2013, Oracle and/or its affiliates. All rights reserved. |
12047 | 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 com.apple.laf; |
|
27 |
||
28 |
import java.awt.*; |
|
29 |
import java.awt.image.*; |
|
30 |
import java.lang.ref.SoftReference; |
|
31 |
import java.lang.reflect.Method; |
|
20835 | 32 |
import java.security.AccessController; |
12047 | 33 |
import java.security.PrivilegedAction; |
34 |
import java.util.*; |
|
35 |
||
36 |
import javax.swing.*; |
|
37 |
import javax.swing.border.Border; |
|
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
38 |
import javax.swing.plaf.UIResource; |
12047 | 39 |
|
36511 | 40 |
import jdk.internal.loader.ClassLoaders; |
41 |
||
12047 | 42 |
import sun.awt.AppContext; |
43 |
||
44 |
import sun.lwawt.macosx.CImage; |
|
45 |
import sun.lwawt.macosx.CImage.Creator; |
|
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
46 |
import sun.lwawt.macosx.CPlatformWindow; |
20835 | 47 |
import sun.reflect.misc.ReflectUtil; |
48 |
import sun.security.action.GetPropertyAction; |
|
12047 | 49 |
import sun.swing.SwingUtilities2; |
50 |
||
51 |
import com.apple.laf.AquaImageFactory.SlicedImageControl; |
|
24532
24831bd48764
8040279: [macosx] Do not use the base image in the MultiResolutionBufferedImage
alexsch
parents:
23666
diff
changeset
|
52 |
import sun.awt.image.MultiResolutionCachedImage; |
12047 | 53 |
|
20835 | 54 |
final class AquaUtils { |
55 |
||
56 |
private static final String ANIMATIONS_PROPERTY = "swing.enableAnimations"; |
|
12047 | 57 |
|
20835 | 58 |
/** |
59 |
* Suppresses default constructor, ensuring non-instantiability. |
|
60 |
*/ |
|
61 |
private AquaUtils() { |
|
62 |
} |
|
63 |
||
64 |
/** |
|
12047 | 65 |
* Convenience function for determining ComponentOrientation. Helps us |
66 |
* avoid having Munge directives throughout the code. |
|
67 |
*/ |
|
20835 | 68 |
static boolean isLeftToRight(final Component c) { |
12047 | 69 |
return c.getComponentOrientation().isLeftToRight(); |
70 |
} |
|
71 |
||
20835 | 72 |
static void enforceComponentOrientation(final Component c, final ComponentOrientation orientation) { |
12047 | 73 |
c.setComponentOrientation(orientation); |
74 |
if (c instanceof Container) { |
|
20835 | 75 |
for (final Component child : ((Container)c).getComponents()) { |
12047 | 76 |
enforceComponentOrientation(child, orientation); |
77 |
} |
|
78 |
} |
|
79 |
} |
|
80 |
||
20835 | 81 |
private static Creator getCImageCreatorInternal() { |
82 |
return AccessController.doPrivileged(new PrivilegedAction<Creator>() { |
|
83 |
@Override |
|
12047 | 84 |
public Creator run() { |
85 |
try { |
|
25762
c4a3548120c6
8044862: Fix raw and unchecked lint warnings in macosx specific code
henryjen
parents:
24532
diff
changeset
|
86 |
final Method getCreatorMethod = CImage.class.getDeclaredMethod( |
c4a3548120c6
8044862: Fix raw and unchecked lint warnings in macosx specific code
henryjen
parents:
24532
diff
changeset
|
87 |
"getCreator", new Class<?>[] {}); |
12047 | 88 |
getCreatorMethod.setAccessible(true); |
20835 | 89 |
return (Creator)getCreatorMethod.invoke(null, new Object[] {}); |
90 |
} catch (final Exception ignored) { |
|
12047 | 91 |
return null; |
92 |
} |
|
93 |
} |
|
94 |
}); |
|
95 |
} |
|
96 |
||
20835 | 97 |
private static final RecyclableSingleton<Creator> cImageCreator = new RecyclableSingleton<Creator>() { |
12047 | 98 |
@Override |
99 |
protected Creator getInstance() { |
|
100 |
return getCImageCreatorInternal(); |
|
101 |
} |
|
102 |
}; |
|
20835 | 103 |
static Creator getCImageCreator() { |
12047 | 104 |
return cImageCreator.get(); |
105 |
} |
|
106 |
||
20835 | 107 |
static Image generateSelectedDarkImage(final Image image) { |
12047 | 108 |
final ImageProducer prod = new FilteredImageSource(image.getSource(), new IconImageFilter() { |
20835 | 109 |
@Override |
12047 | 110 |
int getGreyFor(final int gray) { |
111 |
return gray * 75 / 100; |
|
112 |
} |
|
113 |
}); |
|
114 |
return Toolkit.getDefaultToolkit().createImage(prod); |
|
115 |
} |
|
116 |
||
20835 | 117 |
static Image generateDisabledImage(final Image image) { |
12047 | 118 |
final ImageProducer prod = new FilteredImageSource(image.getSource(), new IconImageFilter() { |
20835 | 119 |
@Override |
12047 | 120 |
int getGreyFor(final int gray) { |
121 |
return 255 - ((255 - gray) * 65 / 100); |
|
122 |
} |
|
123 |
}); |
|
124 |
return Toolkit.getDefaultToolkit().createImage(prod); |
|
125 |
} |
|
126 |
||
20835 | 127 |
static Image generateLightenedImage(final Image image, final int percent) { |
12047 | 128 |
final GrayFilter filter = new GrayFilter(true, percent); |
24532
24831bd48764
8040279: [macosx] Do not use the base image in the MultiResolutionBufferedImage
alexsch
parents:
23666
diff
changeset
|
129 |
return (image instanceof MultiResolutionCachedImage) |
24831bd48764
8040279: [macosx] Do not use the base image in the MultiResolutionBufferedImage
alexsch
parents:
23666
diff
changeset
|
130 |
? ((MultiResolutionCachedImage) image).map( |
23318
7da69afd4ffe
8031573: [macosx] Checkmarks of JCheckBoxMenuItems aren't rendered in high resolution on Retina
alexsch
parents:
20835
diff
changeset
|
131 |
rv -> generateLightenedImage(rv, filter)) |
7da69afd4ffe
8031573: [macosx] Checkmarks of JCheckBoxMenuItems aren't rendered in high resolution on Retina
alexsch
parents:
20835
diff
changeset
|
132 |
: generateLightenedImage(image, filter); |
7da69afd4ffe
8031573: [macosx] Checkmarks of JCheckBoxMenuItems aren't rendered in high resolution on Retina
alexsch
parents:
20835
diff
changeset
|
133 |
} |
7da69afd4ffe
8031573: [macosx] Checkmarks of JCheckBoxMenuItems aren't rendered in high resolution on Retina
alexsch
parents:
20835
diff
changeset
|
134 |
|
7da69afd4ffe
8031573: [macosx] Checkmarks of JCheckBoxMenuItems aren't rendered in high resolution on Retina
alexsch
parents:
20835
diff
changeset
|
135 |
static Image generateLightenedImage(Image image, ImageFilter filter) { |
12047 | 136 |
final ImageProducer prod = new FilteredImageSource(image.getSource(), filter); |
137 |
return Toolkit.getDefaultToolkit().createImage(prod); |
|
138 |
} |
|
139 |
||
20835 | 140 |
private abstract static class IconImageFilter extends RGBImageFilter { |
141 |
IconImageFilter() { |
|
12047 | 142 |
super(); |
143 |
canFilterIndexColorModel = true; |
|
144 |
} |
|
145 |
||
20835 | 146 |
@Override |
147 |
public final int filterRGB(final int x, final int y, final int rgb) { |
|
12047 | 148 |
final int red = (rgb >> 16) & 0xff; |
149 |
final int green = (rgb >> 8) & 0xff; |
|
150 |
final int blue = rgb & 0xff; |
|
151 |
final int gray = getGreyFor((int)((0.30 * red + 0.59 * green + 0.11 * blue) / 3)); |
|
152 |
||
153 |
return (rgb & 0xff000000) | (grayTransform(red, gray) << 16) | (grayTransform(green, gray) << 8) | (grayTransform(blue, gray) << 0); |
|
154 |
} |
|
155 |
||
156 |
private static int grayTransform(final int color, final int gray) { |
|
157 |
int result = color - gray; |
|
158 |
if (result < 0) result = 0; |
|
159 |
if (result > 255) result = 255; |
|
160 |
return result; |
|
161 |
} |
|
162 |
||
20835 | 163 |
abstract int getGreyFor(int gray); |
12047 | 164 |
} |
165 |
||
20835 | 166 |
abstract static class RecyclableObject<T> { |
167 |
private SoftReference<T> objectRef; |
|
12047 | 168 |
|
20835 | 169 |
T get() { |
170 |
T referent; |
|
12047 | 171 |
if (objectRef != null && (referent = objectRef.get()) != null) return referent; |
172 |
referent = create(); |
|
173 |
objectRef = new SoftReference<T>(referent); |
|
174 |
return referent; |
|
175 |
} |
|
176 |
||
177 |
protected abstract T create(); |
|
178 |
} |
|
179 |
||
20835 | 180 |
abstract static class RecyclableSingleton<T> { |
181 |
final T get() { |
|
23666
a54bf43b5ba9
8035069: [macosx] Loading resolution variants by demand
alexsch
parents:
23318
diff
changeset
|
182 |
return AppContext.getSoftReferenceValue(this, () -> getInstance()); |
12047 | 183 |
} |
184 |
||
20835 | 185 |
void reset() { |
186 |
AppContext.getAppContext().remove(this); |
|
12047 | 187 |
} |
188 |
||
20835 | 189 |
abstract T getInstance(); |
12047 | 190 |
} |
191 |
||
20835 | 192 |
static class RecyclableSingletonFromDefaultConstructor<T> extends RecyclableSingleton<T> { |
193 |
private final Class<T> clazz; |
|
12047 | 194 |
|
20835 | 195 |
RecyclableSingletonFromDefaultConstructor(final Class<T> clazz) { |
12047 | 196 |
this.clazz = clazz; |
197 |
} |
|
198 |
||
20835 | 199 |
@Override |
200 |
T getInstance() { |
|
12047 | 201 |
try { |
20835 | 202 |
ReflectUtil.checkPackageAccess(clazz); |
12047 | 203 |
return clazz.newInstance(); |
20835 | 204 |
} catch (InstantiationException | IllegalAccessException ignored) { |
12047 | 205 |
} |
206 |
return null; |
|
207 |
} |
|
208 |
} |
|
209 |
||
20835 | 210 |
abstract static class LazyKeyedSingleton<K, V> { |
211 |
private Map<K, V> refs; |
|
12047 | 212 |
|
20835 | 213 |
V get(final K key) { |
214 |
if (refs == null) refs = new HashMap<>(); |
|
12047 | 215 |
|
216 |
final V cachedValue = refs.get(key); |
|
217 |
if (cachedValue != null) return cachedValue; |
|
218 |
||
219 |
final V value = getInstance(key); |
|
220 |
refs.put(key, value); |
|
221 |
return value; |
|
222 |
} |
|
223 |
||
20835 | 224 |
protected abstract V getInstance(K key); |
12047 | 225 |
} |
226 |
||
20835 | 227 |
private static final RecyclableSingleton<Boolean> enableAnimations = new RecyclableSingleton<Boolean>() { |
12047 | 228 |
@Override |
229 |
protected Boolean getInstance() { |
|
20835 | 230 |
final String sizeProperty = (String) AccessController.doPrivileged((PrivilegedAction<?>)new GetPropertyAction( |
231 |
ANIMATIONS_PROPERTY)); |
|
232 |
return !"false".equals(sizeProperty); // should be true by default |
|
12047 | 233 |
} |
234 |
}; |
|
20835 | 235 |
private static boolean animationsEnabled() { |
12047 | 236 |
return enableAnimations.get(); |
237 |
} |
|
238 |
||
20835 | 239 |
private static final int MENU_BLINK_DELAY = 50; // 50ms == 3/60 sec, according to the spec |
240 |
static void blinkMenu(final Selectable selectable) { |
|
12047 | 241 |
if (!animationsEnabled()) return; |
242 |
try { |
|
243 |
selectable.paintSelected(false); |
|
244 |
Thread.sleep(MENU_BLINK_DELAY); |
|
245 |
selectable.paintSelected(true); |
|
246 |
Thread.sleep(MENU_BLINK_DELAY); |
|
20835 | 247 |
} catch (final InterruptedException ignored) { } |
12047 | 248 |
} |
249 |
||
250 |
interface Selectable { |
|
20835 | 251 |
void paintSelected(boolean selected); |
12047 | 252 |
} |
253 |
||
254 |
interface JComponentPainter { |
|
20835 | 255 |
void paint(JComponent c, Graphics g, int x, int y, int w, int h); |
12047 | 256 |
} |
257 |
||
258 |
interface Painter { |
|
20835 | 259 |
void paint(Graphics g, int x, int y, int w, int h); |
12047 | 260 |
} |
261 |
||
20835 | 262 |
static void paintDropShadowText(final Graphics g, final JComponent c, final Font font, final FontMetrics metrics, final int x, final int y, final int offsetX, final int offsetY, final Color textColor, final Color shadowColor, final String text) { |
12047 | 263 |
g.setFont(font); |
264 |
g.setColor(shadowColor); |
|
265 |
SwingUtilities2.drawString(c, g, text, x + offsetX, y + offsetY + metrics.getAscent()); |
|
266 |
g.setColor(textColor); |
|
267 |
SwingUtilities2.drawString(c, g, text, x, y + metrics.getAscent()); |
|
268 |
} |
|
269 |
||
20835 | 270 |
static class ShadowBorder implements Border { |
271 |
private final Painter prePainter; |
|
272 |
private final Painter postPainter; |
|
12047 | 273 |
|
20835 | 274 |
private final int offsetX; |
275 |
private final int offsetY; |
|
276 |
private final float distance; |
|
277 |
private final int blur; |
|
278 |
private final Insets insets; |
|
279 |
private final ConvolveOp blurOp; |
|
12047 | 280 |
|
20835 | 281 |
ShadowBorder(final Painter prePainter, final Painter postPainter, final int offsetX, final int offsetY, final float distance, final float intensity, final int blur) { |
12047 | 282 |
this.prePainter = prePainter; this.postPainter = postPainter; |
283 |
this.offsetX = offsetX; this.offsetY = offsetY; this.distance = distance; this.blur = blur; |
|
284 |
final int halfBlur = blur / 2; |
|
20835 | 285 |
insets = new Insets(halfBlur - offsetY, halfBlur - offsetX, halfBlur + offsetY, halfBlur + offsetX); |
12047 | 286 |
|
287 |
final float blurry = intensity / (blur * blur); |
|
288 |
final float[] blurKernel = new float[blur * blur]; |
|
289 |
for (int i = 0; i < blurKernel.length; i++) blurKernel[i] = blurry; |
|
290 |
blurOp = new ConvolveOp(new Kernel(blur, blur, blurKernel)); |
|
291 |
} |
|
292 |
||
20835 | 293 |
@Override |
294 |
public final boolean isBorderOpaque() { |
|
12047 | 295 |
return false; |
296 |
} |
|
297 |
||
20835 | 298 |
@Override |
299 |
public final Insets getBorderInsets(final Component c) { |
|
12047 | 300 |
return insets; |
301 |
} |
|
302 |
||
20835 | 303 |
@Override |
12047 | 304 |
public void paintBorder(final Component c, final Graphics g, final int x, final int y, final int width, final int height) { |
305 |
final BufferedImage img = new BufferedImage(width + blur * 2, height + blur * 2, BufferedImage.TYPE_INT_ARGB_PRE); |
|
306 |
paintToImage(img, x, y, width, height); |
|
307 |
// debugFrame("border", img); |
|
308 |
g.drawImage(img, -blur, -blur, null); |
|
309 |
} |
|
310 |
||
20835 | 311 |
private void paintToImage(final BufferedImage img, final int x, final int y, final int width, final int height) { |
12047 | 312 |
// clear the prior image |
313 |
Graphics2D imgG = (Graphics2D)img.getGraphics(); |
|
314 |
imgG.setComposite(AlphaComposite.Clear); |
|
315 |
imgG.setColor(Color.black); |
|
316 |
imgG.fillRect(0, 0, width + blur * 2, height + blur * 2); |
|
317 |
||
318 |
final int adjX = (int)(x + blur + offsetX + (insets.left * distance)); |
|
319 |
final int adjY = (int)(y + blur + offsetY + (insets.top * distance)); |
|
320 |
final int adjW = (int)(width - (insets.left + insets.right) * distance); |
|
321 |
final int adjH = (int)(height - (insets.top + insets.bottom) * distance); |
|
322 |
||
323 |
// let the delegate paint whatever they want to be blurred |
|
324 |
imgG.setComposite(AlphaComposite.DstAtop); |
|
325 |
if (prePainter != null) prePainter.paint(imgG, adjX, adjY, adjW, adjH); |
|
326 |
imgG.dispose(); |
|
327 |
||
328 |
// blur the prior image back into the same pixels |
|
329 |
imgG = (Graphics2D)img.getGraphics(); |
|
330 |
imgG.setComposite(AlphaComposite.DstAtop); |
|
331 |
imgG.setRenderingHint(RenderingHints.KEY_INTERPOLATION, RenderingHints.VALUE_INTERPOLATION_BICUBIC); |
|
332 |
imgG.setRenderingHint(RenderingHints.KEY_ALPHA_INTERPOLATION, RenderingHints.VALUE_ALPHA_INTERPOLATION_QUALITY); |
|
333 |
imgG.drawImage(img, blurOp, 0, 0); |
|
334 |
||
335 |
if (postPainter != null) postPainter.paint(imgG, adjX, adjY, adjW, adjH); |
|
336 |
imgG.dispose(); |
|
337 |
} |
|
338 |
} |
|
339 |
||
20835 | 340 |
static class SlicedShadowBorder extends ShadowBorder { |
341 |
private final SlicedImageControl slices; |
|
12047 | 342 |
|
20835 | 343 |
SlicedShadowBorder(final Painter prePainter, final Painter postPainter, final int offsetX, final int offsetY, final float distance, final float intensity, final int blur, final int templateWidth, final int templateHeight, final int leftCut, final int topCut, final int rightCut, final int bottomCut) { |
12047 | 344 |
super(prePainter, postPainter, offsetX, offsetY, distance, intensity, blur); |
345 |
||
346 |
final BufferedImage i = new BufferedImage(templateWidth, templateHeight, BufferedImage.TYPE_INT_ARGB_PRE); |
|
347 |
super.paintBorder(null, i.getGraphics(), 0, 0, templateWidth, templateHeight); |
|
348 |
// debugFrame("slices", i); |
|
349 |
slices = new SlicedImageControl(i, leftCut, topCut, rightCut, bottomCut, false); |
|
350 |
} |
|
351 |
||
20835 | 352 |
@Override |
12047 | 353 |
public void paintBorder(final Component c, final Graphics g, final int x, final int y, final int width, final int height) { |
354 |
slices.paint(g, x, y, width, height); |
|
355 |
} |
|
356 |
} |
|
357 |
||
358 |
// static void debugFrame(String name, Image image) { |
|
359 |
// JFrame f = new JFrame(name); |
|
360 |
// f.setContentPane(new JLabel(new ImageIcon(image))); |
|
361 |
// f.pack(); |
|
362 |
// f.setVisible(true); |
|
363 |
// } |
|
364 |
||
365 |
// special casing naughty applications, like InstallAnywhere |
|
366 |
// <rdar://problem/4851533> REGR: JButton: Myst IV: the buttons of 1.0.3 updater have redraw issue |
|
367 |
static boolean shouldUseOpaqueButtons() { |
|
36511 | 368 |
// can we use ClassLoader.getSystemClassLoader here? |
369 |
final ClassLoader launcherClassLoader = ClassLoaders.appClassLoader(); |
|
12047 | 370 |
if (classExists(launcherClassLoader, "com.installshield.wizard.platform.macosx.MacOSXUtils")) return true; |
371 |
return false; |
|
372 |
} |
|
373 |
||
20835 | 374 |
private static boolean classExists(final ClassLoader classLoader, final String clazzName) { |
12047 | 375 |
try { |
376 |
return Class.forName(clazzName, false, classLoader) != null; |
|
20835 | 377 |
} catch (final Throwable ignored) { } |
12047 | 378 |
return false; |
379 |
} |
|
380 |
||
20835 | 381 |
private static final RecyclableSingleton<Method> getJComponentGetFlagMethod = new RecyclableSingleton<Method>() { |
382 |
@Override |
|
12047 | 383 |
protected Method getInstance() { |
20835 | 384 |
return AccessController.doPrivileged( |
12047 | 385 |
new PrivilegedAction<Method>() { |
20835 | 386 |
@Override |
12047 | 387 |
public Method run() { |
388 |
try { |
|
25762
c4a3548120c6
8044862: Fix raw and unchecked lint warnings in macosx specific code
henryjen
parents:
24532
diff
changeset
|
389 |
final Method method = JComponent.class.getDeclaredMethod( |
c4a3548120c6
8044862: Fix raw and unchecked lint warnings in macosx specific code
henryjen
parents:
24532
diff
changeset
|
390 |
"getFlag", new Class<?>[] { int.class }); |
12047 | 391 |
method.setAccessible(true); |
392 |
return method; |
|
20835 | 393 |
} catch (final Throwable ignored) { |
12047 | 394 |
return null; |
395 |
} |
|
396 |
} |
|
397 |
} |
|
398 |
); |
|
399 |
} |
|
400 |
}; |
|
401 |
||
20835 | 402 |
private static final Integer OPAQUE_SET_FLAG = 24; // private int JComponent.OPAQUE_SET |
403 |
static boolean hasOpaqueBeenExplicitlySet(final JComponent c) { |
|
12047 | 404 |
final Method method = getJComponentGetFlagMethod.get(); |
405 |
if (method == null) return false; |
|
406 |
try { |
|
407 |
return Boolean.TRUE.equals(method.invoke(c, OPAQUE_SET_FLAG)); |
|
20835 | 408 |
} catch (final Throwable ignored) { |
12047 | 409 |
return false; |
410 |
} |
|
411 |
} |
|
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
412 |
|
20835 | 413 |
private static boolean isWindowTextured(final Component c) { |
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
414 |
if (!(c instanceof JComponent)) { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
415 |
return false; |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
416 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
417 |
final JRootPane pane = ((JComponent) c).getRootPane(); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
418 |
if (pane == null) { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
419 |
return false; |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
420 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
421 |
Object prop = pane.getClientProperty( |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
422 |
CPlatformWindow.WINDOW_BRUSH_METAL_LOOK); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
423 |
if (prop != null) { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
424 |
return Boolean.parseBoolean(prop.toString()); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
425 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
426 |
prop = pane.getClientProperty(CPlatformWindow.WINDOW_STYLE); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
427 |
return prop != null && "textured".equals(prop); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
428 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
429 |
|
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
430 |
private static Color resetAlpha(final Color color) { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
431 |
return new Color(color.getRed(), color.getGreen(), color.getBlue(), 0); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
432 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
433 |
|
20835 | 434 |
static void fillRect(final Graphics g, final Component c) { |
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
435 |
fillRect(g, c, c.getBackground(), 0, 0, c.getWidth(), c.getHeight()); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
436 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
437 |
|
20835 | 438 |
static void fillRect(final Graphics g, final Component c, final Color color, |
439 |
final int x, final int y, final int w, final int h) { |
|
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
440 |
if (!(g instanceof Graphics2D)) { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
441 |
return; |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
442 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
443 |
final Graphics2D cg = (Graphics2D) g.create(); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
444 |
try { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
445 |
if (color instanceof UIResource && isWindowTextured(c) |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
446 |
&& color.equals(SystemColor.window)) { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
447 |
cg.setComposite(AlphaComposite.Src); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
448 |
cg.setColor(resetAlpha(color)); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
449 |
} else { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
450 |
cg.setColor(color); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
451 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
452 |
cg.fillRect(x, y, w, h); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
453 |
} finally { |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
454 |
cg.dispose(); |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
455 |
} |
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
456 |
} |
12047 | 457 |
} |
13234
9437e5985d73
7124513: [macosx] Support NSTexturedBackgroundWindowMask/different titlebar styles to create unified toolbar
serb
parents:
12047
diff
changeset
|
458 |