~ubuntu-branches/debian/stretch/insubstantial/stretch

« back to all changes in this revision

Viewing changes to substance/src/main/java/org/pushingpixels/substance/internal/ui/SubstanceViewportUI.java

  • Committer: Package Import Robot
  • Author(s): Felix Natter
  • Date: 2016-01-18 20:58:45 UTC
  • Revision ID: package-import@ubuntu.com-20160118205845-crbmrkda61qsi5qa
Tags: upstream-7.3+dfsg2
ImportĀ upstreamĀ versionĀ 7.3+dfsg2

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Copyright (c) 2005-2010 Substance Kirill Grouchnikov. All Rights Reserved.
 
3
 *
 
4
 * Redistribution and use in source and binary forms, with or without
 
5
 * modification, are permitted provided that the following conditions are met:
 
6
 *
 
7
 *  o Redistributions of source code must retain the above copyright notice,
 
8
 *    this list of conditions and the following disclaimer.
 
9
 *
 
10
 *  o Redistributions in binary form must reproduce the above copyright notice,
 
11
 *    this list of conditions and the following disclaimer in the documentation
 
12
 *    and/or other materials provided with the distribution.
 
13
 *
 
14
 *  o Neither the name of Substance Kirill Grouchnikov nor the names of
 
15
 *    its contributors may be used to endorse or promote products derived
 
16
 *    from this software without specific prior written permission.
 
17
 *
 
18
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 
19
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 
20
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 
21
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 
22
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 
23
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 
24
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 
25
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 
26
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
 
27
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 
28
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 
29
 */
 
30
package org.pushingpixels.substance.internal.ui;
 
31
 
 
32
import java.awt.Color;
 
33
import java.awt.Graphics;
 
34
 
 
35
import javax.swing.JComponent;
 
36
import javax.swing.JViewport;
 
37
import javax.swing.plaf.*;
 
38
import javax.swing.plaf.basic.BasicViewportUI;
 
39
 
 
40
import org.pushingpixels.substance.api.SubstanceLookAndFeel;
 
41
import org.pushingpixels.substance.internal.painter.BackgroundPaintingUtils;
 
42
import org.pushingpixels.substance.internal.utils.SubstanceColorUtilities;
 
43
import org.pushingpixels.substance.internal.utils.SubstanceCoreUtilities;
 
44
 
 
45
/**
 
46
 * UI for panels in <b>Substance</b> look and feel.
 
47
 * 
 
48
 * @author Kirill Grouchnikov
 
49
 */
 
50
public class SubstanceViewportUI extends BasicViewportUI {
 
51
        /*
 
52
         * (non-Javadoc)
 
53
         * 
 
54
         * @see javax.swing.plaf.ComponentUI#createUI(javax.swing.JComponent)
 
55
         */
 
56
        public static ComponentUI createUI(JComponent comp) {
 
57
                SubstanceCoreUtilities.testComponentCreationThreadingViolation(comp);
 
58
                return new SubstanceViewportUI();
 
59
        }
 
60
 
 
61
        @Override
 
62
        protected void installDefaults(JComponent c) {
 
63
                super.installDefaults(c);
 
64
                // support for per-window skins
 
65
                Color backgr = c.getBackground();
 
66
                if ((backgr == null) || (backgr instanceof UIResource)) {
 
67
                        Color backgroundFillColor = SubstanceColorUtilities
 
68
                                        .getBackgroundFillColor(c);
 
69
                        if (backgroundFillColor != null) {
 
70
                                c.setBackground(new ColorUIResource(backgroundFillColor));
 
71
                        }
 
72
                }
 
73
        }
 
74
 
 
75
        /*
 
76
         * (non-Javadoc)
 
77
         * 
 
78
         * @see javax.swing.plaf.ComponentUI#update(java.awt.Graphics,
 
79
         * javax.swing.JComponent)
 
80
         */
 
81
        @Override
 
82
        public void update(Graphics g, JComponent c) {
 
83
                if (!SubstanceLookAndFeel.isCurrentLookAndFeel())
 
84
                        return;
 
85
 
 
86
                if (toPaintBackground(c)) {
 
87
                        BackgroundPaintingUtils.update(g, c, false);
 
88
                }
 
89
                super.paint(g, c);
 
90
        }
 
91
 
 
92
        /**
 
93
         * Returns indication whether the viewport background should be filled.
 
94
         * 
 
95
         * @param c
 
96
         *            Component (should be {@link JViewport}).
 
97
         * @return <code>true</code> if the viewport background should be filled
 
98
         *         with the background color, <code>false</code> otherwise.
 
99
         */
 
100
        protected boolean toPaintBackground(JComponent c) {
 
101
                return SubstanceCoreUtilities.isOpaque(c);
 
102
        }
 
103
}