Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
6b8e61fd
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看板
提交
6b8e61fd
编写于
10月 12, 2012
作者:
L
lana
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
ceb1ba7a
ad62a4f7
变更
41
隐藏空白更改
内联
并排
Showing
41 changed file
with
1689 addition
and
224 deletion
+1689
-224
.hgtags
.hgtags
+3
-0
make/sun/osxapp/Makefile
make/sun/osxapp/Makefile
+36
-2
make/sun/osxapp/ToBin.java
make/sun/osxapp/ToBin.java
+50
-0
src/macosx/classes/sun/lwawt/LWCanvasPeer.java
src/macosx/classes/sun/lwawt/LWCanvasPeer.java
+19
-8
src/macosx/classes/sun/lwawt/LWCheckboxPeer.java
src/macosx/classes/sun/lwawt/LWCheckboxPeer.java
+6
-1
src/macosx/classes/sun/lwawt/LWComponentPeer.java
src/macosx/classes/sun/lwawt/LWComponentPeer.java
+45
-30
src/macosx/classes/sun/lwawt/LWContainerPeer.java
src/macosx/classes/sun/lwawt/LWContainerPeer.java
+2
-2
src/macosx/classes/sun/lwawt/LWLabelPeer.java
src/macosx/classes/sun/lwawt/LWLabelPeer.java
+2
-31
src/macosx/classes/sun/lwawt/LWListPeer.java
src/macosx/classes/sun/lwawt/LWListPeer.java
+55
-23
src/macosx/classes/sun/lwawt/LWPanelPeer.java
src/macosx/classes/sun/lwawt/LWPanelPeer.java
+0
-6
src/macosx/classes/sun/lwawt/LWScrollBarPeer.java
src/macosx/classes/sun/lwawt/LWScrollBarPeer.java
+0
-8
src/macosx/classes/sun/lwawt/LWTextAreaPeer.java
src/macosx/classes/sun/lwawt/LWTextAreaPeer.java
+38
-11
src/macosx/classes/sun/lwawt/LWTextComponentPeer.java
src/macosx/classes/sun/lwawt/LWTextComponentPeer.java
+7
-11
src/macosx/classes/sun/lwawt/LWTextFieldPeer.java
src/macosx/classes/sun/lwawt/LWTextFieldPeer.java
+3
-14
src/macosx/classes/sun/lwawt/LWToolkit.java
src/macosx/classes/sun/lwawt/LWToolkit.java
+1
-1
src/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java
src/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java
+3
-0
src/macosx/native/sun/awt/AWTEvent.m
src/macosx/native/sun/awt/AWTEvent.m
+4
-3
src/macosx/native/sun/awt/AWTView.m
src/macosx/native/sun/awt/AWTView.m
+4
-1
src/macosx/native/sun/awt/CTextPipe.m
src/macosx/native/sun/awt/CTextPipe.m
+6
-7
src/macosx/native/sun/awt/InitIDs.m
src/macosx/native/sun/awt/InitIDs.m
+4
-1
src/macosx/native/sun/awt/LWCToolkit.m
src/macosx/native/sun/awt/LWCToolkit.m
+15
-5
src/macosx/native/sun/osxapp/NSApplicationAWT.h
src/macosx/native/sun/osxapp/NSApplicationAWT.h
+4
-0
src/macosx/native/sun/osxapp/NSApplicationAWT.m
src/macosx/native/sun/osxapp/NSApplicationAWT.m
+58
-14
src/macosx/native/sun/osxapp/resource/icons/JavaApp.icns
src/macosx/native/sun/osxapp/resource/icons/JavaApp.icns
+0
-0
src/share/classes/java/awt/Choice.java
src/share/classes/java/awt/Choice.java
+14
-1
src/share/classes/javax/swing/ToolTipManager.java
src/share/classes/javax/swing/ToolTipManager.java
+42
-8
src/share/classes/javax/swing/colorchooser/DefaultSwatchChooserPanel.java
...s/javax/swing/colorchooser/DefaultSwatchChooserPanel.java
+129
-9
src/solaris/classes/sun/java2d/xr/XRDrawImage.java
src/solaris/classes/sun/java2d/xr/XRDrawImage.java
+3
-2
src/solaris/native/sun/awt/initIDs.c
src/solaris/native/sun/awt/initIDs.c
+6
-0
src/windows/native/sun/windows/awt_Choice.cpp
src/windows/native/sun/windows/awt_Choice.cpp
+21
-6
src/windows/native/sun/windows/awt_Choice.h
src/windows/native/sun/windows/awt_Choice.h
+0
-1
src/windows/native/sun/windows/awt_Component.cpp
src/windows/native/sun/windows/awt_Component.cpp
+34
-16
src/windows/native/sun/windows/awt_Component.h
src/windows/native/sun/windows/awt_Component.h
+2
-2
test/java/awt/Choice/ItemStateChangeTest/ItemStateChangeTest.java
...a/awt/Choice/ItemStateChangeTest/ItemStateChangeTest.java
+128
-0
test/java/awt/List/EmptyListEventTest/EmptyListEventTest.java
.../java/awt/List/EmptyListEventTest/EmptyListEventTest.java
+158
-0
test/java/awt/ScrollPane/ScrollPanePreferredSize/ScrollPanePreferredSize.java
...Pane/ScrollPanePreferredSize/ScrollPanePreferredSize.java
+65
-0
test/java/awt/TextArea/TextAreaTwicePack/TextAreaTwicePack.java
...ava/awt/TextArea/TextAreaTwicePack/TextAreaTwicePack.java
+66
-0
test/java/awt/event/KeyEvent/DeadKey/DeadKeyMacOSXInputText.java
...va/awt/event/KeyEvent/DeadKey/DeadKeyMacOSXInputText.java
+131
-0
test/javax/swing/JColorChooser/Test7194184.java
test/javax/swing/JColorChooser/Test7194184.java
+113
-0
test/javax/swing/ToolTipManager/7123767/bug7123767.java
test/javax/swing/ToolTipManager/7123767/bug7123767.java
+220
-0
test/sun/java2d/pipe/InterpolationQualityTest.java
test/sun/java2d/pipe/InterpolationQualityTest.java
+192
-0
未找到文件。
.hgtags
浏览文件 @
6b8e61fd
...
@@ -179,3 +179,6 @@ e8569a473cee7f4955bd9e76a9bdf6c6a07ced27 jdk8-b52
...
@@ -179,3 +179,6 @@ e8569a473cee7f4955bd9e76a9bdf6c6a07ced27 jdk8-b52
1f3f4b333341873f00da3dee85e4879f0e89c9bb jdk8-b55
1f3f4b333341873f00da3dee85e4879f0e89c9bb jdk8-b55
2e9eeef2909b33c9224a024afddb61ccb0b77f14 jdk8-b56
2e9eeef2909b33c9224a024afddb61ccb0b77f14 jdk8-b56
51594d095a4bcffac4a314bf6e148214501399e0 jdk8-b57
51594d095a4bcffac4a314bf6e148214501399e0 jdk8-b57
d94613ac03d8de375ef60493e2bb76dbd30d875d jdk8-b58
abad1f417bd3df4296631fc943cd3b7f5062c88a jdk8-b59
cec8fa02f15634acd7d02d04b0b2d8c044cdbaaa jdk8-b60
make/sun/osxapp/Makefile
浏览文件 @
6b8e61fd
...
@@ -28,6 +28,11 @@ LIBRARY = osxapp
...
@@ -28,6 +28,11 @@ LIBRARY = osxapp
PRODUCT
=
sun
PRODUCT
=
sun
include
$(BUILDDIR)/common/Defs.gmk
include
$(BUILDDIR)/common/Defs.gmk
GEN_DIR
=
$(GENSRCDIR)
/sun/osxapp
ICON_DATA
=
$(GEN_DIR)
/AWTIconData.h
CLASSES_INIT
+=
$(ICON_DATA)
#
#
# Files
# Files
#
#
...
@@ -63,6 +68,7 @@ OTHER_LDLIBS += \
...
@@ -63,6 +68,7 @@ OTHER_LDLIBS += \
-framework
QuartzCore
-framework
QuartzCore
CPPFLAGS
+=
\
CPPFLAGS
+=
\
-I
$(GEN_DIR)
\
$(
call
NativeSrcDirList,-I,/native/sun/osxapp
)
$(
call
NativeSrcDirList,-I,/native/sun/osxapp
)
...
@@ -70,6 +76,34 @@ ifeq ($(MILESTONE), internal)
...
@@ -70,6 +76,34 @@ ifeq ($(MILESTONE), internal)
CPPFLAGS
+=
-DINTERNAL_BUILD
CPPFLAGS
+=
-DINTERNAL_BUILD
endif
endif
clean clobber
::
TEMPDIR_CLASSES
=
$(TEMPDIR)
/classes
$(TEMPDIR_CLASSES)/sun/osxapp/ToBin.class
:
ToBin.java
@
$
(
prep-target
)
$(BOOT_JAVAC_CMD)
-d
$(TEMPDIR_CLASSES)
$<
ifdef
OPENJDK
ICONS_PATH_PREFIX
=
$(PLATFORM_SRC_MACOS)
else
ICONS_PATH_PREFIX
=
$(CLOSED_SRC)
/macosx
endif
generated.clean
:
$(RM)
-r
$(GEN_DIR)
/
*
.h
ICONPATH
=
$(ICONS_PATH_PREFIX)
/native/sun/osxapp/resource/icons
ICON
=
$(ICONPATH)
/JavaApp.icns
$(GEN_DIR)/AWTIconData.h
:
$(TEMPDIR_CLASSES)/sun/osxapp/ToBin.class $(ICON)
$
(
prep-target
)
$(RM)
$(ICON_DATA)
$(ECHO)
"static unsigned char sAWTIconData[] = { "
>>
$(ICON_DATA)
;
\
$(CAT)
$(ICON)
|
\
$(BOOT_JAVA_CMD)
-cp
$(TEMPDIR_CLASSES)
-Djava
.awt.headless
=
true
\
sun.osxapp.ToBin
>>
$(ICON_DATA)
;
\
$(ECHO)
"};"
>>
$(ICON_DATA)
;
clean clobber
::
generated.clean
.PHONY
:
.PHONY
:
generated.clean
make/sun/osxapp/ToBin.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
package
sun.osxapp
;
import
java.io.*
;
public
class
ToBin
{
public
static
void
main
(
String
[]
args
)
throws
Exception
{
ByteArrayOutputStream
baos
=
new
ByteArrayOutputStream
();
int
nRead
;
byte
[]
data
=
new
byte
[
4096
];
while
((
nRead
=
System
.
in
.
read
(
data
,
0
,
data
.
length
))
!=
-
1
)
{
baos
.
write
(
data
,
0
,
nRead
);
}
baos
.
flush
();
byte
[]
buf
=
baos
.
toByteArray
();
for
(
int
i
=
0
;
i
<
buf
.
length
;
i
++)
{
System
.
out
.
print
(
String
.
format
(
"0x%1$02X"
,
buf
[
i
])
+
", "
);
if
(
i
%
20
==
0
)
{
System
.
out
.
println
();
}
}
}
}
src/macosx/classes/sun/lwawt/LWCanvasPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -26,26 +26,27 @@
...
@@ -26,26 +26,27 @@
package
sun.lwawt
;
package
sun.lwawt
;
import
java.awt.AWTException
;
import
java.awt.BufferCapabilities
;
import
java.awt.BufferCapabilities
;
import
java.awt.Canvas
;
import
java.awt.Component
;
import
java.awt.Component
;
import
java.awt.Dimension
;
import
java.awt.GraphicsConfiguration
;
import
java.awt.GraphicsConfiguration
;
import
java.awt.Image
;
import
java.awt.Image
;
import
java.awt.peer.CanvasPeer
;
import
java.awt.peer.CanvasPeer
;
import
javax.swing.JComponent
;
import
javax.swing.JComponent
;
final
class
LWCanvasPeer
extends
LWComponentPeer
<
Component
,
JComponent
>
class
LWCanvasPeer
<
T
extends
Component
,
D
extends
JComponent
>
implements
CanvasPeer
{
extends
LWComponentPeer
<
T
,
D
>
implements
CanvasPeer
{
LWCanvasPeer
(
final
Canvas
target
,
PlatformComponent
platformComponent
)
{
LWCanvasPeer
(
final
T
target
,
final
PlatformComponent
platformComponent
)
{
super
(
target
,
platformComponent
);
super
(
target
,
platformComponent
);
}
}
// ---- PEER METHODS ---- //
// ---- PEER METHODS ---- //
@Override
@Override
public
void
createBuffers
(
int
numBuffers
,
BufferCapabilities
caps
)
{
public
void
createBuffers
(
int
numBuffers
,
BufferCapabilities
caps
)
throws
AWTException
{
// TODO
// TODO
}
}
...
@@ -67,10 +68,20 @@ final class LWCanvasPeer extends LWComponentPeer<Component, JComponent>
...
@@ -67,10 +68,20 @@ final class LWCanvasPeer extends LWComponentPeer<Component, JComponent>
}
}
@Override
@Override
public
GraphicsConfiguration
getAppropriateGraphicsConfiguration
(
public
final
GraphicsConfiguration
getAppropriateGraphicsConfiguration
(
GraphicsConfiguration
gc
)
GraphicsConfiguration
gc
)
{
{
// TODO
// TODO
return
gc
;
return
gc
;
}
}
@Override
public
final
Dimension
getPreferredSize
()
{
return
getMinimumSize
();
}
@Override
public
final
Dimension
getMinimumSize
()
{
return
getBounds
().
getSize
();
}
}
}
src/macosx/classes/sun/lwawt/LWCheckboxPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -185,6 +185,11 @@ final class LWCheckboxPeer
...
@@ -185,6 +185,11 @@ final class LWCheckboxPeer
rb
.
setBounds
(
0
,
0
,
w
,
h
);
rb
.
setBounds
(
0
,
0
,
w
,
h
);
}
}
@Override
public
Dimension
getPreferredSize
()
{
return
getCurrentButton
().
getPreferredSize
();
}
@Override
@Override
@Transient
@Transient
public
Dimension
getMinimumSize
()
{
public
Dimension
getMinimumSize
()
{
...
...
src/macosx/classes/sun/lwawt/LWComponentPeer.java
浏览文件 @
6b8e61fd
...
@@ -123,7 +123,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
...
@@ -123,7 +123,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
// private volatile boolean paintPending;
// private volatile boolean paintPending;
private
volatile
boolean
isLayouting
;
private
volatile
boolean
isLayouting
;
private
D
delegate
=
null
;
private
final
D
delegate
;
private
Container
delegateContainer
;
private
Container
delegateContainer
;
private
Component
delegateDropTarget
;
private
Component
delegateDropTarget
;
private
final
Object
dropTargetLock
=
new
Object
();
private
final
Object
dropTargetLock
=
new
Object
();
...
@@ -133,6 +133,11 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
...
@@ -133,6 +133,11 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
private
final
PlatformComponent
platformComponent
;
private
final
PlatformComponent
platformComponent
;
/**
* Character with reasonable value between the minimum width and maximum.
*/
static
final
char
WIDE_CHAR
=
'0'
;
private
final
class
DelegateContainer
extends
Container
{
private
final
class
DelegateContainer
extends
Container
{
{
{
enableEvents
(
0xFFFFFFFF
);
enableEvents
(
0xFFFFFFFF
);
...
@@ -267,9 +272,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
...
@@ -267,9 +272,7 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
}
}
protected
final
D
getDelegate
()
{
protected
final
D
getDelegate
()
{
synchronized
(
getStateLock
())
{
return
delegate
;
return
delegate
;
}
}
}
protected
Component
getDelegateFocusOwner
()
{
protected
Component
getDelegateFocusOwner
()
{
...
@@ -698,26 +701,23 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
...
@@ -698,26 +701,23 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
}
}
@Override
@Override
public
FontMetrics
getFontMetrics
(
Font
f
)
{
public
FontMetrics
getFontMetrics
(
final
Font
f
)
{
// Borrow the metrics from the top-level window
// Borrow the metrics from the top-level window
// return getWindowPeer().getFontMetrics(f);
// return getWindowPeer().getFontMetrics(f);
// Obtain the metrics from the offscreen window where this peer is
// Obtain the metrics from the offscreen window where this peer is
// mostly drawn to.
// mostly drawn to.
// TODO: check for "use platform metrics" settings
// TODO: check for "use platform metrics" settings
Graphics
g
=
getWindowPeer
().
get
Graphics
();
final
Graphics
g
=
getOnscreen
Graphics
();
try
{
if
(
g
!=
null
)
{
if
(
g
!=
null
)
{
try
{
return
g
.
getFontMetrics
(
f
);
return
g
.
getFontMetrics
(
f
);
}
else
{
}
finally
{
synchronized
(
getDelegateLock
())
{
return
delegateContainer
.
getFontMetrics
(
f
);
}
}
}
finally
{
if
(
g
!=
null
)
{
g
.
dispose
();
g
.
dispose
();
}
}
}
}
synchronized
(
getDelegateLock
())
{
return
delegateContainer
.
getFontMetrics
(
f
);
}
}
}
@Override
@Override
...
@@ -847,31 +847,46 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
...
@@ -847,31 +847,46 @@ public abstract class LWComponentPeer<T extends Component, D extends JComponent>
}
}
/**
/**
* Should be overridden in subclasses to forward the request
* Determines the preferred size of the component. By default forwards the
* to the Swing helper component, if required.
* request to the Swing helper component. Should be overridden in subclasses
* if required.
*/
*/
@Override
@Override
public
Dimension
getPreferredSize
()
{
public
Dimension
getPreferredSize
()
{
// It looks like a default implementation for all toolkits
final
Dimension
size
;
return
getMinimumSize
();
synchronized
(
getDelegateLock
())
{
size
=
getDelegate
().
getPreferredSize
();
}
return
validateSize
(
size
);
}
}
/*
/**
* Should be overridden in subclasses to forward the request
* Determines the minimum size of the component. By default forwards the
* to the Swing helper component.
* request to the Swing helper component. Should be overridden in subclasses
* if required.
*/
*/
@Override
@Override
public
Dimension
getMinimumSize
()
{
public
Dimension
getMinimumSize
()
{
D
delegate
=
getDelegate
();
final
Dimension
size
;
synchronized
(
getDelegateLock
())
{
size
=
getDelegate
().
getMinimumSize
();
}
return
validateSize
(
size
);
}
if
(
delegate
==
null
)
{
/**
// Is it a correct default value?
* In some situations delegates can return empty minimum/preferred size.
return
getBounds
().
getSize
();
* (For example: empty JLabel, etc), but awt components never should be
}
else
{
* empty. In the XPeers or WPeers we use some magic constants, but here we
synchronized
(
getDelegateLock
())
{
* try to use something more useful,
return
delegate
.
getMinimumSize
();
*/
}
private
Dimension
validateSize
(
final
Dimension
size
)
{
if
(
size
.
width
==
0
||
size
.
height
==
0
)
{
final
FontMetrics
fm
=
getFontMetrics
(
getFont
());
size
.
width
=
fm
.
charWidth
(
WIDE_CHAR
);
size
.
height
=
fm
.
getHeight
();
}
}
return
size
;
}
}
@Override
@Override
...
...
src/macosx/classes/sun/lwawt/LWContainerPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -41,7 +41,7 @@ import java.util.List;
...
@@ -41,7 +41,7 @@ import java.util.List;
import
javax.swing.JComponent
;
import
javax.swing.JComponent
;
abstract
class
LWContainerPeer
<
T
extends
Container
,
D
extends
JComponent
>
abstract
class
LWContainerPeer
<
T
extends
Container
,
D
extends
JComponent
>
extends
LWC
omponent
Peer
<
T
,
D
>
extends
LWC
anvas
Peer
<
T
,
D
>
implements
ContainerPeer
implements
ContainerPeer
{
{
// List of child peers sorted by z-order from bottom-most
// List of child peers sorted by z-order from bottom-most
...
...
src/macosx/classes/sun/lwawt/LWLabelPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -26,37 +26,26 @@
...
@@ -26,37 +26,26 @@
package
sun.lwawt
;
package
sun.lwawt
;
import
java.awt.Dimension
;
import
java.awt.FontMetrics
;
import
java.awt.Label
;
import
java.awt.Label
;
import
java.awt.peer.LabelPeer
;
import
java.awt.peer.LabelPeer
;
import
javax.swing.JLabel
;
import
javax.swing.JLabel
;
import
javax.swing.SwingConstants
;
import
javax.swing.SwingConstants
;
import
javax.tools.annotation.GenerateNativeHeader
;
/**
/**
* Lightweight implementation of {@link LabelPeer}. Delegates most of the work
* Lightweight implementation of {@link LabelPeer}. Delegates most of the work
* to the {@link JLabel}.
* to the {@link JLabel}.
*/
*/
/* No native methods here, but the constants are needed in the supporting JNI code */
@GenerateNativeHeader
final
class
LWLabelPeer
extends
LWComponentPeer
<
Label
,
JLabel
>
final
class
LWLabelPeer
extends
LWComponentPeer
<
Label
,
JLabel
>
implements
LabelPeer
{
implements
LabelPeer
{
private
static
final
int
TEXT_XPAD
=
5
;
private
static
final
int
TEXT_YPAD
=
1
;
LWLabelPeer
(
final
Label
target
,
final
PlatformComponent
platformComponent
)
{
LWLabelPeer
(
final
Label
target
,
final
PlatformComponent
platformComponent
)
{
super
(
target
,
platformComponent
);
super
(
target
,
platformComponent
);
}
}
@Override
@Override
protected
JLabel
createDelegate
()
{
protected
JLabel
createDelegate
()
{
final
JLabel
label
=
new
JLabel
();
return
new
JLabel
();
label
.
setVerticalAlignment
(
SwingConstants
.
TOP
);
return
label
;
}
}
@Override
@Override
...
@@ -80,24 +69,6 @@ final class LWLabelPeer extends LWComponentPeer<Label, JLabel>
...
@@ -80,24 +69,6 @@ final class LWLabelPeer extends LWComponentPeer<Label, JLabel>
}
}
}
}
@Override
public
Dimension
getMinimumSize
()
{
int
w
=
TEXT_XPAD
;
int
h
=
TEXT_YPAD
;
final
FontMetrics
fm
=
getFontMetrics
(
getFont
());
if
(
fm
!=
null
)
{
final
String
text
;
synchronized
(
getDelegateLock
())
{
text
=
getDelegate
().
getText
();
}
if
(
text
!=
null
)
{
w
+=
fm
.
stringWidth
(
text
);
}
h
+=
fm
.
getHeight
();
}
return
new
Dimension
(
w
,
h
);
}
/**
/**
* Converts {@code Label} alignment constant to the {@code JLabel} constant.
* Converts {@code Label} alignment constant to the {@code JLabel} constant.
* If wrong Label alignment provided returns default alignment.
* If wrong Label alignment provided returns default alignment.
...
...
src/macosx/classes/sun/lwawt/LWListPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -32,10 +32,22 @@ import java.awt.event.*;
...
@@ -32,10 +32,22 @@ import java.awt.event.*;
import
java.awt.peer.ListPeer
;
import
java.awt.peer.ListPeer
;
import
java.util.Arrays
;
import
java.util.Arrays
;
final
class
LWListPeer
/**
extends
LWComponentPeer
<
List
,
LWListPeer
.
ScrollableJList
>
* Lightweight implementation of {@link ListPeer}.
*/
final
class
LWListPeer
extends
LWComponentPeer
<
List
,
LWListPeer
.
ScrollableJList
>
implements
ListPeer
{
implements
ListPeer
{
/**
* The default number of visible rows.
*/
private
static
final
int
DEFAULT_VISIBLE_ROWS
=
4
;
// From java.awt.List,
/**
* This text is used for cell bounds calculation.
*/
private
static
final
String
TEXT
=
"0123456789abcde"
;
LWListPeer
(
final
List
target
,
final
PlatformComponent
platformComponent
)
{
LWListPeer
(
final
List
target
,
final
PlatformComponent
platformComponent
)
{
super
(
target
,
platformComponent
);
super
(
target
,
platformComponent
);
if
(!
getTarget
().
isBackgroundSet
())
{
if
(!
getTarget
().
isBackgroundSet
())
{
...
@@ -134,6 +146,16 @@ final class LWListPeer
...
@@ -134,6 +146,16 @@ final class LWListPeer
}
}
}
}
@Override
public
Dimension
getPreferredSize
()
{
return
getMinimumSize
();
}
@Override
public
Dimension
getMinimumSize
()
{
return
getMinimumSize
(
DEFAULT_VISIBLE_ROWS
);
}
@Override
@Override
public
Dimension
getPreferredSize
(
final
int
rows
)
{
public
Dimension
getPreferredSize
(
final
int
rows
)
{
return
getMinimumSize
(
rows
);
return
getMinimumSize
(
rows
);
...
@@ -142,18 +164,28 @@ final class LWListPeer
...
@@ -142,18 +164,28 @@ final class LWListPeer
@Override
@Override
public
Dimension
getMinimumSize
(
final
int
rows
)
{
public
Dimension
getMinimumSize
(
final
int
rows
)
{
synchronized
(
getDelegateLock
())
{
synchronized
(
getDelegateLock
())
{
final
int
margin
=
2
;
final
Dimension
size
=
getCellSize
();
final
int
space
=
1
;
size
.
height
*=
rows
;
// Always take vertical scrollbar into account.
// TODO: count ScrollPane's scrolling elements if any.
final
JScrollBar
vbar
=
getDelegate
().
getVerticalScrollBar
();
final
FontMetrics
fm
=
getFontMetrics
(
getFont
());
size
.
width
+=
vbar
!=
null
?
vbar
.
getMinimumSize
().
width
:
0
;
final
int
itemHeight
=
(
fm
.
getHeight
()
-
fm
.
getLeading
())
+
(
2
*
space
);
// JScrollPane and JList insets
final
Insets
pi
=
getDelegate
().
getInsets
();
return
new
Dimension
(
20
+
(
fm
==
null
?
10
*
15
:
fm
.
stringWidth
(
"0123456789abcde"
)),
final
Insets
vi
=
getDelegate
().
getView
().
getInsets
();
(
fm
==
null
?
10
:
itemHeight
)
*
rows
+
(
2
*
margin
));
size
.
width
+=
pi
.
left
+
pi
.
right
+
vi
.
left
+
vi
.
right
;
size
.
height
+=
pi
.
top
+
pi
.
bottom
+
vi
.
top
+
vi
.
bottom
;
return
size
;
}
}
}
}
private
Dimension
getCellSize
()
{
final
JList
<
String
>
jList
=
getDelegate
().
getView
();
final
ListCellRenderer
<?
super
String
>
cr
=
jList
.
getCellRenderer
();
final
Component
cell
=
cr
.
getListCellRendererComponent
(
jList
,
TEXT
,
0
,
false
,
false
);
return
cell
.
getPreferredSize
();
}
private
void
revalidate
()
{
private
void
revalidate
()
{
synchronized
(
getDelegateLock
())
{
synchronized
(
getDelegateLock
())
{
getDelegate
().
getView
().
invalidate
();
getDelegate
().
getView
().
invalidate
();
...
@@ -165,10 +197,10 @@ final class LWListPeer
...
@@ -165,10 +197,10 @@ final class LWListPeer
private
boolean
skipStateChangedEvent
;
private
boolean
skipStateChangedEvent
;
private
DefaultListModel
<
Object
>
model
=
private
final
DefaultListModel
<
String
>
model
=
new
DefaultListModel
<
Object
>()
{
new
DefaultListModel
<
String
>()
{
@Override
@Override
public
void
add
(
final
int
index
,
final
Object
element
)
{
public
void
add
(
final
int
index
,
final
String
element
)
{
if
(
index
==
-
1
)
{
if
(
index
==
-
1
)
{
addElement
(
element
);
addElement
(
element
);
}
else
{
}
else
{
...
@@ -181,7 +213,7 @@ final class LWListPeer
...
@@ -181,7 +213,7 @@ final class LWListPeer
ScrollableJList
()
{
ScrollableJList
()
{
getViewport
().
setScrollMode
(
JViewport
.
SIMPLE_SCROLL_MODE
);
getViewport
().
setScrollMode
(
JViewport
.
SIMPLE_SCROLL_MODE
);
final
JList
<
Object
>
list
=
new
JListDelegate
();
final
JList
<
String
>
list
=
new
JListDelegate
();
list
.
addListSelectionListener
(
this
);
list
.
addListSelectionListener
(
this
);
getViewport
().
setView
(
list
);
getViewport
().
setView
(
list
);
...
@@ -223,11 +255,11 @@ final class LWListPeer
...
@@ -223,11 +255,11 @@ final class LWListPeer
}
}
}
}
public
JList
getView
()
{
public
JList
<
String
>
getView
()
{
return
(
JList
)
getViewport
().
getView
();
return
(
JList
<
String
>
)
getViewport
().
getView
();
}
}
public
DefaultListModel
<
Object
>
getModel
()
{
public
DefaultListModel
<
String
>
getModel
()
{
return
model
;
return
model
;
}
}
...
@@ -254,7 +286,7 @@ final class LWListPeer
...
@@ -254,7 +286,7 @@ final class LWListPeer
}
}
}
}
private
final
class
JListDelegate
extends
JList
<
Object
>
{
private
final
class
JListDelegate
extends
JList
<
String
>
{
JListDelegate
()
{
JListDelegate
()
{
super
(
ScrollableJList
.
this
.
model
);
super
(
ScrollableJList
.
this
.
model
);
...
@@ -272,7 +304,7 @@ final class LWListPeer
...
@@ -272,7 +304,7 @@ final class LWListPeer
final
int
index
=
locationToIndex
(
e
.
getPoint
());
final
int
index
=
locationToIndex
(
e
.
getPoint
());
if
(
0
<=
index
&&
index
<
getModel
().
getSize
())
{
if
(
0
<=
index
&&
index
<
getModel
().
getSize
())
{
LWListPeer
.
this
.
postEvent
(
new
ActionEvent
(
getTarget
(),
ActionEvent
.
ACTION_PERFORMED
,
LWListPeer
.
this
.
postEvent
(
new
ActionEvent
(
getTarget
(),
ActionEvent
.
ACTION_PERFORMED
,
getModel
().
getElementAt
(
index
)
.
toString
()
,
e
.
getWhen
(),
e
.
getModifiers
()));
getModel
().
getElementAt
(
index
),
e
.
getWhen
(),
e
.
getModifiers
()));
}
}
}
}
}
}
...
@@ -281,10 +313,10 @@ final class LWListPeer
...
@@ -281,10 +313,10 @@ final class LWListPeer
protected
void
processKeyEvent
(
final
KeyEvent
e
)
{
protected
void
processKeyEvent
(
final
KeyEvent
e
)
{
super
.
processKeyEvent
(
e
);
super
.
processKeyEvent
(
e
);
if
(
e
.
getID
()
==
KeyEvent
.
KEY_PRESSED
&&
e
.
getKeyCode
()
==
KeyEvent
.
VK_ENTER
)
{
if
(
e
.
getID
()
==
KeyEvent
.
KEY_PRESSED
&&
e
.
getKeyCode
()
==
KeyEvent
.
VK_ENTER
)
{
final
Object
selectedValue
=
getSelectedValue
();
final
String
selectedValue
=
getSelectedValue
();
if
(
selectedValue
!=
null
){
if
(
selectedValue
!=
null
){
LWListPeer
.
this
.
postEvent
(
new
ActionEvent
(
getTarget
(),
ActionEvent
.
ACTION_PERFORMED
,
LWListPeer
.
this
.
postEvent
(
new
ActionEvent
(
getTarget
(),
ActionEvent
.
ACTION_PERFORMED
,
selectedValue
.
toString
()
,
e
.
getWhen
(),
e
.
getModifiers
()));
selectedValue
,
e
.
getWhen
(),
e
.
getModifiers
()));
}
}
}
}
}
}
...
...
src/macosx/classes/sun/lwawt/LWPanelPeer.java
浏览文件 @
6b8e61fd
...
@@ -26,7 +26,6 @@
...
@@ -26,7 +26,6 @@
package
sun.lwawt
;
package
sun.lwawt
;
import
java.awt.Dimension
;
import
java.awt.Panel
;
import
java.awt.Panel
;
import
java.awt.peer.PanelPeer
;
import
java.awt.peer.PanelPeer
;
...
@@ -43,9 +42,4 @@ final class LWPanelPeer extends LWContainerPeer<Panel, JPanel>
...
@@ -43,9 +42,4 @@ final class LWPanelPeer extends LWContainerPeer<Panel, JPanel>
public
JPanel
createDelegate
()
{
public
JPanel
createDelegate
()
{
return
new
JPanel
();
return
new
JPanel
();
}
}
@Override
public
Dimension
getMinimumSize
()
{
return
getBounds
().
getSize
();
}
}
}
src/macosx/classes/sun/lwawt/LWScrollBarPeer.java
浏览文件 @
6b8e61fd
...
@@ -27,7 +27,6 @@
...
@@ -27,7 +27,6 @@
package
sun.lwawt
;
package
sun.lwawt
;
import
java.awt.Adjustable
;
import
java.awt.Adjustable
;
import
java.awt.Dimension
;
import
java.awt.Scrollbar
;
import
java.awt.Scrollbar
;
import
java.awt.event.AdjustmentEvent
;
import
java.awt.event.AdjustmentEvent
;
import
java.awt.event.AdjustmentListener
;
import
java.awt.event.AdjustmentListener
;
...
@@ -93,13 +92,6 @@ final class LWScrollBarPeer extends LWComponentPeer<Scrollbar, JScrollBar>
...
@@ -93,13 +92,6 @@ final class LWScrollBarPeer extends LWComponentPeer<Scrollbar, JScrollBar>
}
}
}
}
@Override
public
Dimension
getPreferredSize
()
{
synchronized
(
getDelegateLock
())
{
return
getDelegate
().
getPreferredSize
();
}
}
// Peer also registered as a listener for ComponentDelegate component
// Peer also registered as a listener for ComponentDelegate component
@Override
@Override
public
void
adjustmentValueChanged
(
final
AdjustmentEvent
e
)
{
public
void
adjustmentValueChanged
(
final
AdjustmentEvent
e
)
{
...
...
src/macosx/classes/sun/lwawt/LWTextAreaPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -29,6 +29,7 @@ package sun.lwawt;
...
@@ -29,6 +29,7 @@ package sun.lwawt;
import
java.awt.Component
;
import
java.awt.Component
;
import
java.awt.Cursor
;
import
java.awt.Cursor
;
import
java.awt.Dimension
;
import
java.awt.Dimension
;
import
java.awt.Insets
;
import
java.awt.Point
;
import
java.awt.Point
;
import
java.awt.TextArea
;
import
java.awt.TextArea
;
import
java.awt.event.TextEvent
;
import
java.awt.event.TextEvent
;
...
@@ -41,11 +42,22 @@ import javax.swing.ScrollPaneConstants;
...
@@ -41,11 +42,22 @@ import javax.swing.ScrollPaneConstants;
import
javax.swing.text.Document
;
import
javax.swing.text.Document
;
import
javax.swing.text.JTextComponent
;
import
javax.swing.text.JTextComponent
;
/**
* Lightweight implementation of {@link TextAreaPeer}. Delegates most of the
* work to the {@link JTextArea} inside JScrollPane.
*/
final
class
LWTextAreaPeer
final
class
LWTextAreaPeer
extends
LWTextComponentPeer
<
TextArea
,
LWTextAreaPeer
.
ScrollableJTextArea
>
extends
LWTextComponentPeer
<
TextArea
,
LWTextAreaPeer
.
ScrollableJTextArea
>
implements
TextAreaPeer
{
implements
TextAreaPeer
{
/**
* The default number of visible columns.
*/
private
static
final
int
DEFAULT_COLUMNS
=
60
;
private
static
final
int
DEFAULT_COLUMNS
=
60
;
/**
* The default number of visible rows.
*/
private
static
final
int
DEFAULT_ROWS
=
10
;
private
static
final
int
DEFAULT_ROWS
=
10
;
LWTextAreaPeer
(
final
TextArea
target
,
LWTextAreaPeer
(
final
TextArea
target
,
...
@@ -86,27 +98,42 @@ final class LWTextAreaPeer
...
@@ -86,27 +98,42 @@ final class LWTextAreaPeer
return
getTextComponent
();
return
getTextComponent
();
}
}
@Override
public
Dimension
getPreferredSize
()
{
return
getMinimumSize
();
}
@Override
@Override
public
Dimension
getMinimumSize
()
{
public
Dimension
getMinimumSize
()
{
return
getMinimumSize
(
DEFAULT_ROWS
,
DEFAULT_COLUMNS
);
return
getMinimumSize
(
DEFAULT_ROWS
,
DEFAULT_COLUMNS
);
}
}
@Override
@Override
public
Dimension
get
Minimum
Size
(
final
int
rows
,
final
int
columns
)
{
public
Dimension
get
Preferred
Size
(
final
int
rows
,
final
int
columns
)
{
return
get
Preferred
Size
(
rows
,
columns
);
return
get
Minimum
Size
(
rows
,
columns
);
}
}
@Override
@Override
public
Dimension
get
Preferred
Size
(
final
int
rows
,
final
int
columns
)
{
public
Dimension
get
Minimum
Size
(
final
int
rows
,
final
int
columns
)
{
final
Dimension
size
=
super
.
get
Preferred
Size
(
rows
,
columns
);
final
Dimension
size
=
super
.
get
Minimum
Size
(
rows
,
columns
);
synchronized
(
getDelegateLock
())
{
synchronized
(
getDelegateLock
())
{
final
JScrollBar
vbar
=
getDelegate
().
getVerticalScrollBar
();
// JScrollPane insets
final
JScrollBar
hbar
=
getDelegate
().
getHorizontalScrollBar
();
final
Insets
pi
=
getDelegate
().
getInsets
();
final
int
scrollbarW
=
vbar
!=
null
?
vbar
.
getWidth
()
:
0
;
size
.
width
+=
pi
.
left
+
pi
.
right
;
final
int
scrollbarH
=
hbar
!=
null
?
hbar
.
getHeight
()
:
0
;
size
.
height
+=
pi
.
top
+
pi
.
bottom
;
return
new
Dimension
(
size
.
width
+
scrollbarW
,
// Take scrollbars into account.
size
.
height
+
scrollbarH
);
final
int
vsbPolicy
=
getDelegate
().
getVerticalScrollBarPolicy
();
if
(
vsbPolicy
==
ScrollPaneConstants
.
VERTICAL_SCROLLBAR_ALWAYS
)
{
final
JScrollBar
vbar
=
getDelegate
().
getVerticalScrollBar
();
size
.
width
+=
vbar
!=
null
?
vbar
.
getMinimumSize
().
width
:
0
;
}
final
int
hsbPolicy
=
getDelegate
().
getHorizontalScrollBarPolicy
();
if
(
hsbPolicy
==
ScrollPaneConstants
.
HORIZONTAL_SCROLLBAR_ALWAYS
)
{
final
JScrollBar
hbar
=
getDelegate
().
getHorizontalScrollBar
();
size
.
height
+=
hbar
!=
null
?
hbar
.
getMinimumSize
().
height
:
0
;
}
}
}
return
size
;
}
}
@Override
@Override
...
...
src/macosx/classes/sun/lwawt/LWTextComponentPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -48,10 +48,7 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
...
@@ -48,10 +48,7 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
extends
LWComponentPeer
<
T
,
D
>
extends
LWComponentPeer
<
T
,
D
>
implements
DocumentListener
,
TextComponentPeer
,
InputMethodListener
{
implements
DocumentListener
,
TextComponentPeer
,
InputMethodListener
{
/**
* Character with reasonable value between the minimum width and maximum.
*/
protected
static
final
char
WIDE_CHAR
=
'w'
;
private
volatile
boolean
firstChangeSkipped
;
private
volatile
boolean
firstChangeSkipped
;
LWTextComponentPeer
(
final
T
target
,
LWTextComponentPeer
(
final
T
target
,
...
@@ -95,18 +92,16 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
...
@@ -95,18 +92,16 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
*/
*/
abstract
JTextComponent
getTextComponent
();
abstract
JTextComponent
getTextComponent
();
public
Dimension
get
Preferred
Size
(
final
int
rows
,
final
int
columns
)
{
public
Dimension
get
Minimum
Size
(
final
int
rows
,
final
int
columns
)
{
final
Insets
insets
;
final
Insets
insets
;
synchronized
(
getDelegateLock
())
{
synchronized
(
getDelegateLock
())
{
insets
=
get
Delegate
().
getInsets
();
insets
=
get
TextComponent
().
getInsets
();
}
}
final
int
borderHeight
=
insets
.
top
+
insets
.
bottom
;
final
int
borderHeight
=
insets
.
top
+
insets
.
bottom
;
final
int
borderWidth
=
insets
.
left
+
insets
.
right
;
final
int
borderWidth
=
insets
.
left
+
insets
.
right
;
final
FontMetrics
fm
=
getFontMetrics
(
getFont
());
final
FontMetrics
fm
=
getFontMetrics
(
getFont
());
final
int
charWidth
=
(
fm
!=
null
)
?
fm
.
charWidth
(
WIDE_CHAR
)
:
10
;
return
new
Dimension
(
fm
.
charWidth
(
WIDE_CHAR
)
*
columns
+
borderWidth
,
final
int
itemHeight
=
(
fm
!=
null
)
?
fm
.
getHeight
()
:
10
;
fm
.
getHeight
()
*
rows
+
borderHeight
);
return
new
Dimension
(
columns
*
charWidth
+
borderWidth
,
rows
*
itemHeight
+
borderHeight
);
}
}
@Override
@Override
...
@@ -187,6 +182,7 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
...
@@ -187,6 +182,7 @@ abstract class LWTextComponentPeer<T extends TextComponent, D extends JComponent
}
}
}
}
//TODO IN XAWT we just return true..
@Override
@Override
public
final
boolean
isFocusable
()
{
public
final
boolean
isFocusable
()
{
return
getTarget
().
isFocusable
();
return
getTarget
().
isFocusable
();
...
...
src/macosx/classes/sun/lwawt/LWTextFieldPeer.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2011,
2012,
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
...
@@ -37,16 +37,10 @@ import java.awt.peer.TextFieldPeer;
...
@@ -37,16 +37,10 @@ import java.awt.peer.TextFieldPeer;
import
javax.swing.JPasswordField
;
import
javax.swing.JPasswordField
;
import
javax.swing.text.JTextComponent
;
import
javax.swing.text.JTextComponent
;
import
javax.tools.annotation.GenerateNativeHeader
;
/* No native methods here, but the constants are needed in the supporting JNI code */
@GenerateNativeHeader
final
class
LWTextFieldPeer
final
class
LWTextFieldPeer
extends
LWTextComponentPeer
<
TextField
,
JPasswordField
>
extends
LWTextComponentPeer
<
TextField
,
JPasswordField
>
implements
TextFieldPeer
,
ActionListener
{
implements
TextFieldPeer
,
ActionListener
{
private
static
final
int
DEFAULT_COLUMNS
=
1
;
LWTextFieldPeer
(
final
TextField
target
,
LWTextFieldPeer
(
final
TextField
target
,
final
PlatformComponent
platformComponent
)
{
final
PlatformComponent
platformComponent
)
{
super
(
target
,
platformComponent
);
super
(
target
,
platformComponent
);
...
@@ -83,17 +77,12 @@ final class LWTextFieldPeer
...
@@ -83,17 +77,12 @@ final class LWTextFieldPeer
@Override
@Override
public
Dimension
getPreferredSize
(
final
int
columns
)
{
public
Dimension
getPreferredSize
(
final
int
columns
)
{
return
get
PreferredSize
(
1
,
columns
);
return
get
MinimumSize
(
columns
);
}
}
@Override
@Override
public
Dimension
getMinimumSize
(
final
int
columns
)
{
public
Dimension
getMinimumSize
(
final
int
columns
)
{
return
getPreferredSize
(
columns
);
return
getMinimumSize
(
1
,
columns
);
}
@Override
public
Dimension
getMinimumSize
()
{
return
getMinimumSize
(
DEFAULT_COLUMNS
);
}
}
@Override
@Override
...
...
src/macosx/classes/sun/lwawt/LWToolkit.java
浏览文件 @
6b8e61fd
...
@@ -310,7 +310,7 @@ public abstract class LWToolkit extends SunToolkit implements Runnable {
...
@@ -310,7 +310,7 @@ public abstract class LWToolkit extends SunToolkit implements Runnable {
@Override
@Override
public
CanvasPeer
createCanvas
(
Canvas
target
)
{
public
CanvasPeer
createCanvas
(
Canvas
target
)
{
PlatformComponent
platformComponent
=
createPlatformComponent
();
PlatformComponent
platformComponent
=
createPlatformComponent
();
LWCanvasPeer
peer
=
new
LWCanvasPeer
(
target
,
platformComponent
);
LWCanvasPeer
<?,
?>
peer
=
new
LWCanvasPeer
<>
(
target
,
platformComponent
);
targetCreatedPeer
(
target
,
peer
);
targetCreatedPeer
(
target
,
peer
);
peer
.
initialize
();
peer
.
initialize
();
return
peer
;
return
peer
;
...
...
src/macosx/classes/sun/lwawt/macosx/CPlatformResponder.java
浏览文件 @
6b8e61fd
...
@@ -160,6 +160,9 @@ final class CPlatformResponder {
...
@@ -160,6 +160,9 @@ final class CPlatformResponder {
if
(
isDeadChar
){
if
(
isDeadChar
){
testChar
=
(
char
)
out
[
2
];
testChar
=
(
char
)
out
[
2
];
if
(
testChar
==
0
){
return
;
}
}
}
jkeyCode
=
out
[
0
];
jkeyCode
=
out
[
0
];
...
...
src/macosx/native/sun/awt/AWTEvent.m
浏览文件 @
6b8e61fd
...
@@ -383,6 +383,7 @@ static unichar NsGetDeadKeyChar(unsigned short keyCode)
...
@@ -383,6 +383,7 @@ static unichar NsGetDeadKeyChar(unsigned short keyCode)
{
{
TISInputSourceRef
currentKeyboard
=
TISCopyCurrentKeyboardInputSource
()
;
TISInputSourceRef
currentKeyboard
=
TISCopyCurrentKeyboardInputSource
()
;
CFDataRef
uchr
=
(
CFDataRef
)
TISGetInputSourceProperty
(
currentKeyboard
,
kTISPropertyUnicodeKeyLayoutData
)
;
CFDataRef
uchr
=
(
CFDataRef
)
TISGetInputSourceProperty
(
currentKeyboard
,
kTISPropertyUnicodeKeyLayoutData
)
;
if
(
uchr
==
nil
)
{
return
;
}
const
UCKeyboardLayout
*
keyboardLayout
=
(
const
UCKeyboardLayout
*
)
CFDataGetBytePtr
(
uchr
)
;
const
UCKeyboardLayout
*
keyboardLayout
=
(
const
UCKeyboardLayout
*
)
CFDataGetBytePtr
(
uchr
)
;
//
Carbon
modifiers
should
be
used
instead
of
NSEvent
modifiers
//
Carbon
modifiers
should
be
used
instead
of
NSEvent
modifiers
UInt32
modifierKeyState
=
(
GetCurrentEventKeyModifiers
()
>>
8
)
&
0
xFF
;
UInt32
modifierKeyState
=
(
GetCurrentEventKeyModifiers
()
>>
8
)
&
0
xFF
;
...
@@ -563,18 +564,18 @@ NSUInteger JavaModifiersToNsKeyModifiers(jint javaModifiers, BOOL isExtMods)
...
@@ -563,18 +564,18 @@ NSUInteger JavaModifiersToNsKeyModifiers(jint javaModifiers, BOOL isExtMods)
const
struct
_
nsKeyToJavaModifier
*
cur
;
const
struct
_
nsKeyToJavaModifier
*
cur
;
for
(
cur
=
nsKeyToJavaModifierTable
;
cur
->
nsMask
!=
0
;
++
cur
)
{
for
(
cur
=
nsKeyToJavaModifierTable
;
cur
->
nsMask
!=
0
;
++
cur
)
{
jint
mask
=
isExtMods
?
cur
->
javaExtMask
:
cur
->
javaMask
;
jint
mask
=
isExtMods
?
cur
->
javaExtMask
:
cur
->
javaMask
;
if
((
mask
&
javaModifiers
)
!=
0
)
{
if
((
mask
&
javaModifiers
)
!=
0
)
{
nsFlags
|=
cur
->
nsMask
;
nsFlags
|=
cur
->
nsMask
;
}
}
}
}
//
special
case
//
special
case
jint
mask
=
isExtMods
?
java
_
awt
_
event
_
InputEvent
_
ALT
_
GRAPH
_
DOWN
_
MASK
:
jint
mask
=
isExtMods
?
java
_
awt
_
event
_
InputEvent
_
ALT
_
GRAPH
_
DOWN
_
MASK
:
java
_
awt
_
event
_
InputEvent
_
ALT
_
GRAPH
_
MASK
;
java
_
awt
_
event
_
InputEvent
_
ALT
_
GRAPH
_
MASK
;
if
((
mask
&
javaModifiers
)
!=
0
)
{
if
((
mask
&
javaModifiers
)
!=
0
)
{
nsFlags
|=
NSAlternateKeyMask
;
nsFlags
|=
NSAlternateKeyMask
;
}
}
return
nsFlags
;
return
nsFlags
;
...
...
src/macosx/native/sun/awt/AWTView.m
浏览文件 @
6b8e61fd
...
@@ -279,7 +279,10 @@ AWT_ASSERT_APPKIT_THREAD;
...
@@ -279,7 +279,10 @@ AWT_ASSERT_APPKIT_THREAD;
return
;
return
;
}
}
if
(
!
[
self
hasMarkedText
]
&&
fKeyEventsNeeded
)
{
NSString
*
eventCharacters
=
[
event
characters
];
BOOL
isDeadKey
=
(
eventCharacters
!=
nil
&&
[
eventCharacters
length
]
==
0
);
if
((
!
[
self
hasMarkedText
]
&&
fKeyEventsNeeded
)
||
isDeadKey
)
{
[
self
deliverJavaKeyEventHelper
:
event
];
[
self
deliverJavaKeyEventHelper
:
event
];
}
}
...
...
src/macosx/native/sun/awt/CTextPipe.m
浏览文件 @
6b8e61fd
...
@@ -142,8 +142,11 @@ void JavaCT_DrawGlyphVector
...
@@ -142,8 +142,11 @@ void JavaCT_DrawGlyphVector
// get our baseline transform and font
// get our baseline transform and font
CGContextRef
cgRef
=
qsdo
->
cgRef
;
CGContextRef
cgRef
=
qsdo
->
cgRef
;
CGAffineTransform
ctmText
=
CGContextGetTextMatrix
(
cgRef
);
CGAffineTransform
ctmText
=
CGContextGetTextMatrix
(
cgRef
);
//CGFontRef cgFont = CGContextGetFont(cgRef);
/* Save and restore of graphics context is done before the iteration.
This seems to work using our test case (see bug ID 7158350) so we are restoring it at
the end of the for loop. If we find out that save/restore outside the loop
doesn't work on all cases then we will move the Save/Restore inside the loop.*/
CGContextSaveGState
(
cgRef
);
CGContextSaveGState
(
cgRef
);
CGAffineTransform
invTx
=
CGAffineTransformInvert
(
strike
->
fTx
);
CGAffineTransform
invTx
=
CGAffineTransformInvert
(
strike
->
fTx
);
...
@@ -210,13 +213,9 @@ void JavaCT_DrawGlyphVector
...
@@ -210,13 +213,9 @@ void JavaCT_DrawGlyphVector
pt
.
x
+=
advances
[
i
].
width
;
pt
.
x
+=
advances
[
i
].
width
;
pt
.
y
+=
advances
[
i
].
height
;
pt
.
y
+=
advances
[
i
].
height
;
// reset the font on the context after striking a unicode with CoreText
if
(
uniChar
!=
0
)
{
// CGContextSetFont(cgRef, cgFont);
CGContextSaveGState
(
cgRef
);
}
}
}
// reset the font on the context after striking a unicode with CoreText
CGContextRestoreGState
(
cgRef
);
}
}
// Using the Quartz Surface Data context, draw a hot-substituted character run
// Using the Quartz Surface Data context, draw a hot-substituted character run
...
...
src/macosx/native/sun/awt/InitIDs.m
浏览文件 @
6b8e61fd
...
@@ -47,7 +47,10 @@ JNIEXPORT void JNICALL Java_java_awt_CheckboxMenuItem_initIDs
...
@@ -47,7 +47,10 @@ JNIEXPORT void JNICALL Java_java_awt_CheckboxMenuItem_initIDs
{
{
}
}
JNIEXPORT void JNICALL Java_java_awt_Choice_initIDs
(JNIEnv *env, jclass cls)
{
}
JNIEXPORT void JNICALL Java_java_awt_Color_initIDs
JNIEXPORT void JNICALL Java_java_awt_Color_initIDs
(JNIEnv *env, jclass cls)
(JNIEnv *env, jclass cls)
...
...
src/macosx/native/sun/awt/LWCToolkit.m
浏览文件 @
6b8e61fd
...
@@ -33,6 +33,7 @@
...
@@ -33,6 +33,7 @@
#import "ThreadUtilities.h"
#import "ThreadUtilities.h"
#import "AWT_debug.h"
#import "AWT_debug.h"
#import "CSystemColors.h"
#import "CSystemColors.h"
#import "NSApplicationAWT.h"
#import "sun_lwawt_macosx_LWCToolkit.h"
#import "sun_lwawt_macosx_LWCToolkit.h"
...
@@ -47,7 +48,7 @@ static long eventCount;
...
@@ -47,7 +48,7 @@ static long eventCount;
return
eventCount
;
return
eventCount
;
}
}
+
(
void
)
eventCountPlusPlus
{
+
(
void
)
eventCountPlusPlus
{
eventCount
++
;
eventCount
++
;
}
}
...
@@ -79,7 +80,6 @@ static long eventCount;
...
@@ -79,7 +80,6 @@ static long eventCount;
@end
@end
/*
/*
* Class: sun_lwawt_macosx_LWCToolkit
* Class: sun_lwawt_macosx_LWCToolkit
* Method: nativeSyncQueue
* Method: nativeSyncQueue
...
@@ -90,12 +90,22 @@ JNIEXPORT jboolean JNICALL Java_sun_lwawt_macosx_LWCToolkit_nativeSyncQueue
...
@@ -90,12 +90,22 @@ JNIEXPORT jboolean JNICALL Java_sun_lwawt_macosx_LWCToolkit_nativeSyncQueue
{
{
int
currentEventNum
=
[
AWTToolkit
getEventCount
];
int
currentEventNum
=
[
AWTToolkit
getEventCount
];
[
JNFRunLoop
performOnMainThreadWaiting
:
YES
withBlock
:
^
(){}];
NSApplication
*
sharedApp
=
[
NSApplication
sharedApplication
];
if
([
sharedApp
isKindOfClass
:[
NSApplicationAWT
class
]])
{
NSApplicationAWT
*
theApp
=
(
NSApplicationAWT
*
)
sharedApp
;
[
theApp
postDummyEvent
];
[
theApp
waitForDummyEvent
];
}
else
{
// could happen if we are embedded inside SWT application,
// in this case just spin a single empty block through
// the event loop to give it a chance to process pending events
[
JNFRunLoop
performOnMainThreadWaiting
:
YES
withBlock
:
^
(){}];
}
if
(([
AWTToolkit
getEventCount
]
-
currentEventNum
)
!=
0
)
{
if
(([
AWTToolkit
getEventCount
]
-
currentEventNum
)
!=
0
)
{
return
JNI_TRUE
;
return
JNI_TRUE
;
}
}
return
JNI_FALSE
;
return
JNI_FALSE
;
}
}
...
...
src/macosx/native/sun/osxapp/NSApplicationAWT.h
浏览文件 @
6b8e61fd
...
@@ -29,11 +29,15 @@
...
@@ -29,11 +29,15 @@
@interface
NSApplicationAWT
:
NSApplication
{
@interface
NSApplicationAWT
:
NSApplication
{
NSString
*
fApplicationName
;
NSString
*
fApplicationName
;
NSWindow
*
eventTransparentWindow
;
NSWindow
*
eventTransparentWindow
;
NSTimeInterval
dummyEventTimestamp
;
NSConditionLock
*
seenDummyEventLock
;
}
}
-
(
void
)
finishLaunching
;
-
(
void
)
finishLaunching
;
-
(
void
)
registerWithProcessManager
;
-
(
void
)
registerWithProcessManager
;
-
(
void
)
setDockIconWithEnv
:(
JNIEnv
*
)
env
;
-
(
void
)
setDockIconWithEnv
:(
JNIEnv
*
)
env
;
-
(
void
)
postDummyEvent
;
-
(
void
)
waitForDummyEvent
;
+
(
void
)
runAWTLoopWithApp
:(
NSApplication
*
)
app
;
+
(
void
)
runAWTLoopWithApp
:(
NSApplication
*
)
app
;
...
...
src/macosx/native/sun/osxapp/NSApplicationAWT.m
浏览文件 @
6b8e61fd
...
@@ -31,6 +31,7 @@
...
@@ -31,6 +31,7 @@
#import "PropertiesUtilities.h"
#import "PropertiesUtilities.h"
#import "ThreadUtilities.h"
#import "ThreadUtilities.h"
#import "QueuingApplicationDelegate.h"
#import "QueuingApplicationDelegate.h"
#import "AWTIconData.h"
static
BOOL
sUsingDefaultNIB
=
YES
;
static
BOOL
sUsingDefaultNIB
=
YES
;
...
@@ -52,6 +53,9 @@ BOOL postEventDuringEventSynthesis = NO;
...
@@ -52,6 +53,9 @@ BOOL postEventDuringEventSynthesis = NO;
AWT_ASSERT_APPKIT_THREAD
;
AWT_ASSERT_APPKIT_THREAD
;
fApplicationName
=
nil
;
fApplicationName
=
nil
;
dummyEventTimestamp
=
0
.
0
;
seenDummyEventLock
=
nil
;
// NSApplication will call _RegisterApplication with the application's bundle, but there may not be one.
// NSApplication will call _RegisterApplication with the application's bundle, but there may not be one.
// So, we need to call it ourselves to ensure the app is set up properly.
// So, we need to call it ourselves to ensure the app is set up properly.
...
@@ -255,25 +259,26 @@ AWT_ASSERT_APPKIT_THREAD;
...
@@ -255,25 +259,26 @@ AWT_ASSERT_APPKIT_THREAD;
theIconPath
=
[
PropertiesUtilities
javaSystemPropertyForKey
:
@"apple.awt.application.icon"
withEnv
:
env
];
theIconPath
=
[
PropertiesUtilities
javaSystemPropertyForKey
:
@"apple.awt.application.icon"
withEnv
:
env
];
}
}
// If the icon file wasn't specified as an argument and we need to get an icon
// Use the path specified to get the icon image
// we'll use the generic java app icon.
NSImage
*
iconImage
=
nil
;
NSString
*
defaultIconPath
=
[
NSString
stringWithFormat
:
@"%@%@"
,
SHARED_FRAMEWORK_BUNDLE
,
@"/Resources/GenericApp.icns"
];
if
(
theIconPath
!=
nil
)
{
if
(
theIconPath
==
nil
)
{
iconImage
=
[[
NSImage
alloc
]
initWithContentsOfFile
:
theIconPath
];
}
// If no icon file was specified or we failed to get the icon image
// and there is no bundle's icon, then use the default icon
if
(
iconImage
==
nil
)
{
NSString
*
bundleIcon
=
[[
NSBundle
mainBundle
]
objectForInfoDictionaryKey
:
@"CFBundleIconFile"
];
NSString
*
bundleIcon
=
[[
NSBundle
mainBundle
]
objectForInfoDictionaryKey
:
@"CFBundleIconFile"
];
if
(
bundleIcon
==
nil
)
{
if
(
bundleIcon
==
nil
)
{
theIconPath
=
defaultIconPath
;
NSData
*
iconData
;
iconData
=
[[
NSData
alloc
]
initWithBytesNoCopy
:
sAWTIconData
length
:
sizeof
(
sAWTIconData
)
freeWhenDone
:
NO
];
iconImage
=
[[
NSImage
alloc
]
initWithData
:
iconData
];
[
iconData
release
];
}
}
}
}
// Set up the dock icon if we have an icon name.
// Set up the dock icon if we have an icon image.
if
(
theIconPath
!=
nil
)
{
if
(
iconImage
!=
nil
)
{
NSImage
*
iconImage
=
[[
NSImage
alloc
]
initWithContentsOfFile
:
theIconPath
];
// If we failed for some reason fall back to the default icon.
if
(
iconImage
==
nil
)
{
iconImage
=
[[
NSImage
alloc
]
initWithContentsOfFile
:
defaultIconPath
];
}
[
NSApp
setApplicationIconImage
:
iconImage
];
[
NSApp
setApplicationIconImage
:
iconImage
];
[
iconImage
release
];
[
iconImage
release
];
}
}
...
@@ -328,6 +333,45 @@ AWT_ASSERT_APPKIT_THREAD;
...
@@ -328,6 +333,45 @@ AWT_ASSERT_APPKIT_THREAD;
return
event
;
return
event
;
}
}
// NSTimeInterval has microseconds precision
#define TS_EQUAL(ts1, ts2) (fabs((ts1) - (ts2)) < 1e-6)
-
(
void
)
sendEvent
:(
NSEvent
*
)
event
{
if
([
event
type
]
==
NSApplicationDefined
&&
TS_EQUAL
([
event
timestamp
],
dummyEventTimestamp
))
{
[
seenDummyEventLock
lockWhenCondition
:
NO
];
[
seenDummyEventLock
unlockWithCondition
:
YES
];
}
else
{
[
super
sendEvent
:
event
];
}
}
-
(
void
)
postDummyEvent
{
seenDummyEventLock
=
[[
NSConditionLock
alloc
]
initWithCondition
:
NO
];
dummyEventTimestamp
=
[
NSProcessInfo
processInfo
].
systemUptime
;
NSAutoreleasePool
*
pool
=
[[
NSAutoreleasePool
alloc
]
init
];
NSEvent
*
event
=
[
NSEvent
otherEventWithType
:
NSApplicationDefined
location:
NSMakePoint
(
0
,
0
)
modifierFlags:
0
timestamp:
dummyEventTimestamp
windowNumber:
0
context:
nil
subtype:
0
data1:
0
data2:
0
];
[
NSApp
postEvent
:
event
atStart
:
NO
];
[
pool
drain
];
}
-
(
void
)
waitForDummyEvent
{
[
seenDummyEventLock
lockWhenCondition
:
YES
];
[
seenDummyEventLock
unlock
];
[
seenDummyEventLock
release
];
seenDummyEventLock
=
nil
;
}
@end
@end
...
...
src/macosx/native/sun/osxapp/resource/icons/JavaApp.icns
0 → 100644
浏览文件 @
6b8e61fd
文件已添加
src/share/classes/java/awt/Choice.java
浏览文件 @
6b8e61fd
...
@@ -104,7 +104,16 @@ public class Choice extends Component implements ItemSelectable, Accessible {
...
@@ -104,7 +104,16 @@ public class Choice extends Component implements ItemSelectable, Accessible {
/*
/*
* JDK 1.1 serialVersionUID
* JDK 1.1 serialVersionUID
*/
*/
private
static
final
long
serialVersionUID
=
-
4075310674757313071L
;
private
static
final
long
serialVersionUID
=
-
4075310674757313071L
;
static
{
/* ensure that the necessary native libraries are loaded */
Toolkit
.
loadLibraries
();
/* initialize JNI field and method ids */
if
(!
GraphicsEnvironment
.
isHeadless
())
{
initIDs
();
}
}
/**
/**
* Creates a new choice menu. The menu initially has no items in it.
* Creates a new choice menu. The menu initially has no items in it.
...
@@ -711,6 +720,10 @@ public class Choice extends Component implements ItemSelectable, Accessible {
...
@@ -711,6 +720,10 @@ public class Choice extends Component implements ItemSelectable, Accessible {
}
}
}
}
/**
* Initialize JNI field and method IDs
*/
private
static
native
void
initIDs
();
/////////////////
/////////////////
// Accessibility support
// Accessibility support
...
...
src/share/classes/javax/swing/ToolTipManager.java
浏览文件 @
6b8e61fd
/*
/*
* Copyright (c) 1997, 201
1
, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 1997, 201
2
, 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
...
@@ -217,6 +217,25 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
...
@@ -217,6 +217,25 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
return
exitTimer
.
getInitialDelay
();
return
exitTimer
.
getInitialDelay
();
}
}
// Returns GraphicsConfiguration instance that toFind belongs to or null
// if drawing point is set to a point beyond visible screen area (e.g.
// Point(20000, 20000))
private
GraphicsConfiguration
getDrawingGC
(
Point
toFind
)
{
GraphicsEnvironment
env
=
GraphicsEnvironment
.
getLocalGraphicsEnvironment
();
GraphicsDevice
devices
[]
=
env
.
getScreenDevices
();
for
(
GraphicsDevice
device
:
devices
)
{
GraphicsConfiguration
configs
[]
=
device
.
getConfigurations
();
for
(
GraphicsConfiguration
config
:
configs
)
{
Rectangle
rect
=
config
.
getBounds
();
if
(
rect
.
contains
(
toFind
))
{
return
config
;
}
}
}
return
null
;
}
void
showTipWindow
()
{
void
showTipWindow
()
{
if
(
insideComponent
==
null
||
!
insideComponent
.
isShowing
())
if
(
insideComponent
==
null
||
!
insideComponent
.
isShowing
())
return
;
return
;
...
@@ -231,9 +250,25 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
...
@@ -231,9 +250,25 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
if
(
enabled
)
{
if
(
enabled
)
{
Dimension
size
;
Dimension
size
;
Point
screenLocation
=
insideComponent
.
getLocationOnScreen
();
Point
screenLocation
=
insideComponent
.
getLocationOnScreen
();
Point
location
=
new
Point
();
Point
location
;
GraphicsConfiguration
gc
;
gc
=
insideComponent
.
getGraphicsConfiguration
();
Point
toFind
;
if
(
preferredLocation
!=
null
)
{
toFind
=
new
Point
(
screenLocation
.
x
+
preferredLocation
.
x
,
screenLocation
.
y
+
preferredLocation
.
y
);
}
else
{
toFind
=
mouseEvent
.
getLocationOnScreen
();
}
GraphicsConfiguration
gc
=
getDrawingGC
(
toFind
);
if
(
gc
==
null
)
{
toFind
=
mouseEvent
.
getLocationOnScreen
();
gc
=
getDrawingGC
(
toFind
);
if
(
gc
==
null
)
{
gc
=
insideComponent
.
getGraphicsConfiguration
();
}
}
Rectangle
sBounds
=
gc
.
getBounds
();
Rectangle
sBounds
=
gc
.
getBounds
();
Insets
screenInsets
=
Toolkit
.
getDefaultToolkit
()
Insets
screenInsets
=
Toolkit
.
getDefaultToolkit
()
.
getScreenInsets
(
gc
);
.
getScreenInsets
(
gc
);
...
@@ -253,14 +288,13 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
...
@@ -253,14 +288,13 @@ public class ToolTipManager extends MouseAdapter implements MouseMotionListener
size
=
tip
.
getPreferredSize
();
size
=
tip
.
getPreferredSize
();
if
(
preferredLocation
!=
null
)
{
if
(
preferredLocation
!=
null
)
{
location
.
x
=
screenLocation
.
x
+
preferredLocation
.
x
;
location
=
toFind
;
location
.
y
=
screenLocation
.
y
+
preferredLocation
.
y
;
if
(!
leftToRight
)
{
if
(!
leftToRight
)
{
location
.
x
-=
size
.
width
;
location
.
x
-=
size
.
width
;
}
}
}
else
{
}
else
{
location
.
x
=
screenLocation
.
x
+
mouseEvent
.
getX
();
location
=
new
Point
(
screenLocation
.
x
+
mouseEvent
.
getX
(),
location
.
y
=
screenLocation
.
y
+
mouseEvent
.
getY
()
+
20
;
screenLocation
.
y
+
mouseEvent
.
getY
()
+
20
)
;
if
(!
leftToRight
)
{
if
(!
leftToRight
)
{
if
(
location
.
x
-
size
.
width
>=
0
)
{
if
(
location
.
x
-
size
.
width
>=
0
)
{
location
.
x
-=
size
.
width
;
location
.
x
-=
size
.
width
;
...
...
src/share/classes/javax/swing/colorchooser/DefaultSwatchChooserPanel.java
浏览文件 @
6b8e61fd
...
@@ -57,6 +57,8 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
...
@@ -57,6 +57,8 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
RecentSwatchPanel
recentSwatchPanel
;
RecentSwatchPanel
recentSwatchPanel
;
MouseListener
mainSwatchListener
;
MouseListener
mainSwatchListener
;
MouseListener
recentSwatchListener
;
MouseListener
recentSwatchListener
;
private
KeyListener
mainSwatchKeyListener
;
private
KeyListener
recentSwatchKeyListener
;
public
DefaultSwatchChooserPanel
()
{
public
DefaultSwatchChooserPanel
()
{
super
();
super
();
...
@@ -151,10 +153,14 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
...
@@ -151,10 +153,14 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
recentSwatchPanel
.
putClientProperty
(
AccessibleContext
.
ACCESSIBLE_NAME_PROPERTY
,
recentSwatchPanel
.
putClientProperty
(
AccessibleContext
.
ACCESSIBLE_NAME_PROPERTY
,
recentStr
);
recentStr
);
mainSwatchKeyListener
=
new
MainSwatchKeyListener
();
mainSwatchListener
=
new
MainSwatchListener
();
mainSwatchListener
=
new
MainSwatchListener
();
swatchPanel
.
addMouseListener
(
mainSwatchListener
);
swatchPanel
.
addMouseListener
(
mainSwatchListener
);
swatchPanel
.
addKeyListener
(
mainSwatchKeyListener
);
recentSwatchListener
=
new
RecentSwatchListener
();
recentSwatchListener
=
new
RecentSwatchListener
();
recentSwatchKeyListener
=
new
RecentSwatchKeyListener
();
recentSwatchPanel
.
addMouseListener
(
recentSwatchListener
);
recentSwatchPanel
.
addMouseListener
(
recentSwatchListener
);
recentSwatchPanel
.
addKeyListener
(
recentSwatchKeyListener
);
JPanel
mainHolder
=
new
JPanel
(
new
BorderLayout
());
JPanel
mainHolder
=
new
JPanel
(
new
BorderLayout
());
Border
border
=
new
CompoundBorder
(
new
LineBorder
(
Color
.
black
),
Border
border
=
new
CompoundBorder
(
new
LineBorder
(
Color
.
black
),
...
@@ -196,11 +202,17 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
...
@@ -196,11 +202,17 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
public
void
uninstallChooserPanel
(
JColorChooser
enclosingChooser
)
{
public
void
uninstallChooserPanel
(
JColorChooser
enclosingChooser
)
{
super
.
uninstallChooserPanel
(
enclosingChooser
);
super
.
uninstallChooserPanel
(
enclosingChooser
);
swatchPanel
.
removeMouseListener
(
mainSwatchListener
);
swatchPanel
.
removeMouseListener
(
mainSwatchListener
);
swatchPanel
.
removeKeyListener
(
mainSwatchKeyListener
);
recentSwatchPanel
.
removeMouseListener
(
recentSwatchListener
);
recentSwatchPanel
.
removeMouseListener
(
recentSwatchListener
);
recentSwatchPanel
.
removeKeyListener
(
recentSwatchKeyListener
);
swatchPanel
=
null
;
swatchPanel
=
null
;
recentSwatchPanel
=
null
;
recentSwatchPanel
=
null
;
mainSwatchListener
=
null
;
mainSwatchListener
=
null
;
mainSwatchKeyListener
=
null
;
recentSwatchListener
=
null
;
recentSwatchListener
=
null
;
recentSwatchKeyListener
=
null
;
removeAll
();
// strip out all the sub-components
removeAll
();
// strip out all the sub-components
}
}
...
@@ -209,11 +221,32 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
...
@@ -209,11 +221,32 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
}
}
private
class
RecentSwatchKeyListener
extends
KeyAdapter
{
public
void
keyPressed
(
KeyEvent
e
)
{
if
(
KeyEvent
.
VK_SPACE
==
e
.
getKeyCode
())
{
Color
color
=
recentSwatchPanel
.
getSelectedColor
();
setSelectedColor
(
color
);
}
}
}
private
class
MainSwatchKeyListener
extends
KeyAdapter
{
public
void
keyPressed
(
KeyEvent
e
)
{
if
(
KeyEvent
.
VK_SPACE
==
e
.
getKeyCode
())
{
Color
color
=
swatchPanel
.
getSelectedColor
();
setSelectedColor
(
color
);
recentSwatchPanel
.
setMostRecentColor
(
color
);
}
}
}
class
RecentSwatchListener
extends
MouseAdapter
implements
Serializable
{
class
RecentSwatchListener
extends
MouseAdapter
implements
Serializable
{
public
void
mousePressed
(
MouseEvent
e
)
{
public
void
mousePressed
(
MouseEvent
e
)
{
if
(
isEnabled
())
{
if
(
isEnabled
())
{
Color
color
=
recentSwatchPanel
.
getColorForLocation
(
e
.
getX
(),
e
.
getY
());
Color
color
=
recentSwatchPanel
.
getColorForLocation
(
e
.
getX
(),
e
.
getY
());
recentSwatchPanel
.
setSelectedColorFromLocation
(
e
.
getX
(),
e
.
getY
());
setSelectedColor
(
color
);
setSelectedColor
(
color
);
recentSwatchPanel
.
requestFocusInWindow
();
}
}
}
}
}
}
...
@@ -223,7 +256,9 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
...
@@ -223,7 +256,9 @@ class DefaultSwatchChooserPanel extends AbstractColorChooserPanel {
if
(
isEnabled
())
{
if
(
isEnabled
())
{
Color
color
=
swatchPanel
.
getColorForLocation
(
e
.
getX
(),
e
.
getY
());
Color
color
=
swatchPanel
.
getColorForLocation
(
e
.
getX
(),
e
.
getY
());
setSelectedColor
(
color
);
setSelectedColor
(
color
);
swatchPanel
.
setSelectedColorFromLocation
(
e
.
getX
(),
e
.
getY
());
recentSwatchPanel
.
setMostRecentColor
(
color
);
recentSwatchPanel
.
setMostRecentColor
(
color
);
swatchPanel
.
requestFocusInWindow
();
}
}
}
}
}
}
...
@@ -239,18 +274,81 @@ class SwatchPanel extends JPanel {
...
@@ -239,18 +274,81 @@ class SwatchPanel extends JPanel {
protected
Dimension
numSwatches
;
protected
Dimension
numSwatches
;
protected
Dimension
gap
;
protected
Dimension
gap
;
private
int
selRow
;
private
int
selCol
;
public
SwatchPanel
()
{
public
SwatchPanel
()
{
initValues
();
initValues
();
initColors
();
initColors
();
setToolTipText
(
""
);
// register for events
setToolTipText
(
""
);
// register for events
setOpaque
(
true
);
setOpaque
(
true
);
setBackground
(
Color
.
white
);
setBackground
(
Color
.
white
);
set
RequestFocusEnabled
(
fals
e
);
set
Focusable
(
tru
e
);
setInheritsPopupMenu
(
true
);
setInheritsPopupMenu
(
true
);
addFocusListener
(
new
FocusAdapter
()
{
public
void
focusGained
(
FocusEvent
e
)
{
repaint
();
}
public
void
focusLost
(
FocusEvent
e
)
{
repaint
();
}
});
addKeyListener
(
new
KeyAdapter
()
{
public
void
keyPressed
(
KeyEvent
e
)
{
int
typed
=
e
.
getKeyCode
();
switch
(
typed
)
{
case
KeyEvent
.
VK_UP
:
if
(
selRow
>
0
)
{
selRow
--;
repaint
();
}
break
;
case
KeyEvent
.
VK_DOWN
:
if
(
selRow
<
numSwatches
.
height
-
1
)
{
selRow
++;
repaint
();
}
break
;
case
KeyEvent
.
VK_LEFT
:
if
(
selCol
>
0
&&
SwatchPanel
.
this
.
getComponentOrientation
().
isLeftToRight
())
{
selCol
--;
repaint
();
}
else
if
(
selCol
<
numSwatches
.
width
-
1
&&
!
SwatchPanel
.
this
.
getComponentOrientation
().
isLeftToRight
())
{
selCol
++;
repaint
();
}
break
;
case
KeyEvent
.
VK_RIGHT
:
if
(
selCol
<
numSwatches
.
width
-
1
&&
SwatchPanel
.
this
.
getComponentOrientation
().
isLeftToRight
())
{
selCol
++;
repaint
();
}
else
if
(
selCol
>
0
&&
!
SwatchPanel
.
this
.
getComponentOrientation
().
isLeftToRight
())
{
selCol
--;
repaint
();
}
break
;
case
KeyEvent
.
VK_HOME
:
selCol
=
0
;
selRow
=
0
;
repaint
();
break
;
case
KeyEvent
.
VK_END
:
selCol
=
numSwatches
.
width
-
1
;
selRow
=
numSwatches
.
height
-
1
;
repaint
();
break
;
}
}
});
}
}
public
boolean
isFocusTraversable
()
{
public
Color
getSelectedColor
()
{
return
false
;
return
getColorForCell
(
selCol
,
selRow
)
;
}
}
protected
void
initValues
()
{
protected
void
initValues
()
{
...
@@ -263,11 +361,10 @@ class SwatchPanel extends JPanel {
...
@@ -263,11 +361,10 @@ class SwatchPanel extends JPanel {
for
(
int
row
=
0
;
row
<
numSwatches
.
height
;
row
++)
{
for
(
int
row
=
0
;
row
<
numSwatches
.
height
;
row
++)
{
int
y
=
row
*
(
swatchSize
.
height
+
gap
.
height
);
int
y
=
row
*
(
swatchSize
.
height
+
gap
.
height
);
for
(
int
column
=
0
;
column
<
numSwatches
.
width
;
column
++)
{
for
(
int
column
=
0
;
column
<
numSwatches
.
width
;
column
++)
{
Color
c
=
getColorForCell
(
column
,
row
);
g
.
setColor
(
getColorForCell
(
column
,
row
)
);
g
.
setColor
(
c
);
int
x
;
int
x
;
if
((!
this
.
getComponentOrientation
().
isLeftToRight
())
&&
if
(!
this
.
getComponentOrientation
().
isLeftToRight
())
{
(
this
instanceof
RecentSwatchPanel
))
{
x
=
(
numSwatches
.
width
-
column
-
1
)
*
(
swatchSize
.
width
+
gap
.
width
);
x
=
(
numSwatches
.
width
-
column
-
1
)
*
(
swatchSize
.
width
+
gap
.
width
);
}
else
{
}
else
{
x
=
column
*
(
swatchSize
.
width
+
gap
.
width
);
x
=
column
*
(
swatchSize
.
width
+
gap
.
width
);
...
@@ -276,6 +373,20 @@ class SwatchPanel extends JPanel {
...
@@ -276,6 +373,20 @@ class SwatchPanel extends JPanel {
g
.
setColor
(
Color
.
black
);
g
.
setColor
(
Color
.
black
);
g
.
drawLine
(
x
+
swatchSize
.
width
-
1
,
y
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
+
swatchSize
.
width
-
1
,
y
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
,
y
+
swatchSize
.
height
-
1
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
,
y
+
swatchSize
.
height
-
1
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
if
(
selRow
==
row
&&
selCol
==
column
&&
this
.
isFocusOwner
())
{
Color
c2
=
new
Color
(
c
.
getRed
()
<
125
?
255
:
0
,
c
.
getGreen
()
<
125
?
255
:
0
,
c
.
getBlue
()
<
125
?
255
:
0
);
g
.
setColor
(
c2
);
g
.
drawLine
(
x
,
y
,
x
+
swatchSize
.
width
-
1
,
y
);
g
.
drawLine
(
x
,
y
,
x
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
+
swatchSize
.
width
-
1
,
y
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
,
y
+
swatchSize
.
height
-
1
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
,
y
,
x
+
swatchSize
.
width
-
1
,
y
+
swatchSize
.
height
-
1
);
g
.
drawLine
(
x
,
y
+
swatchSize
.
height
-
1
,
x
+
swatchSize
.
width
-
1
,
y
);
}
}
}
}
}
}
}
...
@@ -296,10 +407,19 @@ class SwatchPanel extends JPanel {
...
@@ -296,10 +407,19 @@ class SwatchPanel extends JPanel {
return
color
.
getRed
()+
", "
+
color
.
getGreen
()
+
", "
+
color
.
getBlue
();
return
color
.
getRed
()+
", "
+
color
.
getGreen
()
+
", "
+
color
.
getBlue
();
}
}
public
void
setSelectedColorFromLocation
(
int
x
,
int
y
)
{
if
(!
this
.
getComponentOrientation
().
isLeftToRight
())
{
selCol
=
numSwatches
.
width
-
x
/
(
swatchSize
.
width
+
gap
.
width
)
-
1
;
}
else
{
selCol
=
x
/
(
swatchSize
.
width
+
gap
.
width
);
}
selRow
=
y
/
(
swatchSize
.
height
+
gap
.
height
);
repaint
();
}
public
Color
getColorForLocation
(
int
x
,
int
y
)
{
public
Color
getColorForLocation
(
int
x
,
int
y
)
{
int
column
;
int
column
;
if
((!
this
.
getComponentOrientation
().
isLeftToRight
())
&&
if
(!
this
.
getComponentOrientation
().
isLeftToRight
())
{
(
this
instanceof
RecentSwatchPanel
))
{
column
=
numSwatches
.
width
-
x
/
(
swatchSize
.
width
+
gap
.
width
)
-
1
;
column
=
numSwatches
.
width
-
x
/
(
swatchSize
.
width
+
gap
.
width
)
-
1
;
}
else
{
}
else
{
column
=
x
/
(
swatchSize
.
width
+
gap
.
width
);
column
=
x
/
(
swatchSize
.
width
+
gap
.
width
);
...
...
src/solaris/classes/sun/java2d/xr/XRDrawImage.java
浏览文件 @
6b8e61fd
...
@@ -27,6 +27,7 @@ package sun.java2d.xr;
...
@@ -27,6 +27,7 @@ package sun.java2d.xr;
import
java.awt.*
;
import
java.awt.*
;
import
java.awt.geom.*
;
import
java.awt.geom.*
;
import
java.awt.image.*
;
import
sun.java2d.*
;
import
sun.java2d.*
;
import
sun.java2d.loops.*
;
import
sun.java2d.loops.*
;
...
@@ -45,8 +46,8 @@ public class XRDrawImage extends DrawImage {
...
@@ -45,8 +46,8 @@ public class XRDrawImage extends DrawImage {
SurfaceData
srcData
=
dstData
.
getSourceSurfaceData
(
img
,
SurfaceData
srcData
=
dstData
.
getSourceSurfaceData
(
img
,
SunGraphics2D
.
TRANSFORM_GENERIC
,
sg
.
imageComp
,
bgColor
);
SunGraphics2D
.
TRANSFORM_GENERIC
,
sg
.
imageComp
,
bgColor
);
if
(
srcData
!=
null
&&
!
isBgOperation
(
srcData
,
bgColor
)
)
{
// TODO: Do we bail out on bgBlits?
if
(
srcData
!=
null
&&
!
isBgOperation
(
srcData
,
bgColor
)
// && srcData instanceof XRSurfaceData
) {
&&
interpType
<=
AffineTransformOp
.
TYPE_BILINEAR
)
{
SurfaceType
srcType
=
srcData
.
getSurfaceType
();
SurfaceType
srcType
=
srcData
.
getSurfaceType
();
SurfaceType
dstType
=
dstData
.
getSurfaceType
();
SurfaceType
dstType
=
dstData
.
getSurfaceType
();
...
...
src/solaris/native/sun/awt/initIDs.c
浏览文件 @
6b8e61fd
...
@@ -88,6 +88,12 @@ Java_java_awt_CheckboxMenuItem_initIDs
...
@@ -88,6 +88,12 @@ Java_java_awt_CheckboxMenuItem_initIDs
{
{
}
}
JNIEXPORT
void
JNICALL
Java_java_awt_Choice_initIDs
(
JNIEnv
*
env
,
jclass
clazz
)
{
}
JNIEXPORT
void
JNICALL
JNIEXPORT
void
JNICALL
Java_java_awt_Dimension_initIDs
Java_java_awt_Dimension_initIDs
(
JNIEnv
*
env
,
jclass
clazz
)
(
JNIEnv
*
env
,
jclass
clazz
)
...
...
src/windows/native/sun/windows/awt_Choice.cpp
浏览文件 @
6b8e61fd
...
@@ -79,6 +79,10 @@ BOOL AwtChoice::sm_isMouseMoveInList = FALSE;
...
@@ -79,6 +79,10 @@ BOOL AwtChoice::sm_isMouseMoveInList = FALSE;
static
const
UINT
MINIMUM_NUMBER_OF_VISIBLE_ITEMS
=
8
;
static
const
UINT
MINIMUM_NUMBER_OF_VISIBLE_ITEMS
=
8
;
namespace
{
jfieldID
selectedIndexID
;
}
/*************************************************************************
/*************************************************************************
* AwtChoice class methods
* AwtChoice class methods
*/
*/
...
@@ -86,7 +90,6 @@ static const UINT MINIMUM_NUMBER_OF_VISIBLE_ITEMS = 8;
...
@@ -86,7 +90,6 @@ static const UINT MINIMUM_NUMBER_OF_VISIBLE_ITEMS = 8;
AwtChoice
::
AwtChoice
()
{
AwtChoice
::
AwtChoice
()
{
m_hList
=
NULL
;
m_hList
=
NULL
;
m_listDefWindowProc
=
NULL
;
m_listDefWindowProc
=
NULL
;
m_selectedItem
=
-
1
;
}
}
LPCTSTR
AwtChoice
::
GetClassName
()
{
LPCTSTR
AwtChoice
::
GetClassName
()
{
...
@@ -102,7 +105,6 @@ void AwtChoice::Dispose() {
...
@@ -102,7 +105,6 @@ void AwtChoice::Dispose() {
AwtChoice
*
AwtChoice
::
Create
(
jobject
peer
,
jobject
parent
)
{
AwtChoice
*
AwtChoice
::
Create
(
jobject
peer
,
jobject
parent
)
{
JNIEnv
*
env
=
(
JNIEnv
*
)
JNU_GetEnv
(
jvm
,
JNI_VERSION_1_2
);
JNIEnv
*
env
=
(
JNIEnv
*
)
JNU_GetEnv
(
jvm
,
JNI_VERSION_1_2
);
jobject
target
=
NULL
;
jobject
target
=
NULL
;
...
@@ -438,10 +440,14 @@ LRESULT CALLBACK AwtChoice::ListWindowProc(HWND hwnd, UINT message,
...
@@ -438,10 +440,14 @@ LRESULT CALLBACK AwtChoice::ListWindowProc(HWND hwnd, UINT message,
MsgRouting
AwtChoice
::
WmNotify
(
UINT
notifyCode
)
MsgRouting
AwtChoice
::
WmNotify
(
UINT
notifyCode
)
{
{
if
(
notifyCode
==
CBN_SELCHANGE
)
{
if
(
notifyCode
==
CBN_SELCHANGE
)
{
int
selectedItem
=
(
int
)
SendMessage
(
CB_GETCURSEL
);
int
selectedIndex
=
(
int
)
SendMessage
(
CB_GETCURSEL
);
if
(
selectedItem
!=
CB_ERR
&&
m_selectedItem
!=
selectedItem
){
m_selectedItem
=
selectedItem
;
JNIEnv
*
env
=
(
JNIEnv
*
)
JNU_GetEnv
(
jvm
,
JNI_VERSION_1_2
);
DoCallback
(
"handleAction"
,
"(I)V"
,
selectedItem
);
jobject
target
=
GetTarget
(
env
);
int
previousIndex
=
env
->
GetIntField
(
target
,
selectedIndexID
);
if
(
selectedIndex
!=
CB_ERR
&&
selectedIndex
!=
previousIndex
){
DoCallback
(
"handleAction"
,
"(I)V"
,
selectedIndex
);
}
}
}
else
if
(
notifyCode
==
CBN_DROPDOWN
)
{
}
else
if
(
notifyCode
==
CBN_DROPDOWN
)
{
...
@@ -695,6 +701,15 @@ done:
...
@@ -695,6 +701,15 @@ done:
extern
"C"
{
extern
"C"
{
JNIEXPORT
void
JNICALL
Java_java_awt_Choice_initIDs
(
JNIEnv
*
env
,
jclass
cls
)
{
TRY
;
selectedIndexID
=
env
->
GetFieldID
(
cls
,
"selectedIndex"
,
"I"
);
DASSERT
(
selectedIndexID
);
CATCH_BAD_ALLOC
;
}
/*
/*
* Class: sun_awt_windows_WChoicePeer
* Class: sun_awt_windows_WChoicePeer
* Method: select
* Method: select
...
...
src/windows/native/sun/windows/awt_Choice.h
浏览文件 @
6b8e61fd
...
@@ -94,7 +94,6 @@ private:
...
@@ -94,7 +94,6 @@ private:
static
BOOL
sm_isMouseMoveInList
;
static
BOOL
sm_isMouseMoveInList
;
HWND
m_hList
;
HWND
m_hList
;
WNDPROC
m_listDefWindowProc
;
WNDPROC
m_listDefWindowProc
;
int
m_selectedItem
;
static
LRESULT
CALLBACK
ListWindowProc
(
HWND
hwnd
,
UINT
message
,
static
LRESULT
CALLBACK
ListWindowProc
(
HWND
hwnd
,
UINT
message
,
WPARAM
wParam
,
LPARAM
lParam
);
WPARAM
wParam
,
LPARAM
lParam
);
};
};
...
...
src/windows/native/sun/windows/awt_Component.cpp
浏览文件 @
6b8e61fd
...
@@ -3144,7 +3144,8 @@ void AwtComponent::JavaKeyToWindowsKey(UINT javaKey,
...
@@ -3144,7 +3144,8 @@ void AwtComponent::JavaKeyToWindowsKey(UINT javaKey,
return
;
return
;
}
}
UINT
AwtComponent
::
WindowsKeyToJavaKey
(
UINT
windowsKey
,
UINT
modifiers
)
UINT
AwtComponent
::
WindowsKeyToJavaKey
(
UINT
windowsKey
,
UINT
modifiers
,
UINT
character
,
BOOL
isDeadKey
)
{
{
// Handle the few cases where we need to take the modifier into
// Handle the few cases where we need to take the modifier into
// consideration for the Java VK code or where we have to take the keyboard
// consideration for the Java VK code or where we have to take the keyboard
...
@@ -3171,6 +3172,15 @@ UINT AwtComponent::WindowsKeyToJavaKey(UINT windowsKey, UINT modifiers)
...
@@ -3171,6 +3172,15 @@ UINT AwtComponent::WindowsKeyToJavaKey(UINT windowsKey, UINT modifiers)
break
;
break
;
};
};
// check dead key
if
(
isDeadKey
)
{
for
(
int
i
=
0
;
charToDeadVKTable
[
i
].
c
!=
0
;
i
++
)
{
if
(
charToDeadVKTable
[
i
].
c
==
character
)
{
return
charToDeadVKTable
[
i
].
javaKey
;
}
}
}
// for the general case, use a bi-directional table
// for the general case, use a bi-directional table
for
(
int
i
=
0
;
keyMapTable
[
i
].
windowsKey
!=
0
;
i
++
)
{
for
(
int
i
=
0
;
keyMapTable
[
i
].
windowsKey
!=
0
;
i
++
)
{
if
(
keyMapTable
[
i
].
windowsKey
==
windowsKey
)
{
if
(
keyMapTable
[
i
].
windowsKey
==
windowsKey
)
{
...
@@ -3384,14 +3394,18 @@ AwtComponent::UpdateDynPrimaryKeymap(UINT wkey, UINT jkeyLegacy, jint keyLocatio
...
@@ -3384,14 +3394,18 @@ AwtComponent::UpdateDynPrimaryKeymap(UINT wkey, UINT jkeyLegacy, jint keyLocatio
}
}
}
}
UINT
AwtComponent
::
WindowsKeyToJavaChar
(
UINT
wkey
,
UINT
modifiers
,
TransOps
ops
)
UINT
AwtComponent
::
WindowsKeyToJavaChar
(
UINT
wkey
,
UINT
modifiers
,
TransOps
ops
,
BOOL
&
isDeadKey
)
{
{
static
Hashtable
transTable
(
"VKEY translations"
);
static
Hashtable
transTable
(
"VKEY translations"
);
static
Hashtable
deadKeyFlagTable
(
"Dead Key Flags"
);
isDeadKey
=
FALSE
;
// Try to translate using last saved translation
// Try to translate using last saved translation
if
(
ops
==
LOAD
)
{
if
(
ops
==
LOAD
)
{
void
*
deadKeyFlag
=
deadKeyFlagTable
.
remove
(
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
wkey
)));
void
*
value
=
transTable
.
remove
(
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
wkey
)));
void
*
value
=
transTable
.
remove
(
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
wkey
)));
if
(
value
!=
NULL
)
{
if
(
value
!=
NULL
)
{
isDeadKey
=
static_cast
<
BOOL
>
(
reinterpret_cast
<
INT_PTR
>
(
deadKeyFlag
));
return
static_cast
<
UINT
>
(
reinterpret_cast
<
INT_PTR
>
(
value
));
return
static_cast
<
UINT
>
(
reinterpret_cast
<
INT_PTR
>
(
value
));
}
}
}
}
...
@@ -3484,12 +3498,13 @@ UINT AwtComponent::WindowsKeyToJavaChar(UINT wkey, UINT modifiers, TransOps ops)
...
@@ -3484,12 +3498,13 @@ UINT AwtComponent::WindowsKeyToJavaChar(UINT wkey, UINT modifiers, TransOps ops)
// instead of creating our own conversion tables, I'll let Win32
// instead of creating our own conversion tables, I'll let Win32
// convert the character for me.
// convert the character for me.
WORD
mbChar
;
WORD
wChar
[
2
]
;
UINT
scancode
=
::
MapVirtualKey
(
wkey
,
0
);
UINT
scancode
=
::
MapVirtualKey
(
wkey
,
0
);
int
converted
=
::
To
Ascii
Ex
(
wkey
,
scancode
,
keyboardState
,
int
converted
=
::
To
Unicode
Ex
(
wkey
,
scancode
,
keyboardState
,
&
mbChar
,
0
,
GetKeyboardLayout
());
wChar
,
2
,
0
,
GetKeyboardLayout
());
UINT
translation
;
UINT
translation
;
BOOL
deadKeyFlag
=
(
converted
==
2
);
// Dead Key
// Dead Key
if
(
converted
<
0
)
{
if
(
converted
<
0
)
{
...
@@ -3508,16 +3523,16 @@ UINT AwtComponent::WindowsKeyToJavaChar(UINT wkey, UINT modifiers, TransOps ops)
...
@@ -3508,16 +3523,16 @@ UINT AwtComponent::WindowsKeyToJavaChar(UINT wkey, UINT modifiers, TransOps ops)
}
else
}
else
// the caller expects a Unicode character.
// the caller expects a Unicode character.
if
(
converted
>
0
)
{
if
(
converted
>
0
)
{
WCHAR
unicodeChar
[
2
];
translation
=
wChar
[
0
];
VERIFY
(
::
MultiByteToWideChar
(
GetCodePage
(),
MB_PRECOMPOSED
,
(
LPCSTR
)
&
mbChar
,
1
,
unicodeChar
,
1
));
translation
=
unicodeChar
[
0
];
}
}
if
(
ops
==
SAVE
)
{
if
(
ops
==
SAVE
)
{
transTable
.
put
(
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
wkey
)),
transTable
.
put
(
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
wkey
)),
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
translation
)));
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
translation
)));
deadKeyFlagTable
.
put
(
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
wkey
)),
reinterpret_cast
<
void
*>
(
static_cast
<
INT_PTR
>
(
deadKeyFlag
)));
}
}
isDeadKey
=
deadKeyFlag
;
return
translation
;
return
translation
;
}
}
...
@@ -3537,8 +3552,9 @@ MsgRouting AwtComponent::WmKeyDown(UINT wkey, UINT repCnt,
...
@@ -3537,8 +3552,9 @@ MsgRouting AwtComponent::WmKeyDown(UINT wkey, UINT repCnt,
UINT
modifiers
=
GetJavaModifiers
();
UINT
modifiers
=
GetJavaModifiers
();
jint
keyLocation
=
GetKeyLocation
(
wkey
,
flags
);
jint
keyLocation
=
GetKeyLocation
(
wkey
,
flags
);
UINT
jkey
=
WindowsKeyToJavaKey
(
wkey
,
modifiers
);
BOOL
isDeadKey
=
FALSE
;
UINT
character
=
WindowsKeyToJavaChar
(
wkey
,
modifiers
,
SAVE
);
UINT
character
=
WindowsKeyToJavaChar
(
wkey
,
modifiers
,
SAVE
,
isDeadKey
);
UINT
jkey
=
WindowsKeyToJavaKey
(
wkey
,
modifiers
,
character
,
isDeadKey
);
UpdateDynPrimaryKeymap
(
wkey
,
jkey
,
keyLocation
,
modifiers
);
UpdateDynPrimaryKeymap
(
wkey
,
jkey
,
keyLocation
,
modifiers
);
...
@@ -3579,8 +3595,9 @@ MsgRouting AwtComponent::WmKeyUp(UINT wkey, UINT repCnt,
...
@@ -3579,8 +3595,9 @@ MsgRouting AwtComponent::WmKeyUp(UINT wkey, UINT repCnt,
UINT
modifiers
=
GetJavaModifiers
();
UINT
modifiers
=
GetJavaModifiers
();
jint
keyLocation
=
GetKeyLocation
(
wkey
,
flags
);
jint
keyLocation
=
GetKeyLocation
(
wkey
,
flags
);
UINT
jkey
=
WindowsKeyToJavaKey
(
wkey
,
modifiers
);
BOOL
isDeadKey
=
FALSE
;
UINT
character
=
WindowsKeyToJavaChar
(
wkey
,
modifiers
,
LOAD
);
UINT
character
=
WindowsKeyToJavaChar
(
wkey
,
modifiers
,
LOAD
,
isDeadKey
);
UINT
jkey
=
WindowsKeyToJavaKey
(
wkey
,
modifiers
,
character
,
isDeadKey
);
UpdateDynPrimaryKeymap
(
wkey
,
jkey
,
keyLocation
,
modifiers
);
UpdateDynPrimaryKeymap
(
wkey
,
jkey
,
keyLocation
,
modifiers
);
SendKeyEventToFocusOwner
(
java_awt_event_KeyEvent_KEY_RELEASED
,
SendKeyEventToFocusOwner
(
java_awt_event_KeyEvent_KEY_RELEASED
,
...
@@ -5628,7 +5645,8 @@ void AwtComponent::_NativeHandleEvent(void *param)
...
@@ -5628,7 +5645,8 @@ void AwtComponent::_NativeHandleEvent(void *param)
}
}
}
}
modifiedChar
=
p
->
WindowsKeyToJavaChar
(
winKey
,
modifiers
,
AwtComponent
::
NONE
);
BOOL
isDeadKey
=
FALSE
;
modifiedChar
=
p
->
WindowsKeyToJavaChar
(
winKey
,
modifiers
,
AwtComponent
::
NONE
,
isDeadKey
);
bCharChanged
=
(
keyChar
!=
modifiedChar
);
bCharChanged
=
(
keyChar
!=
modifiedChar
);
}
}
break
;
break
;
...
@@ -7166,4 +7184,4 @@ void ReleaseDCList(HWND hwnd, DCList &list) {
...
@@ -7166,4 +7184,4 @@ void ReleaseDCList(HWND hwnd, DCList &list) {
removedDCs
=
removedDCs
->
next
;
removedDCs
=
removedDCs
->
next
;
delete
tmpDCList
;
delete
tmpDCList
;
}
}
}
}
\ No newline at end of file
src/windows/native/sun/windows/awt_Component.h
浏览文件 @
6b8e61fd
...
@@ -441,7 +441,7 @@ public:
...
@@ -441,7 +441,7 @@ public:
static
jint
GetJavaModifiers
();
static
jint
GetJavaModifiers
();
static
jint
GetButton
(
int
mouseButton
);
static
jint
GetButton
(
int
mouseButton
);
static
UINT
GetButtonMK
(
int
mouseButton
);
static
UINT
GetButtonMK
(
int
mouseButton
);
static
UINT
WindowsKeyToJavaKey
(
UINT
windowsKey
,
UINT
modifiers
);
static
UINT
WindowsKeyToJavaKey
(
UINT
windowsKey
,
UINT
modifiers
,
UINT
character
,
BOOL
isDeadKey
);
static
void
JavaKeyToWindowsKey
(
UINT
javaKey
,
UINT
*
windowsKey
,
UINT
*
modifiers
,
UINT
originalWindowsKey
);
static
void
JavaKeyToWindowsKey
(
UINT
javaKey
,
UINT
*
windowsKey
,
UINT
*
modifiers
,
UINT
originalWindowsKey
);
static
void
UpdateDynPrimaryKeymap
(
UINT
wkey
,
UINT
jkeyLegacy
,
jint
keyLocation
,
UINT
modifiers
);
static
void
UpdateDynPrimaryKeymap
(
UINT
wkey
,
UINT
jkeyLegacy
,
jint
keyLocation
,
UINT
modifiers
);
...
@@ -453,7 +453,7 @@ public:
...
@@ -453,7 +453,7 @@ public:
enum
TransOps
{
NONE
,
LOAD
,
SAVE
};
enum
TransOps
{
NONE
,
LOAD
,
SAVE
};
UINT
WindowsKeyToJavaChar
(
UINT
wkey
,
UINT
modifiers
,
TransOps
ops
);
UINT
WindowsKeyToJavaChar
(
UINT
wkey
,
UINT
modifiers
,
TransOps
ops
,
BOOL
&
isDeadKey
);
/* routines used for input method support */
/* routines used for input method support */
void
SetInputMethod
(
jobject
im
,
BOOL
useNativeCompWindow
);
void
SetInputMethod
(
jobject
im
,
BOOL
useNativeCompWindow
);
...
...
test/java/awt/Choice/ItemStateChangeTest/ItemStateChangeTest.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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 7171412
@summary awt Choice doesn't fire ItemStateChange when selecting item after select() call
@author Oleg Pekhovskiy: area=awt-choice
@library ../../regtesthelpers
@build Util
@run main ItemStateChangeTest
*/
import
test.java.awt.regtesthelpers.Util
;
import
java.awt.*
;
import
java.awt.event.*
;
import
sun.awt.OSInfo
;
public
class
ItemStateChangeTest
extends
Frame
{
int
events
=
0
;
public
static
void
main
(
String
args
[])
{
new
ItemStateChangeTest
();
}
public
ItemStateChangeTest
()
{
if
(
OSInfo
.
getOSType
()
!=
OSInfo
.
OSType
.
WINDOWS
)
{
return
;
}
try
{
final
Robot
robot
=
new
Robot
();
robot
.
setAutoDelay
(
20
);
Util
.
waitForIdle
(
robot
);
addWindowListener
(
new
WindowAdapter
()
{
@Override
public
void
windowClosing
(
WindowEvent
e
)
{
System
.
exit
(
0
);
}
});
final
Choice
choice
=
new
Choice
();
choice
.
add
(
"A"
);
choice
.
add
(
"B"
);
choice
.
addItemListener
(
new
ItemListener
()
{
@Override
public
void
itemStateChanged
(
ItemEvent
e
)
{
++
events
;
}
});
add
(
choice
);
setSize
(
200
,
150
);
setVisible
(
true
);
toFront
();
// choose B
int
y
=
chooseB
(
choice
,
robot
,
16
);
// reset to A
choice
.
select
(
0
);
robot
.
delay
(
20
);
Util
.
waitForIdle
(
robot
);
// choose B again
chooseB
(
choice
,
robot
,
y
);
if
(
events
==
2
)
{
System
.
out
.
println
(
"Test passed!"
);
}
else
{
throw
new
RuntimeException
(
"Test failed!"
);
}
}
catch
(
AWTException
e
)
{
throw
new
RuntimeException
(
"Test failed!"
);
}
}
final
int
chooseB
(
Choice
choice
,
Robot
robot
,
int
y
)
{
while
(
true
)
{
// show drop-down list
Util
.
clickOnComp
(
choice
,
robot
);
Util
.
waitForIdle
(
robot
);
Point
pt
=
choice
.
getLocationOnScreen
();
Dimension
size
=
choice
.
getSize
();
// try to click B item
robot
.
mouseMove
(
pt
.
x
+
size
.
width
/
2
,
pt
.
y
+
size
.
height
+
y
);
Util
.
waitForIdle
(
robot
);
robot
.
mousePress
(
InputEvent
.
BUTTON1_DOWN_MASK
);
Util
.
waitForIdle
(
robot
);
robot
.
mouseRelease
(
InputEvent
.
BUTTON1_DOWN_MASK
);
Util
.
waitForIdle
(
robot
);
if
(
choice
.
getSelectedIndex
()
==
1
)
{
break
;
}
// if it's not B, position cursor lower by 2 pixels and try again
y
+=
2
;
}
return
y
;
}
}
test/java/awt/List/EmptyListEventTest/EmptyListEventTest.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2008, 2012, 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 6366126
* @summary List throws ArrayIndexOutOfBoundsException when pressing ENTER after removing all the items, Win32
* @author Dmitry Cherepanov area=awt.list
* @run main EmptyListEventTest
*/
import
java.awt.*
;
import
java.awt.event.*
;
import
javax.swing.JFrame
;
import
javax.swing.JPanel
;
import
javax.swing.SwingUtilities
;
import
sun.awt.SunToolkit
;
public
class
EmptyListEventTest
{
private
static
List
list
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
SunToolkit
toolkit
=
(
SunToolkit
)
Toolkit
.
getDefaultToolkit
();
Robot
robot
=
new
Robot
();
robot
.
setAutoDelay
(
50
);
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
createAndShowGUI
();
}
});
toolkit
.
realSync
();
// press mouse -> ItemEvent
Point
point
=
getClickPoint
();
robot
.
mouseMove
(
point
.
x
,
point
.
y
);
robot
.
mousePress
(
InputEvent
.
BUTTON1_MASK
);
robot
.
mouseRelease
(
InputEvent
.
BUTTON1_MASK
);
toolkit
.
realSync
();
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
list
.
requestFocusInWindow
();
}
});
toolkit
.
realSync
();
if
(
KeyboardFocusManager
.
getCurrentKeyboardFocusManager
().
getFocusOwner
()
!=
list
)
{
throw
new
RuntimeException
(
"Test failed - list isn't focus owner."
);
}
// press key ENTER -> ActionEvent
robot
.
keyPress
(
KeyEvent
.
VK_ENTER
);
robot
.
keyRelease
(
KeyEvent
.
VK_ENTER
);
toolkit
.
realSync
();
// press key SPACE -> ItemEvent
robot
.
keyPress
(
KeyEvent
.
VK_SPACE
);
robot
.
keyRelease
(
KeyEvent
.
VK_SPACE
);
toolkit
.
realSync
();
// mouse double click -> ActionEvent
robot
.
setAutoDelay
(
10
);
robot
.
mousePress
(
InputEvent
.
BUTTON1_MASK
);
robot
.
mouseRelease
(
InputEvent
.
BUTTON1_MASK
);
robot
.
mousePress
(
InputEvent
.
BUTTON1_MASK
);
robot
.
mouseRelease
(
InputEvent
.
BUTTON1_MASK
);
toolkit
.
realSync
();
}
private
static
Point
getClickPoint
()
throws
Exception
{
final
Point
[]
result
=
new
Point
[
1
];
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
Point
point
=
list
.
getLocationOnScreen
();
point
.
translate
(
list
.
getWidth
()
/
2
,
list
.
getHeight
()
/
2
);
result
[
0
]
=
point
;
}
});
return
result
[
0
];
}
private
static
void
createAndShowGUI
()
{
JFrame
frame
=
new
JFrame
();
frame
.
setSize
(
200
,
200
);
frame
.
setDefaultCloseOperation
(
JFrame
.
EXIT_ON_CLOSE
);
JPanel
panel
=
new
JPanel
(
new
BorderLayout
());
frame
.
getToolkit
().
addAWTEventListener
(
new
AWTEventListener
()
{
public
void
eventDispatched
(
AWTEvent
e
)
{
System
.
out
.
println
(
e
);
}
},
AWTEvent
.
FOCUS_EVENT_MASK
|
AWTEvent
.
WINDOW_FOCUS_EVENT_MASK
);
MyListener
listener
=
new
MyListener
();
list
=
new
List
(
4
,
true
);
list
.
addActionListener
(
listener
);
list
.
addItemListener
(
listener
);
panel
.
add
(
list
);
frame
.
getContentPane
().
add
(
panel
);
frame
.
setVisible
(
true
);
}
static
class
MyListener
implements
ActionListener
,
ItemListener
{
public
void
actionPerformed
(
ActionEvent
ae
)
{
System
.
err
.
println
(
ae
);
throw
new
RuntimeException
(
"Test failed - list is empty so event is redundant"
);
}
public
void
itemStateChanged
(
ItemEvent
ie
)
{
System
.
err
.
println
(
ie
);
throw
new
RuntimeException
(
"Test failed - list is empty so event is redundant"
);
}
}
}
test/java/awt/ScrollPane/ScrollPanePreferredSize/ScrollPanePreferredSize.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
import
java.awt.Dimension
;
import
java.awt.Frame
;
import
java.awt.ScrollPane
;
import
java.awt.Toolkit
;
import
sun.awt.SunToolkit
;
/**
* @test
* @bug 7124213
* @author Sergey Bylokhov
*/
public
final
class
ScrollPanePreferredSize
{
public
static
void
main
(
final
String
[]
args
)
{
final
Dimension
expected
=
new
Dimension
(
300
,
300
);
final
Frame
frame
=
new
Frame
();
final
ScrollPane
sp
=
new
ScrollPane
();
sp
.
setSize
(
expected
);
frame
.
add
(
sp
);
frame
.
pack
();
frame
.
setLocationRelativeTo
(
null
);
frame
.
setVisible
(
true
);
sleep
();
final
Dimension
size
=
frame
.
getSize
();
if
(
size
.
width
<
expected
.
width
||
size
.
height
<
expected
.
height
)
{
throw
new
RuntimeException
(
"Expected size: >= "
+
expected
+
", actual size: "
+
size
);
}
frame
.
dispose
();
}
private
static
void
sleep
()
{
((
SunToolkit
)
Toolkit
.
getDefaultToolkit
()).
realSync
();
try
{
Thread
.
sleep
(
500L
);
}
catch
(
InterruptedException
ignored
)
{
}
}
}
test/java/awt/TextArea/TextAreaTwicePack/TextAreaTwicePack.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle in the LICENSE file that accompanied this code.
*
* 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.
*/
import
java.awt.Dimension
;
import
java.awt.Frame
;
import
java.awt.TextArea
;
import
java.awt.Toolkit
;
import
sun.awt.SunToolkit
;
/**
* @test
* @bug 7160627
* @summary We shouldn't get different frame size when we call Frame.pack()
* twice.
* @author Sergey Bylokhov
*/
public
final
class
TextAreaTwicePack
{
public
static
void
main
(
final
String
[]
args
)
{
final
Frame
frame
=
new
Frame
();
final
TextArea
ta
=
new
TextArea
();
frame
.
add
(
ta
);
frame
.
pack
();
frame
.
setVisible
(
true
);
sleep
();
final
Dimension
before
=
frame
.
getSize
();
frame
.
pack
();
final
Dimension
after
=
frame
.
getSize
();
if
(!
after
.
equals
(
before
))
{
throw
new
RuntimeException
(
"Expected size: "
+
before
+
", actual size: "
+
after
);
}
frame
.
dispose
();
}
private
static
void
sleep
()
{
((
SunToolkit
)
Toolkit
.
getDefaultToolkit
()).
realSync
();
try
{
Thread
.
sleep
(
500L
);
}
catch
(
InterruptedException
ignored
)
{
}
}
}
test/java/awt/event/KeyEvent/DeadKey/DeadKeyMacOSXInputText.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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 7199180
* @summary [macosx] Dead keys handling for input methods
* @author alexandr.scherbatiy area=awt.event
* @run main DeadKeyMacOSXInputText
*/
import
java.awt.*
;
import
java.awt.event.*
;
import
java.awt.event.KeyEvent
;
import
javax.swing.JTextField
;
import
sun.awt.OSInfo
;
import
sun.awt.SunToolkit
;
public
class
DeadKeyMacOSXInputText
{
private
static
SunToolkit
toolkit
;
private
static
volatile
int
state
=
0
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
if
(
OSInfo
.
getOSType
()
!=
OSInfo
.
OSType
.
MACOSX
)
{
return
;
}
toolkit
=
(
SunToolkit
)
Toolkit
.
getDefaultToolkit
();
Robot
robot
=
new
Robot
();
robot
.
setAutoDelay
(
50
);
createAndShowGUI
();
// Pressed keys: Alt + E + A
// Results: ALT + VK_DEAD_ACUTE + a with accute accent
robot
.
keyPress
(
KeyEvent
.
VK_ALT
);
robot
.
keyPress
(
KeyEvent
.
VK_E
);
robot
.
keyRelease
(
KeyEvent
.
VK_E
);
robot
.
keyRelease
(
KeyEvent
.
VK_ALT
);
robot
.
keyPress
(
KeyEvent
.
VK_A
);
robot
.
keyRelease
(
KeyEvent
.
VK_A
);
toolkit
.
realSync
();
if
(
state
!=
3
)
{
throw
new
RuntimeException
(
"Wrong number of key events."
);
}
}
static
void
createAndShowGUI
()
{
Frame
frame
=
new
Frame
();
frame
.
setSize
(
300
,
300
);
Panel
panel
=
new
Panel
(
new
BorderLayout
());
JTextField
textField
=
new
JTextField
();
textField
.
addKeyListener
(
new
DeadKeyListener
());
panel
.
add
(
textField
,
BorderLayout
.
CENTER
);
frame
.
add
(
panel
);
frame
.
setVisible
(
true
);
toolkit
.
realSync
();
textField
.
requestFocusInWindow
();
toolkit
.
realSync
();
}
static
class
DeadKeyListener
extends
KeyAdapter
{
@Override
public
void
keyPressed
(
KeyEvent
e
)
{
int
keyCode
=
e
.
getKeyCode
();
char
keyChar
=
e
.
getKeyChar
();
switch
(
state
)
{
case
0
:
if
(
keyCode
!=
KeyEvent
.
VK_ALT
)
{
throw
new
RuntimeException
(
"Alt is not pressed."
);
}
state
++;
break
;
case
1
:
if
(
keyCode
!=
KeyEvent
.
VK_DEAD_ACUTE
)
{
throw
new
RuntimeException
(
"Dead ACUTE is not pressed."
);
}
if
(
keyChar
!=
0xB4
)
{
throw
new
RuntimeException
(
"Pressed char is not dead acute."
);
}
state
++;
break
;
}
}
@Override
public
void
keyTyped
(
KeyEvent
e
)
{
int
keyCode
=
e
.
getKeyCode
();
char
keyChar
=
e
.
getKeyChar
();
if
(
state
==
2
)
{
if
(
keyCode
!=
0
)
{
throw
new
RuntimeException
(
"Key code should be undefined."
);
}
if
(
keyChar
!=
0xE1
)
{
throw
new
RuntimeException
(
"A char does not have ACCUTE accent"
);
}
state
++;
}
else
{
throw
new
RuntimeException
(
"Wron number of keyTyped events."
);
}
}
}
}
test/javax/swing/JColorChooser/Test7194184.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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.
*/
/*
* Portions Copyright (c) 2012 IBM Corporation
*/
/*
* @test
* @bug 7194184
* @summary Tests JColorChooser Swatch keyboard accessibility.
* @author Sean Chou
* @library ../regtesthelpers
* @build Util
* @run main Test7194184
*/
import
java.awt.Component
;
import
java.awt.AWTException
;
import
java.awt.Color
;
import
java.awt.Robot
;
import
java.awt.Toolkit
;
import
java.awt.event.KeyEvent
;
import
javax.swing.JColorChooser
;
import
javax.swing.JFrame
;
import
javax.swing.SwingUtilities
;
import
java.util.concurrent.Callable
;
import
sun.awt.SunToolkit
;
public
class
Test7194184
implements
Runnable
{
private
static
JFrame
frame
;
private
static
JColorChooser
colorChooser
;
private
static
Color
selectedColor
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
testKeyBoardAccess
();
}
private
static
void
testKeyBoardAccess
()
throws
Exception
{
Robot
robot
=
new
Robot
();
SunToolkit
toolkit
=
(
SunToolkit
)
Toolkit
.
getDefaultToolkit
();
SwingUtilities
.
invokeLater
(
new
Test7194184
());
toolkit
.
realSync
();
SwingUtilities
.
invokeLater
(
new
Runnable
()
{
@Override
public
void
run
()
{
selectedColor
=
colorChooser
.
getColor
();
Component
recentSwatchPanel
=
Util
.
findSubComponent
(
colorChooser
,
"RecentSwatchPanel"
);
if
(
recentSwatchPanel
==
null
)
{
throw
new
RuntimeException
(
"RecentSwatchPanel not found"
);
}
recentSwatchPanel
.
requestFocusInWindow
();
}
});
toolkit
.
realSync
();
// Tab to move the focus to MainSwatch
Util
.
hitKeys
(
robot
,
KeyEvent
.
VK_SHIFT
,
KeyEvent
.
VK_TAB
);
// Select the color on right
Util
.
hitKeys
(
robot
,
KeyEvent
.
VK_RIGHT
);
Util
.
hitKeys
(
robot
,
KeyEvent
.
VK_RIGHT
);
Util
.
hitKeys
(
robot
,
KeyEvent
.
VK_SPACE
);
toolkit
.
realSync
();
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
frame
.
dispose
();
if
(
selectedColor
==
colorChooser
.
getColor
())
{
throw
new
RuntimeException
(
"JColorChooser misses keyboard accessibility"
);
}
}
});
}
public
void
run
()
{
String
title
=
getClass
().
getName
();
frame
=
new
JFrame
(
title
);
colorChooser
=
new
JColorChooser
();
frame
.
add
(
colorChooser
);
frame
.
pack
();
frame
.
setVisible
(
true
);
}
}
test/javax/swing/ToolTipManager/7123767/bug7123767.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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 7123767
@summary Wrong tooltip location in Multi-Monitor configurations
@author Vladislav Karnaukhov
@run main bug7123767
*/
import
sun.awt.SunToolkit
;
import
javax.swing.*
;
import
javax.swing.plaf.metal.MetalLookAndFeel
;
import
java.awt.*
;
import
java.awt.event.MouseEvent
;
import
java.lang.reflect.InvocationTargetException
;
public
class
bug7123767
extends
JFrame
{
private
static
class
TestFactory
extends
PopupFactory
{
private
static
TestFactory
newFactory
=
new
TestFactory
();
private
static
PopupFactory
oldFactory
;
private
TestFactory
()
{
super
();
}
public
static
void
install
()
{
if
(
oldFactory
==
null
)
{
oldFactory
=
getSharedInstance
();
setSharedInstance
(
newFactory
);
}
}
public
static
void
uninstall
()
{
if
(
oldFactory
!=
null
)
{
setSharedInstance
(
oldFactory
);
}
}
// Actual test happens here
public
Popup
getPopup
(
Component
owner
,
Component
contents
,
int
x
,
int
y
)
{
GraphicsConfiguration
mouseGC
=
testGC
(
MouseInfo
.
getPointerInfo
().
getLocation
());
if
(
mouseGC
==
null
)
{
throw
new
RuntimeException
(
"Can't find GraphicsConfiguration that mouse pointer belongs to"
);
}
GraphicsConfiguration
tipGC
=
testGC
(
new
Point
(
x
,
y
));
if
(
tipGC
==
null
)
{
throw
new
RuntimeException
(
"Can't find GraphicsConfiguration that tip belongs to"
);
}
if
(!
mouseGC
.
equals
(
tipGC
))
{
throw
new
RuntimeException
(
"Mouse and tip GCs are not equal"
);
}
return
super
.
getPopup
(
owner
,
contents
,
x
,
y
);
}
private
static
GraphicsConfiguration
testGC
(
Point
pt
)
{
GraphicsEnvironment
environment
=
GraphicsEnvironment
.
getLocalGraphicsEnvironment
();
GraphicsDevice
[]
devices
=
environment
.
getScreenDevices
();
for
(
GraphicsDevice
device
:
devices
)
{
GraphicsConfiguration
[]
configs
=
device
.
getConfigurations
();
for
(
GraphicsConfiguration
config
:
configs
)
{
Rectangle
rect
=
config
.
getBounds
();
Insets
insets
=
Toolkit
.
getDefaultToolkit
().
getScreenInsets
(
config
);
adjustInsets
(
rect
,
insets
);
if
(
rect
.
contains
(
pt
))
return
config
;
}
}
return
null
;
}
}
private
static
final
int
MARGIN
=
10
;
private
static
bug7123767
frame
;
private
static
Robot
robot
;
public
static
void
main
(
String
[]
args
)
throws
Exception
{
UIManager
.
setLookAndFeel
(
new
MetalLookAndFeel
());
setUp
();
testToolTip
();
TestFactory
.
uninstall
();
}
// Creates a window that is stretched across all available monitors
// and adds itself as ContainerListener to track tooltips drawing
private
bug7123767
()
{
super
();
ToolTipManager
.
sharedInstance
().
setInitialDelay
(
0
);
setDefaultCloseOperation
(
DISPOSE_ON_CLOSE
);
TestFactory
.
install
();
JLabel
label1
=
new
JLabel
(
"no preferred location"
);
label1
.
setToolTipText
(
"tip"
);
add
(
label1
,
BorderLayout
.
WEST
);
JLabel
label2
=
new
JLabel
(
"preferred location (20000, 20000)"
)
{
public
Point
getToolTipLocation
(
MouseEvent
event
)
{
return
new
Point
(
20000
,
20000
);
}
};
label2
.
setToolTipText
(
"tip"
);
add
(
label2
,
BorderLayout
.
EAST
);
setUndecorated
(
true
);
pack
();
Rectangle
rect
=
new
Rectangle
();
GraphicsEnvironment
environment
=
GraphicsEnvironment
.
getLocalGraphicsEnvironment
();
GraphicsDevice
[]
devices
=
environment
.
getScreenDevices
();
for
(
GraphicsDevice
device
:
devices
)
{
GraphicsConfiguration
[]
configs
=
device
.
getConfigurations
();
for
(
GraphicsConfiguration
config
:
configs
)
{
Insets
localInsets
=
Toolkit
.
getDefaultToolkit
().
getScreenInsets
(
config
);
Rectangle
localRect
=
config
.
getBounds
();
adjustInsets
(
localRect
,
localInsets
);
rect
.
add
(
localRect
);
}
}
setBounds
(
rect
);
}
private
static
void
setUp
()
throws
InterruptedException
,
InvocationTargetException
{
SwingUtilities
.
invokeAndWait
(
new
Runnable
()
{
@Override
public
void
run
()
{
frame
=
new
bug7123767
();
frame
.
setVisible
(
true
);
}
});
}
// Moves mouse pointer to the corners of every GraphicsConfiguration
private
static
void
testToolTip
()
throws
AWTException
{
SunToolkit
toolkit
=
(
SunToolkit
)
Toolkit
.
getDefaultToolkit
();
toolkit
.
realSync
();
GraphicsEnvironment
environment
=
GraphicsEnvironment
.
getLocalGraphicsEnvironment
();
GraphicsDevice
[]
devices
=
environment
.
getScreenDevices
();
for
(
GraphicsDevice
device
:
devices
)
{
GraphicsConfiguration
[]
configs
=
device
.
getConfigurations
();
for
(
GraphicsConfiguration
config
:
configs
)
{
Rectangle
rect
=
config
.
getBounds
();
Insets
insets
=
toolkit
.
getScreenInsets
(
config
);
adjustInsets
(
rect
,
insets
);
// Upper left
glide
(
rect
.
x
+
rect
.
width
/
2
,
rect
.
y
+
rect
.
height
/
2
,
rect
.
x
+
MARGIN
,
rect
.
y
+
MARGIN
);
toolkit
.
realSync
();
// Lower left
glide
(
rect
.
x
+
rect
.
width
/
2
,
rect
.
y
+
rect
.
height
/
2
,
rect
.
x
+
MARGIN
,
rect
.
y
+
rect
.
height
-
MARGIN
);
toolkit
.
realSync
();
// Upper right
glide
(
rect
.
x
+
rect
.
width
/
2
,
rect
.
y
+
rect
.
height
/
2
,
rect
.
x
+
rect
.
width
-
MARGIN
,
rect
.
y
+
MARGIN
);
toolkit
.
realSync
();
// Lower right
glide
(
rect
.
x
+
rect
.
width
/
2
,
rect
.
y
+
rect
.
height
/
2
,
rect
.
x
+
rect
.
width
-
MARGIN
,
rect
.
y
+
rect
.
height
-
MARGIN
);
toolkit
.
realSync
();
}
}
}
private
static
void
glide
(
int
x0
,
int
y0
,
int
x1
,
int
y1
)
throws
AWTException
{
if
(
robot
==
null
)
{
robot
=
new
Robot
();
robot
.
setAutoDelay
(
20
);
}
float
dmax
=
(
float
)
Math
.
max
(
Math
.
abs
(
x1
-
x0
),
Math
.
abs
(
y1
-
y0
));
float
dx
=
(
x1
-
x0
)
/
dmax
;
float
dy
=
(
y1
-
y0
)
/
dmax
;
robot
.
mouseMove
(
x0
,
y0
);
for
(
int
i
=
1
;
i
<=
dmax
;
i
+=
10
)
{
robot
.
mouseMove
((
int
)
(
x0
+
dx
*
i
),
(
int
)
(
y0
+
dy
*
i
));
}
}
private
static
void
adjustInsets
(
Rectangle
rect
,
final
Insets
insets
)
{
rect
.
x
+=
insets
.
left
;
rect
.
y
+=
insets
.
top
;
rect
.
width
-=
(
insets
.
left
+
insets
.
right
);
rect
.
height
-=
(
insets
.
top
+
insets
.
bottom
);
}
}
test/sun/java2d/pipe/InterpolationQualityTest.java
0 → 100644
浏览文件 @
6b8e61fd
/*
* Copyright (c) 2012, 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 7188093 8000176
* @summary Tests each of the 3 possible methods for rendering an upscaled
* image via rendering hints for default, xrender and opengl pipelines.
*
* @author Vadim.Pakhnushev@oracle.com
* @run main/othervm -Dsun.java2d.xrender=false InterpolationQualityTest
* @run main/othervm -Dsun.java2d.xrender=True InterpolationQualityTest
* @run main/othervm -Dsun.java2d.opengl=True InterpolationQualityTest
* @run main/othervm -Dsun.java2d.d3d=false InterpolationQualityTest
* @run main/othervm -Dsun.java2d.d3d=True InterpolationQualityTest
*/
import
java.awt.*
;
import
java.awt.image.*
;
import
java.io.File
;
import
java.io.IOException
;
import
javax.imageio.ImageIO
;
public
class
InterpolationQualityTest
{
private
static
final
int
testSize
=
4
,
scaleFactor
=
20
,
tolerance
=
3
;
private
static
final
int
sw
=
testSize
*
scaleFactor
;
private
static
final
int
sh
=
testSize
*
scaleFactor
;
private
Image
testImage
;
private
VolatileImage
vImg
;
public
InterpolationQualityTest
()
{
testImage
=
createTestImage
();
}
private
Image
createTestImage
()
{
BufferedImage
bi
=
new
BufferedImage
(
testSize
,
testSize
,
BufferedImage
.
TYPE_INT_ARGB
);
Graphics2D
g
=
bi
.
createGraphics
();
g
.
setColor
(
Color
.
BLACK
);
g
.
fillRect
(
0
,
0
,
testSize
,
testSize
);
for
(
int
i
=
0
;
i
<
testSize
;
i
++)
{
bi
.
setRGB
(
i
,
i
,
Color
.
WHITE
.
getRGB
());
}
return
bi
;
}
private
BufferedImage
createReferenceImage
(
Object
hint
)
{
BufferedImage
bi
=
new
BufferedImage
(
sw
,
sh
,
BufferedImage
.
TYPE_INT_ARGB
);
Graphics2D
g2d
=
bi
.
createGraphics
();
drawImage
(
g2d
,
hint
);
return
bi
;
}
private
void
drawImage
(
Graphics2D
g2d
,
Object
hint
)
{
g2d
.
setRenderingHint
(
RenderingHints
.
KEY_INTERPOLATION
,
hint
);
g2d
.
drawImage
(
testImage
,
0
,
0
,
sw
,
sh
,
null
);
}
private
GraphicsConfiguration
getDefaultGC
()
{
return
GraphicsEnvironment
.
getLocalGraphicsEnvironment
().
getDefaultScreenDevice
().
getDefaultConfiguration
();
}
private
void
createVImg
()
{
vImg
=
getDefaultGC
().
createCompatibleVolatileImage
(
sw
,
sh
);
}
private
void
renderOffscreen
(
Object
hint
)
{
Graphics2D
g
=
vImg
.
createGraphics
();
drawImage
(
g
,
hint
);
g
.
dispose
();
}
private
BufferedImage
renderImage
(
Object
hint
)
{
BufferedImage
snapshot
;
createVImg
();
renderOffscreen
(
hint
);
do
{
int
status
=
vImg
.
validate
(
getDefaultGC
());
if
(
status
!=
VolatileImage
.
IMAGE_OK
)
{
if
(
status
==
VolatileImage
.
IMAGE_INCOMPATIBLE
)
{
createVImg
();
}
renderOffscreen
(
hint
);
}
snapshot
=
vImg
.
getSnapshot
();
}
while
(
vImg
.
contentsLost
());
vImg
.
flush
();
return
snapshot
;
}
private
boolean
compareComponent
(
int
comp1
,
int
comp2
)
{
return
Math
.
abs
(
comp1
-
comp2
)
<=
tolerance
;
}
private
boolean
compareRGB
(
int
rgb1
,
int
rgb2
)
{
Color
col1
=
new
Color
(
rgb1
);
Color
col2
=
new
Color
(
rgb2
);
return
compareComponent
(
col1
.
getRed
(),
col2
.
getRed
())
&&
compareComponent
(
col1
.
getBlue
(),
col2
.
getBlue
())
&&
compareComponent
(
col1
.
getGreen
(),
col2
.
getGreen
())
&&
compareComponent
(
col1
.
getAlpha
(),
col2
.
getAlpha
());
}
private
boolean
compareImages
(
BufferedImage
img
,
BufferedImage
ref
,
String
imgName
)
{
for
(
int
y
=
0
;
y
<
ref
.
getHeight
();
y
++)
{
for
(
int
x
=
0
;
x
<
ref
.
getWidth
();
x
++)
{
if
(!
compareRGB
(
ref
.
getRGB
(
x
,
y
),
img
.
getRGB
(
x
,
y
)))
{
System
.
out
.
println
(
imgName
+
".getRGB("
+
x
+
", "
+
y
+
") = "
+
new
Color
(
img
.
getRGB
(
x
,
y
))
+
" != "
+
new
Color
(
ref
.
getRGB
(
x
,
y
)));
return
false
;
}
}
}
return
true
;
}
private
boolean
test
(
Object
hint
)
{
BufferedImage
refImage
=
createReferenceImage
(
hint
);
BufferedImage
resImage
=
renderImage
(
hint
);
boolean
passed
=
compareImages
(
resImage
,
refImage
,
"resImage"
);
System
.
out
.
println
(
getHintName
(
hint
)
+
(
passed
?
" passed."
:
" failed."
));
if
(!
passed
)
{
dumpImage
(
refImage
,
"out_"
+
getHintName
(
hint
)
+
"_ref.png"
);
dumpImage
(
resImage
,
"out_"
+
getHintName
(
hint
)
+
".png"
);
}
return
passed
;
}
public
void
test
()
{
boolean
passed
=
true
;
passed
&=
test
(
RenderingHints
.
VALUE_INTERPOLATION_NEAREST_NEIGHBOR
);
passed
&=
test
(
RenderingHints
.
VALUE_INTERPOLATION_BILINEAR
);
passed
&=
test
(
RenderingHints
.
VALUE_INTERPOLATION_BICUBIC
);
if
(
passed
)
{
System
.
out
.
println
(
"Test PASSED."
);
}
else
{
throw
new
RuntimeException
(
"Test FAILED."
);
}
}
private
String
getHintName
(
Object
hint
)
{
if
(
hint
==
RenderingHints
.
VALUE_INTERPOLATION_NEAREST_NEIGHBOR
)
{
return
"nearest"
;
}
else
if
(
hint
==
RenderingHints
.
VALUE_INTERPOLATION_BILINEAR
)
{
return
"bilinear"
;
}
else
if
(
hint
==
RenderingHints
.
VALUE_INTERPOLATION_BICUBIC
)
{
return
"bicubic"
;
}
else
{
return
"null"
;
}
}
private
void
dumpImage
(
BufferedImage
bi
,
String
name
)
{
try
{
ImageIO
.
write
(
bi
,
"PNG"
,
new
File
(
name
));
}
catch
(
IOException
ex
)
{
}
}
public
static
void
main
(
String
[]
argv
)
{
InterpolationQualityTest
test
=
new
InterpolationQualityTest
();
test
.
test
();
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录