Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
555a6d52
D
dragonwell8_jdk
项目概览
openanolis
/
dragonwell8_jdk
通知
4
Star
2
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
dragonwell8_jdk
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
555a6d52
编写于
10月 29, 2015
作者:
A
aivanov
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8134828: Scrollbar thumb disappears with Nimbus L&F
Reviewed-by: alexsch, alexp
上级
29617d3c
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
118 addition
and
18 deletion
+118
-18
src/share/classes/javax/swing/plaf/nimbus/AbstractRegionPainter.java
...lasses/javax/swing/plaf/nimbus/AbstractRegionPainter.java
+0
-4
src/share/classes/javax/swing/plaf/nimbus/skin.laf
src/share/classes/javax/swing/plaf/nimbus/skin.laf
+11
-7
src/share/classes/javax/swing/plaf/synth/SynthProgressBarUI.java
...re/classes/javax/swing/plaf/synth/SynthProgressBarUI.java
+14
-7
test/javax/swing/plaf/nimbus/8041642/ScrollBarThumbVisibleTest.java
.../swing/plaf/nimbus/8041642/ScrollBarThumbVisibleTest.java
+93
-0
未找到文件。
src/share/classes/javax/swing/plaf/nimbus/AbstractRegionPainter.java
浏览文件 @
555a6d52
...
@@ -625,10 +625,6 @@ public abstract class AbstractRegionPainter implements Painter<JComponent> {
...
@@ -625,10 +625,6 @@ public abstract class AbstractRegionPainter implements Painter<JComponent> {
// check if we can scale to the requested size
// check if we can scale to the requested size
Dimension
canvas
=
ctx
.
canvasSize
;
Dimension
canvas
=
ctx
.
canvasSize
;
Insets
insets
=
ctx
.
stretchingInsets
;
Insets
insets
=
ctx
.
stretchingInsets
;
if
(
insets
.
left
+
insets
.
right
>
w
||
insets
.
top
+
insets
.
bottom
>
h
)
{
return
;
}
if
(
w
<=
(
canvas
.
width
*
ctx
.
maxHorizontalScaleFactor
)
&&
h
<=
(
canvas
.
height
*
ctx
.
maxVerticalScaleFactor
))
{
if
(
w
<=
(
canvas
.
width
*
ctx
.
maxHorizontalScaleFactor
)
&&
h
<=
(
canvas
.
height
*
ctx
.
maxVerticalScaleFactor
))
{
// get image at canvas size
// get image at canvas size
VolatileImage
img
=
getImage
(
g
.
getDeviceConfiguration
(),
c
,
canvas
.
width
,
canvas
.
height
,
extendedCacheKeys
);
VolatileImage
img
=
getImage
(
g
.
getDeviceConfiguration
(),
c
,
canvas
.
width
,
canvas
.
height
,
extendedCacheKeys
);
...
...
src/share/classes/javax/swing/plaf/nimbus/skin.laf
浏览文件 @
555a6d52
<?xml version="1.0" encoding="UTF-8"?>
<?xml version="1.0" encoding="UTF-8"?>
<!--
<!--
Copyright (c) 1998, 201
4
, Oracle and/or its affiliates. All rights reserved.
Copyright (c) 1998, 201
5
, Oracle and/or its affiliates. All rights reserved.
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
This code is free software; you can redistribute it and/or modify it
This code is free software; you can redistribute it and/or modify it
...
@@ -16195,6 +16195,10 @@
...
@@ -16195,6 +16195,10 @@
<dimension width="150" height="19"/>
<dimension width="150" height="19"/>
</uiProperty>
</uiProperty>
<uiProperty name="cycleTime" type="INT" value="250"/>
<uiProperty name="cycleTime" type="INT" value="250"/>
<uiProperty name="minBarSize" type="DIMENSION">
<dimension width="6" height="6"/>
</uiProperty>
<uiProperty name="glowWidth" type="INT" value="2"/>
</uiproperties>
</uiproperties>
</style>
</style>
<backgroundStates>
<backgroundStates>
...
@@ -16351,7 +16355,7 @@
...
@@ -16351,7 +16355,7 @@
<canvas>
<canvas>
<size width="27" height="19"/>
<size width="27" height="19"/>
<nextLayerNameIndex>2</nextLayerNameIndex>
<nextLayerNameIndex>2</nextLayerNameIndex>
<stretchingInsets top="
5" bottom="5" left="5" right="5
"/>
<stretchingInsets top="
3" bottom="3" left="3" right="3
"/>
<layer name="Layer 1">
<layer name="Layer 1">
<opacity>1.0</opacity>
<opacity>1.0</opacity>
<fillOpacity>1.0</fillOpacity>
<fillOpacity>1.0</fillOpacity>
...
@@ -16444,7 +16448,7 @@
...
@@ -16444,7 +16448,7 @@
<canvas>
<canvas>
<size width="27" height="19"/>
<size width="27" height="19"/>
<nextLayerNameIndex>2</nextLayerNameIndex>
<nextLayerNameIndex>2</nextLayerNameIndex>
<stretchingInsets top="
5" bottom="5" left="5" right="5
"/>
<stretchingInsets top="
3" bottom="3" left="3" right="3
"/>
<layer name="Layer 1">
<layer name="Layer 1">
<opacity>1.0</opacity>
<opacity>1.0</opacity>
<fillOpacity>1.0</fillOpacity>
<fillOpacity>1.0</fillOpacity>
...
@@ -16528,7 +16532,7 @@
...
@@ -16528,7 +16532,7 @@
<canvas>
<canvas>
<size width="30" height="13"/>
<size width="30" height="13"/>
<nextLayerNameIndex>2</nextLayerNameIndex>
<nextLayerNameIndex>2</nextLayerNameIndex>
<stretchingInsets top="
5" bottom="5" left="5" right="5
"/>
<stretchingInsets top="
3" bottom="3" left="3" right="3
"/>
<layer name="Layer 1">
<layer name="Layer 1">
<opacity>1.0</opacity>
<opacity>1.0</opacity>
<fillOpacity>1.0</fillOpacity>
<fillOpacity>1.0</fillOpacity>
...
@@ -16619,7 +16623,7 @@
...
@@ -16619,7 +16623,7 @@
<canvas>
<canvas>
<size width="27" height="19"/>
<size width="27" height="19"/>
<nextLayerNameIndex>2</nextLayerNameIndex>
<nextLayerNameIndex>2</nextLayerNameIndex>
<stretchingInsets top="
5" bottom="5" left="5" right="5
"/>
<stretchingInsets top="
3" bottom="3" left="3" right="3
"/>
<layer name="Layer 1">
<layer name="Layer 1">
<opacity>1.0</opacity>
<opacity>1.0</opacity>
<fillOpacity>1.0</fillOpacity>
<fillOpacity>1.0</fillOpacity>
...
@@ -16701,7 +16705,7 @@
...
@@ -16701,7 +16705,7 @@
<canvas>
<canvas>
<size width="27" height="19"/>
<size width="27" height="19"/>
<nextLayerNameIndex>2</nextLayerNameIndex>
<nextLayerNameIndex>2</nextLayerNameIndex>
<stretchingInsets top="
5" bottom="5" left="5" right="5
"/>
<stretchingInsets top="
3" bottom="3" left="3" right="3
"/>
<layer name="Layer 1">
<layer name="Layer 1">
<opacity>1.0</opacity>
<opacity>1.0</opacity>
<fillOpacity>1.0</fillOpacity>
<fillOpacity>1.0</fillOpacity>
...
@@ -16785,7 +16789,7 @@
...
@@ -16785,7 +16789,7 @@
<canvas>
<canvas>
<size width="30" height="13"/>
<size width="30" height="13"/>
<nextLayerNameIndex>2</nextLayerNameIndex>
<nextLayerNameIndex>2</nextLayerNameIndex>
<stretchingInsets top="
5" bottom="5" left="5" right="5
"/>
<stretchingInsets top="
3" bottom="3" left="3" right="3
"/>
<layer name="Layer 1">
<layer name="Layer 1">
<opacity>1.0</opacity>
<opacity>1.0</opacity>
<fillOpacity>1.0</fillOpacity>
<fillOpacity>1.0</fillOpacity>
src/share/classes/javax/swing/plaf/synth/SynthProgressBarUI.java
浏览文件 @
555a6d52
/*
/*
* Copyright (c) 2002, 201
3
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2002, 201
5
, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
*
* This code is free software; you can redistribute it and/or modify it
* This code is free software; you can redistribute it and/or modify it
...
@@ -49,6 +49,8 @@ public class SynthProgressBarUI extends BasicProgressBarUI
...
@@ -49,6 +49,8 @@ public class SynthProgressBarUI extends BasicProgressBarUI
private
boolean
paintOutsideClip
;
private
boolean
paintOutsideClip
;
private
boolean
tileWhenIndeterminate
;
//whether to tile indeterminate painting
private
boolean
tileWhenIndeterminate
;
//whether to tile indeterminate painting
private
int
tileWidth
;
//the width of each tile
private
int
tileWidth
;
//the width of each tile
private
Dimension
minBarSize
;
// minimal visible bar size
private
int
glowWidth
;
// Glow around the bar foreground
/**
/**
* Creates a new UI object for the given component.
* Creates a new UI object for the given component.
...
@@ -114,6 +116,8 @@ public class SynthProgressBarUI extends BasicProgressBarUI
...
@@ -114,6 +116,8 @@ public class SynthProgressBarUI extends BasicProgressBarUI
tileWidth
*=
0.784
;
tileWidth
*=
0.784
;
}
}
}
}
minBarSize
=
(
Dimension
)
style
.
get
(
context
,
"ProgressBar.minBarSize"
);
glowWidth
=
style
.
getInt
(
context
,
"ProgressBar.glowWidth"
,
0
);
context
.
dispose
();
context
.
dispose
();
}
}
...
@@ -258,7 +262,7 @@ public class SynthProgressBarUI extends BasicProgressBarUI
...
@@ -258,7 +262,7 @@ public class SynthProgressBarUI extends BasicProgressBarUI
if
(!
SynthLookAndFeel
.
isLeftToRight
(
pBar
))
{
if
(!
SynthLookAndFeel
.
isLeftToRight
(
pBar
))
{
x
=
pBar
.
getWidth
()
-
pBarInsets
.
right
-
width
x
=
pBar
.
getWidth
()
-
pBarInsets
.
right
-
width
-
progressPadding
;
-
progressPadding
-
glowWidth
;
}
}
}
else
{
// JProgressBar.VERTICAL
}
else
{
// JProgressBar.VERTICAL
x
=
pBarInsets
.
left
+
progressPadding
;
x
=
pBarInsets
.
left
+
progressPadding
;
...
@@ -271,9 +275,9 @@ public class SynthProgressBarUI extends BasicProgressBarUI
...
@@ -271,9 +275,9 @@ public class SynthProgressBarUI extends BasicProgressBarUI
y
=
pBar
.
getHeight
()
-
pBarInsets
.
bottom
-
height
y
=
pBar
.
getHeight
()
-
pBarInsets
.
bottom
-
height
-
progressPadding
;
-
progressPadding
;
// When the progress bar is vertical we always paint
if
(
SynthLookAndFeel
.
isLeftToRight
(
pBar
))
{
// from bottom to top, not matter what the component
y
-=
glowWidth
;
// orientation is.
}
}
}
}
}
}
else
{
}
else
{
...
@@ -307,8 +311,11 @@ public class SynthProgressBarUI extends BasicProgressBarUI
...
@@ -307,8 +311,11 @@ public class SynthProgressBarUI extends BasicProgressBarUI
}
}
g
.
setClip
(
clip
);
g
.
setClip
(
clip
);
}
else
{
}
else
{
context
.
getPainter
().
paintProgressBarForeground
(
context
,
g
,
if
(
minBarSize
==
null
||
(
width
>=
minBarSize
.
width
x
,
y
,
width
,
height
,
pBar
.
getOrientation
());
&&
height
>=
minBarSize
.
height
))
{
context
.
getPainter
().
paintProgressBarForeground
(
context
,
g
,
x
,
y
,
width
,
height
,
pBar
.
getOrientation
());
}
}
}
if
(
pBar
.
isStringPainted
())
{
if
(
pBar
.
isStringPainted
())
{
...
...
test/javax/swing/plaf/nimbus/8041642/ScrollBarThumbVisibleTest.java
0 → 100644
浏览文件 @
555a6d52
/*
* Copyright (c) 2015, Oracle and/or its affiliates. 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/* @test
@bug 8134828
@summary Scrollbar thumb disappears with Nimbus L&F
@author Semyon Sadetsky
*/
import
javax.swing.*
;
import
java.awt.*
;
public
class
ScrollBarThumbVisibleTest
{
private
static
JFrame
frame
;
private
static
Point
point
;
private
static
JScrollBar
bar
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
for
(
UIManager
.
LookAndFeelInfo
info
:
UIManager
.
getInstalledLookAndFeels
())
{
if
(
"Nimbus"
.
equals
(
info
.
getName
()))
{
try
{
UIManager
.
setLookAndFeel
(
info
.
getClassName
());
}
catch
(
Exception
ex
)
{
}
break
;
}
}
try
{
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
public
void
run
()
{
frame
=
new
JFrame
();
frame
.
setUndecorated
(
true
);
frame
.
setDefaultCloseOperation
(
JFrame
.
EXIT_ON_CLOSE
);
setup
(
frame
);
}
});
final
Robot
robot
=
new
Robot
();
robot
.
delay
(
200
);
robot
.
waitForIdle
();
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
point
=
bar
.
getLocationOnScreen
();
}
});
Color
color1
=
robot
.
getPixelColor
(
point
.
x
+
48
,
point
.
y
+
55
);
Color
color2
=
robot
.
getPixelColor
(
point
.
x
+
48
,
point
.
y
+
125
);
System
.
out
.
println
(
color1
);
System
.
out
.
println
(
color2
);
if
(
color1
.
equals
(
color2
))
{
throw
new
RuntimeException
(
"Thump is not visible"
);
}
}
finally
{
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
frame
.
dispose
();
}
});
}
System
.
out
.
println
(
"ok"
);
}
static
void
setup
(
JFrame
frame
)
{
bar
=
new
JScrollBar
(
Adjustable
.
VERTICAL
,
500
,
0
,
0
,
1000
);
frame
.
getContentPane
().
add
(
bar
);
frame
.
setSize
(
50
,
250
);
frame
.
setLocation
(
100
,
100
);
frame
.
setVisible
(
true
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录