Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
6e80b33e
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看板
提交
6e80b33e
编写于
4月 05, 2018
作者:
S
sveerabhadra
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
8195738: scroll poistion in ScrollPane is reset after calling validate()
Reviewed-by: serb, ssadetsky
上级
c6a9b973
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
100 addition
and
11 deletion
+100
-11
src/windows/native/sun/windows/awt_ScrollPane.cpp
src/windows/native/sun/windows/awt_ScrollPane.cpp
+9
-11
test/java/awt/ScrollPane/ScrollPaneValidateTest.java
test/java/awt/ScrollPane/ScrollPaneValidateTest.java
+91
-0
未找到文件。
src/windows/native/sun/windows/awt_ScrollPane.cpp
浏览文件 @
6e80b33e
...
@@ -196,15 +196,7 @@ void AwtScrollPane::SetScrollInfo(int orient, int max, int page,
...
@@ -196,15 +196,7 @@ void AwtScrollPane::SetScrollInfo(int orient, int max, int page,
// and the page size changes
// and the page size changes
posAfter
=
GetScrollPos
(
orient
);
posAfter
=
GetScrollPos
(
orient
);
if
(
posBefore
!=
posAfter
)
{
if
(
posBefore
!=
posAfter
)
{
if
(
max
==
0
&&
posAfter
==
0
)
{
PostScrollEvent
(
orient
,
SB_THUMBPOSITION
,
posAfter
);
// Caller used nMin==nMax idiom to hide scrollbar.
// On the new themes (Windows XP, Vista) this would reset
// scroll position to zero ("just inside the range") (6404832).
//
PostScrollEvent
(
orient
,
SB_THUMBPOSITION
,
posBefore
);
}
else
{
PostScrollEvent
(
orient
,
SB_THUMBPOSITION
,
posAfter
);
}
}
}
}
}
...
@@ -263,8 +255,11 @@ void AwtScrollPane::RecalcSizes(int parentWidth, int parentHeight,
...
@@ -263,8 +255,11 @@ void AwtScrollPane::RecalcSizes(int parentWidth, int parentHeight,
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
env
->
DeleteLocalRef
(
hAdj
);
env
->
DeleteLocalRef
(
hAdj
);
}
else
{
}
else
{
SetScrollInfo
(
SB_HORZ
,
0
,
0
,
/* Set scroll info to imitate the behaviour and since we don't
need to display it, explicitly don't show the bar */
SetScrollInfo
(
SB_HORZ
,
childWidth
-
1
,
parentWidth
,
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
::
ShowScrollBar
(
GetHWnd
(),
SB_HORZ
,
false
);
}
}
if
(
needsVert
)
{
if
(
needsVert
)
{
...
@@ -275,8 +270,11 @@ void AwtScrollPane::RecalcSizes(int parentWidth, int parentHeight,
...
@@ -275,8 +270,11 @@ void AwtScrollPane::RecalcSizes(int parentWidth, int parentHeight,
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
env
->
DeleteLocalRef
(
vAdj
);
env
->
DeleteLocalRef
(
vAdj
);
}
else
{
}
else
{
SetScrollInfo
(
SB_VERT
,
0
,
0
,
/* Set scroll info to imitate the behaviour and since we don't
need to display it, explicitly don't show the bar */
SetScrollInfo
(
SB_VERT
,
childHeight
-
1
,
parentHeight
,
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
(
policy
==
java_awt_ScrollPane_SCROLLBARS_ALWAYS
));
::
ShowScrollBar
(
GetHWnd
(),
SB_VERT
,
false
);
}
}
env
->
DeleteLocalRef
(
target
);
env
->
DeleteLocalRef
(
target
);
...
...
test/java/awt/ScrollPane/ScrollPaneValidateTest.java
0 → 100644
浏览文件 @
6e80b33e
/*
* Copyright (c) 2018, 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 8195738
* @summary scroll position in ScrollPane is reset after calling validate()
* @run main ScrollPaneValidateTest
*/
import
java.awt.ScrollPane
;
import
java.awt.BorderLayout
;
import
java.awt.GridLayout
;
import
java.awt.Button
;
import
java.awt.Dimension
;
import
java.awt.Frame
;
import
java.awt.Panel
;
import
java.awt.Point
;
import
java.awt.Robot
;
import
java.awt.AWTException
;
public
class
ScrollPaneValidateTest
extends
Frame
{
ScrollPane
pane
;
public
ScrollPaneValidateTest
()
{
setBounds
(
300
,
300
,
300
,
300
);
pane
=
new
ScrollPane
(
ScrollPane
.
SCROLLBARS_NEVER
);
add
(
pane
,
BorderLayout
.
NORTH
);
pane
.
add
(
new
InnerPanel
());
}
public
static
void
main
(
String
[]
args
)
throws
AWTException
{
Robot
robot
=
new
Robot
();
final
ScrollPaneValidateTest
obj
=
new
ScrollPaneValidateTest
();
obj
.
setVisible
(
true
);
// set to some scroll position
obj
.
pane
.
setScrollPosition
(
600
,
200
);
// get the newly set position
Point
scrollPosition
=
obj
.
pane
.
getScrollPosition
();
// call validate multiple times
obj
.
pane
.
validate
();
robot
.
delay
(
1000
);
obj
.
pane
.
validate
();
robot
.
delay
(
1000
);
// compare position after calling the validate function
if
(!
scrollPosition
.
equals
(
obj
.
pane
.
getScrollPosition
()))
{
obj
.
dispose
();
throw
new
RuntimeException
(
"Scrolling position is changed in ScrollPane"
);
}
obj
.
dispose
();
return
;
}
class
InnerPanel
extends
Panel
{
public
InnerPanel
()
{
this
.
setLayout
(
new
GridLayout
(
2
,
4
));
for
(
int
i
=
1
;
i
<=
8
;
i
++)
{
this
.
add
(
new
Button
(
"Button"
+
i
));
}
}
public
Dimension
getPreferredSize
()
{
return
new
Dimension
(
980
,
200
);
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录