提交 0d25bee6 编写于 作者: R rupashka

6587742: filling half of a JSlider's track is no longer optional

Summary: now OceanTheme uses the JSlider.isFilled property like other themes
Reviewed-by: alexp
上级 921a835c
...@@ -27,23 +27,13 @@ package javax.swing.plaf.metal; ...@@ -27,23 +27,13 @@ package javax.swing.plaf.metal;
import javax.swing.plaf.basic.BasicSliderUI; import javax.swing.plaf.basic.BasicSliderUI;
import java.awt.Component;
import java.awt.Container;
import java.awt.Graphics; import java.awt.Graphics;
import java.awt.Dimension; import java.awt.Dimension;
import java.awt.Rectangle; import java.awt.Rectangle;
import java.awt.Point;
import java.awt.Insets;
import java.awt.Color; import java.awt.Color;
import java.io.Serializable;
import java.awt.IllegalComponentStateException;
import java.awt.Polygon;
import java.beans.*; import java.beans.*;
import javax.swing.border.AbstractBorder;
import javax.swing.*; import javax.swing.*;
import javax.swing.event.*;
import javax.swing.plaf.*; import javax.swing.plaf.*;
/** /**
...@@ -131,10 +121,7 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -131,10 +121,7 @@ public class MetalSliderUI extends BasicSliderUI {
scrollListener.setScrollByBlock( false ); scrollListener.setScrollByBlock( false );
Object sliderFillProp = c.getClientProperty( SLIDER_FILL ); prepareFilledSliderField();
if ( sliderFillProp != null ) {
filledSlider = ((Boolean)sliderFillProp).booleanValue();
}
} }
protected PropertyChangeListener createPropertyChangeListener( JSlider slider ) { protected PropertyChangeListener createPropertyChangeListener( JSlider slider ) {
...@@ -145,15 +132,20 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -145,15 +132,20 @@ public class MetalSliderUI extends BasicSliderUI {
public void propertyChange( PropertyChangeEvent e ) { // listen for slider fill public void propertyChange( PropertyChangeEvent e ) { // listen for slider fill
super.propertyChange( e ); super.propertyChange( e );
String name = e.getPropertyName(); if (e.getPropertyName().equals(SLIDER_FILL)) {
if ( name.equals( SLIDER_FILL ) ) { prepareFilledSliderField();
if ( e.getNewValue() != null ) {
filledSlider = ((Boolean)e.getNewValue()).booleanValue();
} }
else {
filledSlider = false;
} }
} }
private void prepareFilledSliderField() {
// Use true for Ocean theme
filledSlider = MetalLookAndFeel.usingOcean();
Object sliderFillProp = slider.getClientProperty(SLIDER_FILL);
if (sliderFillProp != null) {
filledSlider = ((Boolean) sliderFillProp).booleanValue();
} }
} }
...@@ -172,22 +164,11 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -172,22 +164,11 @@ public class MetalSliderUI extends BasicSliderUI {
g.translate( -knobBounds.x, -knobBounds.y ); g.translate( -knobBounds.x, -knobBounds.y );
} }
/**
* If <code>chooseFirst</code>is true, <code>c1</code> is returned,
* otherwise <code>c2</code>.
*/
private Color chooseColor(boolean chooseFirst, Color c1, Color c2) {
if (chooseFirst) {
return c2;
}
return c1;
}
/** /**
* Returns a rectangle enclosing the track that will be painted. * Returns a rectangle enclosing the track that will be painted.
*/ */
private Rectangle getPaintTrackRect() { private Rectangle getPaintTrackRect() {
int trackLeft = 0, trackRight = 0, trackTop = 0, trackBottom = 0; int trackLeft = 0, trackRight, trackTop = 0, trackBottom;
if (slider.getOrientation() == JSlider.HORIZONTAL) { if (slider.getOrientation() == JSlider.HORIZONTAL) {
trackBottom = (trackRect.height - 1) - getThumbOverhang(); trackBottom = (trackRect.height - 1) - getThumbOverhang();
trackTop = trackBottom - (getTrackWidth() - 1); trackTop = trackBottom - (getTrackWidth() - 1);
...@@ -223,8 +204,8 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -223,8 +204,8 @@ public class MetalSliderUI extends BasicSliderUI {
int trackLeft = 0; int trackLeft = 0;
int trackTop = 0; int trackTop = 0;
int trackRight = 0; int trackRight;
int trackBottom = 0; int trackBottom;
// Draw the track // Draw the track
if ( slider.getOrientation() == JSlider.HORIZONTAL ) { if ( slider.getOrientation() == JSlider.HORIZONTAL ) {
...@@ -266,11 +247,11 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -266,11 +247,11 @@ public class MetalSliderUI extends BasicSliderUI {
// Draw the fill // Draw the fill
if ( filledSlider ) { if ( filledSlider ) {
int middleOfThumb = 0; int middleOfThumb;
int fillTop = 0; int fillTop;
int fillLeft = 0; int fillLeft;
int fillBottom = 0; int fillBottom;
int fillRight = 0; int fillRight;
if ( slider.getOrientation() == JSlider.HORIZONTAL ) { if ( slider.getOrientation() == JSlider.HORIZONTAL ) {
middleOfThumb = thumbRect.x + (thumbRect.width / 2); middleOfThumb = thumbRect.x + (thumbRect.width / 2);
...@@ -335,35 +316,34 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -335,35 +316,34 @@ public class MetalSliderUI extends BasicSliderUI {
int w = paintRect.width; int w = paintRect.width;
int h = paintRect.height; int h = paintRect.height;
if (!slider.isEnabled()) { if (slider.getOrientation() == JSlider.HORIZONTAL) {
g.setColor(MetalLookAndFeel.getControlShadow()); int middleOfThumb = thumbRect.x + thumbRect.width / 2 - paintRect.x;
g.drawRect(0, 0, w - 1, h - 1);
} if (slider.isEnabled()) {
else if (slider.getOrientation() == JSlider.HORIZONTAL) {
int middleOfThumb = thumbRect.x + (thumbRect.width / 2) -
paintRect.x;
int fillMinX; int fillMinX;
int fillMaxX; int fillMaxX;
if (middleOfThumb > 0) { if (middleOfThumb > 0) {
g.setColor(chooseColor(drawInverted, g.setColor(drawInverted ? MetalLookAndFeel.getControlDarkShadow() :
MetalLookAndFeel.getPrimaryControlDarkShadow(), MetalLookAndFeel.getPrimaryControlDarkShadow());
MetalLookAndFeel.getControlDarkShadow()));
g.drawRect(0, 0, middleOfThumb - 1, h - 1); g.drawRect(0, 0, middleOfThumb - 1, h - 1);
} }
if (middleOfThumb < w) { if (middleOfThumb < w) {
g.setColor(chooseColor(drawInverted, g.setColor(drawInverted ? MetalLookAndFeel.getPrimaryControlDarkShadow() :
MetalLookAndFeel.getControlDarkShadow(), MetalLookAndFeel.getControlDarkShadow());
MetalLookAndFeel.getPrimaryControlDarkShadow()));
g.drawRect(middleOfThumb, 0, w - middleOfThumb - 1, h - 1); g.drawRect(middleOfThumb, 0, w - middleOfThumb - 1, h - 1);
} }
if (filledSlider) {
g.setColor(MetalLookAndFeel.getPrimaryControlShadow()); g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
if (drawInverted) { if (drawInverted) {
fillMinX = middleOfThumb; fillMinX = middleOfThumb;
fillMaxX = w - 2; fillMaxX = w - 2;
g.drawLine(1, 1, middleOfThumb, 1); g.drawLine(1, 1, middleOfThumb, 1);
} } else {
else {
fillMinX = 1; fillMinX = 1;
fillMaxX = middleOfThumb; fillMaxX = middleOfThumb;
g.drawLine(middleOfThumb, 1, w - 1, 1); g.drawLine(middleOfThumb, 1, w - 1, 1);
...@@ -379,63 +359,96 @@ public class MetalSliderUI extends BasicSliderUI { ...@@ -379,63 +359,96 @@ public class MetalSliderUI extends BasicSliderUI {
g.drawLine(fillMinX, 4, fillMaxX, 4); g.drawLine(fillMinX, 4, fillMaxX, 4);
} }
} }
else { } else {
int middleOfThumb = thumbRect.y + (thumbRect.height / 2) - g.setColor(MetalLookAndFeel.getControlShadow());
paintRect.y;
if (middleOfThumb > 0) {
if (!drawInverted && filledSlider) {
g.fillRect(0, 0, middleOfThumb - 1, h - 1);
} else {
g.drawRect(0, 0, middleOfThumb - 1, h - 1);
}
}
if (middleOfThumb < w) {
if (drawInverted && filledSlider) {
g.fillRect(middleOfThumb, 0, w - middleOfThumb - 1, h - 1);
} else {
g.drawRect(middleOfThumb, 0, w - middleOfThumb - 1, h - 1);
}
}
}
} else {
int middleOfThumb = thumbRect.y + (thumbRect.height / 2) - paintRect.y;
if (slider.isEnabled()) {
int fillMinY; int fillMinY;
int fillMaxY; int fillMaxY;
if (middleOfThumb > 0) { if (middleOfThumb > 0) {
g.setColor(chooseColor(drawInverted, g.setColor(drawInverted ? MetalLookAndFeel.getPrimaryControlDarkShadow() :
MetalLookAndFeel.getControlDarkShadow(), MetalLookAndFeel.getControlDarkShadow());
MetalLookAndFeel.getPrimaryControlDarkShadow()));
g.drawRect(0, 0, w - 1, middleOfThumb - 1); g.drawRect(0, 0, w - 1, middleOfThumb - 1);
} }
if (middleOfThumb < h) { if (middleOfThumb < h) {
g.setColor(chooseColor(drawInverted, g.setColor(drawInverted ? MetalLookAndFeel.getControlDarkShadow() :
MetalLookAndFeel.getPrimaryControlDarkShadow(), MetalLookAndFeel.getPrimaryControlDarkShadow());
MetalLookAndFeel.getControlDarkShadow()));
g.drawRect(0, middleOfThumb, w - 1, h - middleOfThumb - 1); g.drawRect(0, middleOfThumb, w - 1, h - middleOfThumb - 1);
} }
if (filledSlider) {
g.setColor(MetalLookAndFeel.getPrimaryControlShadow()); g.setColor(MetalLookAndFeel.getPrimaryControlShadow());
if (drawInverted()) { if (drawInverted()) {
fillMinY = 1; fillMinY = 1;
fillMaxY = middleOfThumb; fillMaxY = middleOfThumb;
if (leftToRight) { if (leftToRight) {
g.drawLine(1, middleOfThumb, 1, h - 1); g.drawLine(1, middleOfThumb, 1, h - 1);
} } else {
else {
g.drawLine(w - 2, middleOfThumb, w - 2, h - 1); g.drawLine(w - 2, middleOfThumb, w - 2, h - 1);
} }
} } else {
else {
fillMinY = middleOfThumb; fillMinY = middleOfThumb;
fillMaxY = h - 2; fillMaxY = h - 2;
if (leftToRight) { if (leftToRight) {
g.drawLine(1, 1, 1, middleOfThumb); g.drawLine(1, 1, 1, middleOfThumb);
} } else {
else {
g.drawLine(w - 2, 1, w - 2, middleOfThumb); g.drawLine(w - 2, 1, w - 2, middleOfThumb);
} }
} }
if (w == 6) { if (w == 6) {
g.setColor(chooseColor(!leftToRight, g.setColor(leftToRight ? MetalLookAndFeel.getWhite() : MetalLookAndFeel.getPrimaryControlShadow());
MetalLookAndFeel.getWhite(),
MetalLookAndFeel.getPrimaryControlShadow()));
g.drawLine(1, fillMinY, 1, fillMaxY); g.drawLine(1, fillMinY, 1, fillMaxY);
g.setColor(chooseColor(!leftToRight, sliderAltTrackColor, g.setColor(leftToRight ? sliderAltTrackColor : MetalLookAndFeel.getControlShadow());
MetalLookAndFeel.getControlShadow()));
g.drawLine(2, fillMinY, 2, fillMaxY); g.drawLine(2, fillMinY, 2, fillMaxY);
g.setColor(chooseColor(!leftToRight, g.setColor(leftToRight ? MetalLookAndFeel.getControlShadow() : sliderAltTrackColor);
MetalLookAndFeel.getControlShadow(),
sliderAltTrackColor));
g.drawLine(3, fillMinY, 3, fillMaxY); g.drawLine(3, fillMinY, 3, fillMaxY);
g.setColor(chooseColor(!leftToRight, g.setColor(leftToRight ? MetalLookAndFeel.getPrimaryControlShadow() : MetalLookAndFeel.getWhite());
MetalLookAndFeel.getPrimaryControlShadow(),
MetalLookAndFeel.getWhite()));
g.drawLine(4, fillMinY, 4, fillMaxY); g.drawLine(4, fillMinY, 4, fillMaxY);
} }
} }
} else {
g.setColor(MetalLookAndFeel.getControlShadow());
if (middleOfThumb > 0) {
if (drawInverted && filledSlider) {
g.fillRect(0, 0, w - 1, middleOfThumb - 1);
} else {
g.drawRect(0, 0, w - 1, middleOfThumb - 1);
}
}
if (middleOfThumb < h) {
if (!drawInverted && filledSlider) {
g.fillRect(0, middleOfThumb, w - 1, h - middleOfThumb - 1);
} else {
g.drawRect(0, middleOfThumb, w - 1, h - middleOfThumb - 1);
}
}
}
}
g.translate(-paintRect.x, -paintRect.y); g.translate(-paintRect.x, -paintRect.y);
} }
......
<html>
<body>
<applet code="bug6587742.class" width=800 height=600></applet>
Select every theme and check that all sliders looks good.
Note that every slider has a tooltip text with information about
slider configuration.
There is a small difference in sliders with property "filled = null" (it's
default behaviour when property JSlider.isFilled is not setted)
for themes:
1. OceanTheme - sliders look like filled
2. DefaultMetalTheme - sliders look like NOT filled
</body>
</html>
/*
* Copyright 2008 Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*/
/* @test
* @bug 6587742
* @summary filling half of a JSlider's track is no longer optional
* @author Pavel Porvatov
* @run applet/manual=done bug6587742.html
*/
import javax.swing.*;
import javax.swing.plaf.metal.DefaultMetalTheme;
import javax.swing.plaf.metal.MetalLookAndFeel;
import javax.swing.plaf.metal.MetalTheme;
import javax.swing.plaf.metal.OceanTheme;
import java.awt.event.ItemEvent;
import java.awt.event.ItemListener;
public class bug6587742 extends JApplet {
public void init() {
TestPanel panel = new TestPanel();
setContentPane(panel);
}
private class TestPanel extends JPanel {
private final JComboBox cbThemes = new JComboBox();
private TestPanel() {
// Fill cbThemes
cbThemes.addItem(new OceanTheme());
cbThemes.addItem(new DefaultMetalTheme());
cbThemes.addItemListener(new ItemListener() {
public void itemStateChanged(ItemEvent e) {
MetalTheme theme = (MetalTheme) cbThemes.getSelectedItem();
if (theme != null) {
MetalLookAndFeel.setCurrentTheme(theme);
// re-install the Metal Look and Feel
try {
UIManager.setLookAndFeel(new MetalLookAndFeel());
} catch (UnsupportedLookAndFeelException e1) {
JOptionPane.showMessageDialog(TestPanel.this, "Can't change theme: " + e1.getMessage(),
"Error", JOptionPane.ERROR_MESSAGE);
return;
}
SwingUtilities.updateComponentTreeUI(bug6587742.this);
}
}
});
JPanel pnVertical = new JPanel();
pnVertical.setLayout(new BoxLayout(pnVertical, BoxLayout.Y_AXIS));
for (int i = 0; i < 12; i++) {
int filled = i >> 2;
pnVertical.add(createSlider(false, filled > 1 ? null : Boolean.valueOf(filled == 1), (i & 2) == 0,
(i & 1) != 0));
}
JPanel pnHorizontal = new JPanel();
pnHorizontal.setLayout(new BoxLayout(pnHorizontal, BoxLayout.X_AXIS));
for (int i = 0; i < 12; i++) {
int filled = i >> 2;
pnHorizontal.add(createSlider(true, filled > 1 ? null : Boolean.valueOf(filled == 1), (i & 2) == 0,
(i & 1) != 0));
}
JTabbedPane tpSliders = new JTabbedPane();
tpSliders.add("Vertical sliders", pnVertical);
tpSliders.add("Horizontal sliders", pnHorizontal);
setLayout(new BoxLayout(this, BoxLayout.Y_AXIS));
add(new JLabel("Select theme:"));
add(cbThemes);
add(tpSliders);
}
}
private static JSlider createSlider(boolean vertical, Boolean filled, boolean enabled, boolean inverted) {
JSlider result = new JSlider(vertical ? SwingConstants.VERTICAL : SwingConstants.HORIZONTAL, 0, 100, 50);
result.setMajorTickSpacing(20);
result.setMinorTickSpacing(5);
result.setPaintTicks(true);
result.setPaintLabels(true);
result.setEnabled(enabled);
if (filled != null) {
result.putClientProperty("JSlider.isFilled", filled);
}
result.setInverted(inverted);
result.setToolTipText("<html>vertical = " + vertical + "<br>enabled = " + enabled + "<br>filled = " + filled +
"<br>inverted = " + inverted + "</html>");
return result;
}
}
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册