Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
c81cfa0d
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看板
提交
c81cfa0d
编写于
2月 08, 2011
作者:
P
prr
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
7006865: Regression: Corrupted output when printing images with bit depth of 4
Reviewed-by: bae, jgodinez
上级
4883457f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
299 addition
and
4 deletion
+299
-4
src/windows/classes/sun/awt/windows/WPathGraphics.java
src/windows/classes/sun/awt/windows/WPathGraphics.java
+24
-2
src/windows/classes/sun/awt/windows/WPrinterJob.java
src/windows/classes/sun/awt/windows/WPrinterJob.java
+3
-2
test/java/awt/print/PrinterJob/ImagePrinting/ImageTypes.java
test/java/awt/print/PrinterJob/ImagePrinting/ImageTypes.java
+272
-0
未找到文件。
src/windows/classes/sun/awt/windows/WPathGraphics.java
浏览文件 @
c81cfa0d
...
@@ -51,9 +51,12 @@ import java.awt.image.ColorModel;
...
@@ -51,9 +51,12 @@ import java.awt.image.ColorModel;
import
java.awt.image.DataBuffer
;
import
java.awt.image.DataBuffer
;
import
java.awt.image.IndexColorModel
;
import
java.awt.image.IndexColorModel
;
import
java.awt.image.WritableRaster
;
import
java.awt.image.WritableRaster
;
import
java.awt.image.ComponentSampleModel
;
import
java.awt.image.MultiPixelPackedSampleModel
;
import
java.awt.image.SampleModel
;
import
sun.awt.image.ByteComponentRaster
;
import
sun.awt.image.ByteComponentRaster
;
import
sun.awt.image.BytePackedRaster
;
import
sun.awt.image.BytePackedRaster
;
import
java.awt.print.PageFormat
;
import
java.awt.print.PageFormat
;
import
java.awt.print.Printable
;
import
java.awt.print.Printable
;
import
java.awt.print.PrinterException
;
import
java.awt.print.PrinterException
;
...
@@ -1272,6 +1275,25 @@ class WPathGraphics extends PathGraphics {
...
@@ -1272,6 +1275,25 @@ class WPathGraphics extends PathGraphics {
return
false
;
return
false
;
}
}
int
bitsPerPixel
=
24
;
SampleModel
sm
=
deepImage
.
getSampleModel
();
if
(
sm
instanceof
ComponentSampleModel
)
{
ComponentSampleModel
csm
=
(
ComponentSampleModel
)
sm
;
bitsPerPixel
=
csm
.
getPixelStride
()
*
8
;
}
else
if
(
sm
instanceof
MultiPixelPackedSampleModel
)
{
MultiPixelPackedSampleModel
mppsm
=
(
MultiPixelPackedSampleModel
)
sm
;
bitsPerPixel
=
mppsm
.
getPixelBitStride
();
}
else
{
if
(
icm
!=
null
)
{
int
diw
=
deepImage
.
getWidth
();
int
dih
=
deepImage
.
getHeight
();
if
(
diw
>
0
&&
dih
>
0
)
{
bitsPerPixel
=
data
.
length
*
8
/
diw
/
dih
;
}
}
}
/* Because the caller's image has been rotated
/* Because the caller's image has been rotated
* and sheared into our BufferedImage and because
* and sheared into our BufferedImage and because
* we will be handing that BufferedImage directly to
* we will be handing that BufferedImage directly to
...
@@ -1289,7 +1311,7 @@ class WPathGraphics extends PathGraphics {
...
@@ -1289,7 +1311,7 @@ class WPathGraphics extends PathGraphics {
(
float
)
Math
.
rint
(
scaledBounds
.
height
+
0.5
),
(
float
)
Math
.
rint
(
scaledBounds
.
height
+
0.5
),
0
f
,
0
f
,
0
f
,
0
f
,
deepImage
.
getWidth
(),
deepImage
.
getHeight
(),
deepImage
.
getWidth
(),
deepImage
.
getHeight
(),
icm
);
bitsPerPixel
,
icm
);
setClip
(
holdClip
);
setClip
(
holdClip
);
}
}
...
...
src/windows/classes/sun/awt/windows/WPrinterJob.java
浏览文件 @
c81cfa0d
...
@@ -1212,13 +1212,14 @@ public class WPrinterJob extends RasterPrinterJob implements DisposerTarget {
...
@@ -1212,13 +1212,14 @@ public class WPrinterJob extends RasterPrinterJob implements DisposerTarget {
float
destWidth
,
float
destHeight
,
float
destWidth
,
float
destHeight
,
float
srcX
,
float
srcY
,
float
srcX
,
float
srcY
,
float
srcWidth
,
float
srcHeight
,
float
srcWidth
,
float
srcHeight
,
int
sampleBitsPerPixel
,
IndexColorModel
icm
)
{
IndexColorModel
icm
)
{
int
bitCount
=
24
;
int
bitCount
=
24
;
byte
[]
bmiColors
=
null
;
byte
[]
bmiColors
=
null
;
if
(
icm
!=
null
)
{
if
(
icm
!=
null
)
{
bitCount
=
icm
.
getPixelSize
()
;
bitCount
=
sampleBitsPerPixel
;
bmiColors
=
new
byte
[(
1
<<
bitCount
)*
4
];
bmiColors
=
new
byte
[(
1
<<
icm
.
getPixelSize
()
)*
4
];
for
(
int
i
=
0
;
i
<
icm
.
getMapSize
();
i
++)
{
for
(
int
i
=
0
;
i
<
icm
.
getMapSize
();
i
++)
{
bmiColors
[
i
*
4
+
0
]=(
byte
)(
icm
.
getBlue
(
i
)&
0xff
);
bmiColors
[
i
*
4
+
0
]=(
byte
)(
icm
.
getBlue
(
i
)&
0xff
);
bmiColors
[
i
*
4
+
1
]=(
byte
)(
icm
.
getGreen
(
i
)&
0xff
);
bmiColors
[
i
*
4
+
1
]=(
byte
)(
icm
.
getGreen
(
i
)&
0xff
);
...
...
test/java/awt/print/PrinterJob/ImagePrinting/ImageTypes.java
0 → 100644
浏览文件 @
c81cfa0d
/*
* Copyright (c) 2006, 2011, 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 4521945 7006865
* @summary Test printing images of different types.
* @author prr
* @run main/manual=yesno/timeout=900 ImageTypes
*/
import
java.io.*
;
import
static
java
.
awt
.
Color
.*;
import
java.awt.*
;
import
java.awt.geom.*
;
import
java.awt.event.*
;
import
java.awt.print.*
;
import
java.awt.image.*
;
import
static
java
.
awt
.
image
.
BufferedImage
.*;
import
javax.print.*
;
import
javax.print.attribute.*
;
import
javax.print.attribute.standard.*
;
public
class
ImageTypes
extends
Frame
implements
ActionListener
{
private
ImageCanvas
c
;
public
static
void
main
(
String
args
[])
{
ImageTypes
f
=
new
ImageTypes
();
f
.
show
();
}
public
ImageTypes
()
{
super
(
"Image Types Printing Test"
);
c
=
new
ImageCanvas
();
add
(
"Center"
,
c
);
Button
printThisButton
=
new
Button
(
"Print"
);
printThisButton
.
addActionListener
(
this
);
Panel
p
=
new
Panel
();
p
.
add
(
printThisButton
);
add
(
"South"
,
p
);
add
(
"North"
,
getInstructions
());
addWindowListener
(
new
WindowAdapter
()
{
public
void
windowClosing
(
WindowEvent
e
)
{
System
.
exit
(
0
);
}
});
pack
();
}
private
TextArea
getInstructions
()
{
TextArea
ta
=
new
TextArea
(
10
,
60
);
ta
.
setFont
(
new
Font
(
"Dialog"
,
Font
.
PLAIN
,
11
));
ta
.
setText
(
"This is a manual test as it requires that you compare "
+
"the on-screen rendering with the printed output.\n"
+
"Select the 'Print' button to print out the test.\n"
+
"For each image compare the printed one to the on-screen one.\n"
+
"The test PASSES if the onscreen and printed rendering match."
);
return
ta
;
}
public
void
actionPerformed
(
ActionEvent
e
)
{
PrinterJob
pj
=
PrinterJob
.
getPrinterJob
();
PrintRequestAttributeSet
attrs
=
new
HashPrintRequestAttributeSet
();
if
(
pj
!=
null
&&
pj
.
printDialog
(
attrs
))
{
pj
.
setPrintable
(
c
);
try
{
pj
.
print
(
attrs
);
}
catch
(
PrinterException
pe
)
{
pe
.
printStackTrace
();
throw
new
RuntimeException
(
"Exception whilst printing."
);
}
finally
{
System
.
out
.
println
(
"PRINT RETURNED OK."
);
}
}
}
}
class
ImageCanvas
extends
Component
implements
Printable
{
IndexColorModel
icm2
=
null
;
IndexColorModel
icm4
=
null
;
BufferedImage
opaqueImg
=
null
;
BufferedImage
transImg
=
null
;
int
sw
=
99
,
sh
=
99
;
void
paintImage
(
BufferedImage
bi
,
Color
c1
,
Color
c2
)
{
GradientPaint
tp
=
new
GradientPaint
(
0.0f
,
0.0f
,
c1
,
10
f
,
8
f
,
c2
,
true
);
Graphics2D
g2d
=
(
Graphics2D
)
bi
.
getGraphics
();
g2d
.
setPaint
(
tp
);
g2d
.
fillRect
(
0
,
0
,
sw
,
sh
);
g2d
.
setColor
(
gray
);
int
cnt
=
0
;
Font
font
=
new
Font
(
"Serif"
,
Font
.
PLAIN
,
11
);
g2d
.
setFont
(
font
);
FontMetrics
fm
=
g2d
.
getFontMetrics
();
for
(
int
y
=
12
;
y
<
sh
;
y
+=
12
)
{
int
x
=
0
;
while
(
x
<
sw
)
{
String
s
=
(
new
Integer
(++
cnt
)).
toString
();
g2d
.
drawString
(
s
,
x
,
y
);
x
+=
fm
.
stringWidth
(
s
);
}
}
}
ImageCanvas
()
{
opaqueImg
=
new
BufferedImage
(
sw
,
sh
,
TYPE_INT_RGB
);
Color
o1
=
new
Color
(
0
,
0
,
0
);
Color
o2
=
new
Color
(
255
,
255
,
255
);
paintImage
(
opaqueImg
,
o1
,
o2
);
transImg
=
new
BufferedImage
(
sw
,
sh
,
TYPE_INT_ARGB
);
Color
t1
=
new
Color
(
255
,
255
,
255
,
220
);
Color
t2
=
new
Color
(
255
,
200
,
0
,
220
);
paintImage
(
transImg
,
t1
,
t2
);
/* greyscale 2bpp */
byte
[]
arr2bpp
=
{(
byte
)
0
,
(
byte
)
0x55
,
(
byte
)
0xaa
,
(
byte
)
0xff
};
icm2
=
new
IndexColorModel
(
2
,
4
,
arr2bpp
,
arr2bpp
,
arr2bpp
);
/* color 4bpp */
int
[]
cmap
=
new
int
[
16
];
cmap
[
0
]
=
black
.
getRGB
();
cmap
[
1
]
=
white
.
getRGB
();
cmap
[
2
]
=
gray
.
getRGB
();
cmap
[
3
]
=
lightGray
.
getRGB
();
cmap
[
4
]
=
red
.
getRGB
();
cmap
[
5
]
=
green
.
getRGB
();
cmap
[
6
]
=
blue
.
getRGB
();
cmap
[
7
]
=
yellow
.
getRGB
();
cmap
[
8
]
=
cyan
.
getRGB
();
cmap
[
9
]
=
magenta
.
getRGB
();
cmap
[
10
]
=
orange
.
getRGB
();
cmap
[
11
]
=
pink
.
getRGB
();
cmap
[
12
]
=
darkGray
.
getRGB
();
cmap
[
13
]
=
192
<<
16
;
// dark red.
cmap
[
14
]
=
192
<<
8
;
// dark green
cmap
[
15
]
=
192
;
// dark blue
icm4
=
new
IndexColorModel
(
4
,
16
,
cmap
,
0
,
false
,
-
1
,
DataBuffer
.
TYPE_BYTE
);
}
public
int
print
(
Graphics
g
,
PageFormat
pgFmt
,
int
pgIndex
)
{
if
(
pgIndex
>
0
)
{
return
Printable
.
NO_SUCH_PAGE
;
}
Graphics2D
g2d
=
(
Graphics2D
)
g
;
g2d
.
translate
(
pgFmt
.
getImageableX
(),
pgFmt
.
getImageableY
());
paint
(
g2d
);
return
Printable
.
PAGE_EXISTS
;
}
private
void
drawImage
(
Graphics
g
,
int
biType
,
IndexColorModel
icm
)
{
BufferedImage
bi
;
if
(
icm
!=
null
)
{
bi
=
new
BufferedImage
(
sw
,
sh
,
biType
,
icm
);
}
else
{
bi
=
new
BufferedImage
(
sw
,
sh
,
biType
);
}
Graphics
big
=
bi
.
getGraphics
();
if
(
bi
.
getColorModel
().
getPixelSize
()
<=
2
)
{
big
.
drawImage
(
opaqueImg
,
0
,
0
,
null
);
}
else
{
big
.
drawImage
(
transImg
,
0
,
0
,
null
);
}
g
.
drawImage
(
bi
,
0
,
0
,
null
);
}
public
void
paint
(
Graphics
g
)
{
int
incX
=
sw
+
10
,
incY
=
sh
+
10
;
g
.
translate
(
10
,
10
);
drawImage
(
g
,
TYPE_INT_RGB
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_INT_BGR
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_INT_ARGB
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_INT_ARGB_PRE
,
null
);
g
.
translate
(-
3
*
incX
,
incY
);
drawImage
(
g
,
TYPE_3BYTE_BGR
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_4BYTE_ABGR
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_4BYTE_ABGR_PRE
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_USHORT_555_RGB
,
null
);
g
.
translate
(-
3
*
incX
,
incY
);
drawImage
(
g
,
TYPE_USHORT_555_RGB
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_USHORT_GRAY
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_BYTE_GRAY
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_BYTE_INDEXED
,
null
);
g
.
translate
(-
3
*
incX
,
incY
);
drawImage
(
g
,
TYPE_BYTE_BINARY
,
null
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_BYTE_BINARY
,
icm2
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_BYTE_BINARY
,
icm4
);
g
.
translate
(
incX
,
0
);
drawImage
(
g
,
TYPE_BYTE_INDEXED
,
icm2
);
g
.
translate
(-
3
*
incX
,
incY
);
drawImage
(
g
,
TYPE_BYTE_INDEXED
,
icm4
);
g
.
translate
(
incX
,
0
);
}
/* Size is chosen to match default imageable width of a NA letter
* page. This means there will be clipping, what is clipped will
* depend on PageFormat orientation.
*/
public
Dimension
getPreferredSize
()
{
return
new
Dimension
(
468
,
600
);
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录