Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
dragonwell8_jdk
提交
e782f663
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看板
提交
e782f663
编写于
11月 27, 2013
作者:
L
lana
浏览文件
操作
浏览文件
下载
差异文件
Merge
上级
b8975b25
b7fa5552
变更
25
隐藏空白更改
内联
并排
Showing
25 changed file
with
294 addition
and
96 deletion
+294
-96
src/share/classes/java/awt/Font.java
src/share/classes/java/awt/Font.java
+2
-2
src/share/classes/java/awt/Graphics2D.java
src/share/classes/java/awt/Graphics2D.java
+3
-3
src/share/classes/java/awt/GraphicsConfiguration.java
src/share/classes/java/awt/GraphicsConfiguration.java
+2
-2
src/share/classes/java/awt/GraphicsDevice.java
src/share/classes/java/awt/GraphicsDevice.java
+2
-2
src/share/classes/java/awt/Image.java
src/share/classes/java/awt/Image.java
+1
-1
src/share/classes/java/awt/MediaTracker.java
src/share/classes/java/awt/MediaTracker.java
+2
-2
src/share/classes/java/awt/PageAttributes.java
src/share/classes/java/awt/PageAttributes.java
+13
-13
src/share/classes/java/awt/Rectangle.java
src/share/classes/java/awt/Rectangle.java
+4
-4
src/share/classes/java/awt/RenderingHints.java
src/share/classes/java/awt/RenderingHints.java
+34
-34
src/share/classes/java/awt/font/NumericShaper.java
src/share/classes/java/awt/font/NumericShaper.java
+1
-1
src/share/classes/java/awt/font/TextAttribute.java
src/share/classes/java/awt/font/TextAttribute.java
+4
-6
src/share/classes/java/awt/geom/FlatteningPathIterator.java
src/share/classes/java/awt/geom/FlatteningPathIterator.java
+3
-3
src/share/classes/java/awt/geom/Path2D.java
src/share/classes/java/awt/geom/Path2D.java
+2
-2
src/share/classes/java/awt/image/MultiPixelPackedSampleModel.java
...e/classes/java/awt/image/MultiPixelPackedSampleModel.java
+1
-1
src/share/classes/java/awt/print/Book.java
src/share/classes/java/awt/print/Book.java
+2
-2
src/share/classes/java/awt/print/PageFormat.java
src/share/classes/java/awt/print/PageFormat.java
+1
-1
src/share/classes/java/awt/print/Printable.java
src/share/classes/java/awt/print/Printable.java
+1
-1
src/share/classes/java/awt/print/PrinterJob.java
src/share/classes/java/awt/print/PrinterJob.java
+2
-2
src/solaris/classes/sun/font/XRTextRenderer.java
src/solaris/classes/sun/font/XRTextRenderer.java
+14
-9
src/solaris/classes/sun/java2d/xr/XRSurfaceData.java
src/solaris/classes/sun/java2d/xr/XRSurfaceData.java
+11
-1
src/solaris/classes/sun/print/IPPPrintService.java
src/solaris/classes/sun/print/IPPPrintService.java
+5
-2
src/solaris/classes/sun/print/UnixPrintServiceLookup.java
src/solaris/classes/sun/print/UnixPrintServiceLookup.java
+1
-1
test/java/awt/Graphics2D/DrawString/TextRenderingTest.java
test/java/awt/Graphics2D/DrawString/TextRenderingTest.java
+110
-0
test/java/awt/Graphics2D/DrawString/XRenderElt254TextTest.java
...java/awt/Graphics2D/DrawString/XRenderElt254TextTest.java
+72
-0
test/java/awt/print/PageFormat/PageFormatFromAttributes.java
test/java/awt/print/PageFormat/PageFormatFromAttributes.java
+1
-1
未找到文件。
src/share/classes/java/awt/Font.java
浏览文件 @
e782f663
...
...
@@ -71,7 +71,7 @@ import static sun.font.EAttribute.*;
* and to render sequences of glyphs on <code>Graphics</code> and
* <code>Component</code> objects.
*
* <h
4>Characters and Glyphs</h4
>
* <h
3>Characters and Glyphs</h3
>
*
* A <em>character</em> is a symbol that represents an item such as a letter,
* a digit, or punctuation in an abstract way. For example, <code>'g'</code>,
...
...
@@ -192,7 +192,7 @@ import static sun.font.EAttribute.*;
* not serializable. See {@link java.awt.im.InputMethodHighlight}.</li>
* </ul>
*
* Clients who create custom subclasses of <code>Paint</code> and
*
<p>
Clients who create custom subclasses of <code>Paint</code> and
* <code>GraphicAttribute</code> can make them serializable and
* avoid this problem. Clients who use input method highlights can
* convert these to the platform-specific attributes for that
...
...
src/share/classes/java/awt/Graphics2D.java
浏览文件 @
e782f663
...
...
@@ -78,7 +78,7 @@ import java.util.Map;
* <p>
* When creating a <code>Graphics2D</code> object, the
* <code>GraphicsConfiguration</code>
* specifies the <a name="
#
deftransform">default transform</a> for
* specifies the <a name="deftransform">default transform</a> for
* the target of the <code>Graphics2D</code> (a
* {@link Component} or {@link Image}). This default transform maps the
* user space coordinate system to screen and printer device coordinates
...
...
@@ -1103,7 +1103,7 @@ public abstract class Graphics2D extends Graphics {
* method is intended only for restoring the original
* <code>Graphics2D</code> transform after rendering, as shown in this
* example:
* <pre>
<blockquote>
* <pre>
* // Get the current transform
* AffineTransform saveAT = g2.getTransform();
* // Perform transformation
...
...
@@ -1112,7 +1112,7 @@ public abstract class Graphics2D extends Graphics {
* g2d.draw(...);
* // Restore original transform
* g2d.setTransform(saveAT);
* </
blockquote></
pre>
* </pre>
*
* @param Tx the <code>AffineTransform</code> that was retrieved
* from the <code>getTransform</code> method
...
...
src/share/classes/java/awt/GraphicsConfiguration.java
浏览文件 @
e782f663
...
...
@@ -75,7 +75,7 @@ import sun.awt.image.SunVolatileImage;
* bounds of the virtual device. The following code sample
* calculates the bounds of the virtual device.
*
* <pre>
* <pre>
{@code
* Rectangle virtualBounds = new Rectangle();
* GraphicsEnvironment ge = GraphicsEnvironment.
* getLocalGraphicsEnvironment();
...
...
@@ -89,7 +89,7 @@ import sun.awt.image.SunVolatileImage;
* virtualBounds =
* virtualBounds.union(gc[i].getBounds());
* }
* } </pre>
* }
}
</pre>
*
* @see Window
* @see Frame
...
...
src/share/classes/java/awt/GraphicsDevice.java
浏览文件 @
e782f663
...
...
@@ -46,7 +46,7 @@ import sun.awt.SunToolkit;
* following code sample demonstrates how to create a <code>JFrame</code>
* object for each <code>GraphicsConfiguration</code> on each screen
* device in the <code>GraphicsEnvironment</code>:
* <pre>
* <pre>
{@code
* GraphicsEnvironment ge = GraphicsEnvironment.
* getLocalGraphicsEnvironment();
* GraphicsDevice[] gs = ge.getScreenDevices();
...
...
@@ -66,7 +66,7 @@ import sun.awt.SunToolkit;
* f.show();
* }
* }
* </pre>
*
}
</pre>
* <p>
* For more information on full-screen exclusive mode API, see the
* <a href="http://docs.oracle.com/javase/tutorial/extra/fullscreen/index.html">
...
...
src/share/classes/java/awt/Image.java
浏览文件 @
e782f663
...
...
@@ -124,7 +124,7 @@ public abstract class Image {
* @param name a property name.
* @param observer an object waiting for this image to be loaded.
* @return the value of the named property.
* @throws
<code>NullPointerException</code>
if the property name is null.
* @throws
NullPointerException
if the property name is null.
* @see java.awt.image.ImageObserver
* @see java.awt.Image#UndefinedProperty
*/
...
...
src/share/classes/java/awt/MediaTracker.java
浏览文件 @
e782f663
...
...
@@ -66,7 +66,7 @@ import java.awt.image.ImageObserver;
* <p>
* Here is an example of using <code>MediaTracker</code>:
* <p>
* <hr><blockquote><pre>
* <hr><blockquote><pre>
{@code
* import java.applet.Applet;
* import java.awt.Color;
* import java.awt.Image;
...
...
@@ -160,7 +160,7 @@ import java.awt.image.ImageObserver;
* }
* }
* }
* </pre></blockquote><hr>
*
}
</pre></blockquote><hr>
*
* @author Jim Graham
* @since JDK1.0
...
...
src/share/classes/java/awt/PageAttributes.java
浏览文件 @
e782f663
...
...
@@ -187,55 +187,55 @@ public final class PageAttributes implements Cloneable {
};
/**
* The MediaType instance for ISO/DIN
&
JIS 4A0, 1682 x 2378 mm.
* The MediaType instance for ISO/DIN
and
JIS 4A0, 1682 x 2378 mm.
*/
public
static
final
MediaType
ISO_4A0
=
new
MediaType
(
I_ISO_4A0
);
/**
* The MediaType instance for ISO/DIN
&
JIS 2A0, 1189 x 1682 mm.
* The MediaType instance for ISO/DIN
and
JIS 2A0, 1189 x 1682 mm.
*/
public
static
final
MediaType
ISO_2A0
=
new
MediaType
(
I_ISO_2A0
);
/**
* The MediaType instance for ISO/DIN
&
JIS A0, 841 x 1189 mm.
* The MediaType instance for ISO/DIN
and
JIS A0, 841 x 1189 mm.
*/
public
static
final
MediaType
ISO_A0
=
new
MediaType
(
I_ISO_A0
);
/**
* The MediaType instance for ISO/DIN
&
JIS A1, 594 x 841 mm.
* The MediaType instance for ISO/DIN
and
JIS A1, 594 x 841 mm.
*/
public
static
final
MediaType
ISO_A1
=
new
MediaType
(
I_ISO_A1
);
/**
* The MediaType instance for ISO/DIN
&
JIS A2, 420 x 594 mm.
* The MediaType instance for ISO/DIN
and
JIS A2, 420 x 594 mm.
*/
public
static
final
MediaType
ISO_A2
=
new
MediaType
(
I_ISO_A2
);
/**
* The MediaType instance for ISO/DIN
&
JIS A3, 297 x 420 mm.
* The MediaType instance for ISO/DIN
and
JIS A3, 297 x 420 mm.
*/
public
static
final
MediaType
ISO_A3
=
new
MediaType
(
I_ISO_A3
);
/**
* The MediaType instance for ISO/DIN
&
JIS A4, 210 x 297 mm.
* The MediaType instance for ISO/DIN
and
JIS A4, 210 x 297 mm.
*/
public
static
final
MediaType
ISO_A4
=
new
MediaType
(
I_ISO_A4
);
/**
* The MediaType instance for ISO/DIN
&
JIS A5, 148 x 210 mm.
* The MediaType instance for ISO/DIN
and
JIS A5, 148 x 210 mm.
*/
public
static
final
MediaType
ISO_A5
=
new
MediaType
(
I_ISO_A5
);
/**
* The MediaType instance for ISO/DIN
&
JIS A6, 105 x 148 mm.
* The MediaType instance for ISO/DIN
and
JIS A6, 105 x 148 mm.
*/
public
static
final
MediaType
ISO_A6
=
new
MediaType
(
I_ISO_A6
);
/**
* The MediaType instance for ISO/DIN
&
JIS A7, 74 x 105 mm.
* The MediaType instance for ISO/DIN
and
JIS A7, 74 x 105 mm.
*/
public
static
final
MediaType
ISO_A7
=
new
MediaType
(
I_ISO_A7
);
/**
* The MediaType instance for ISO/DIN
&
JIS A8, 52 x 74 mm.
* The MediaType instance for ISO/DIN
and
JIS A8, 52 x 74 mm.
*/
public
static
final
MediaType
ISO_A8
=
new
MediaType
(
I_ISO_A8
);
/**
* The MediaType instance for ISO/DIN
&
JIS A9, 37 x 52 mm.
* The MediaType instance for ISO/DIN
and
JIS A9, 37 x 52 mm.
*/
public
static
final
MediaType
ISO_A9
=
new
MediaType
(
I_ISO_A9
);
/**
* The MediaType instance for ISO/DIN
&
JIS A10, 26 x 37 mm.
* The MediaType instance for ISO/DIN
and
JIS A10, 26 x 37 mm.
*/
public
static
final
MediaType
ISO_A10
=
new
MediaType
(
I_ISO_A10
);
/**
...
...
src/share/classes/java/awt/Rectangle.java
浏览文件 @
e782f663
...
...
@@ -76,19 +76,19 @@ import java.beans.Transient;
* negative width and height or it should use the first point in the set
* to construct the {@code Rectangle}.
* For example:
* <pre>
* <pre>
{@code
* Rectangle bounds = new Rectangle(0, 0, -1, -1);
* for (int i = 0; i < points.length; i++) {
* bounds.add(points[i]);
* }
* </pre>
*
}
</pre>
* or if we know that the points array contains at least one point:
* <pre>
* <pre>
{@code
* Rectangle bounds = new Rectangle(points[0]);
* for (int i = 1; i < points.length; i++) {
* bounds.add(points[i]);
* }
* </pre>
*
}
</pre>
* <p>
* This class uses 32-bit integers to store its location and dimensions.
* Frequently operations may produce a result that exceeds the range of
...
...
src/share/classes/java/awt/RenderingHints.java
浏览文件 @
e782f663
...
...
@@ -999,15 +999,15 @@ public class RenderingHints
}
/**
* Returns
<code>true</code> if this <code>RenderingHints</code>
* Returns
{@code true} if this {@code RenderingHints}
* contains a mapping for the specified key.
*
* @param key key whose presence in this
*
<code>RenderingHints</code>
is to be tested.
* @return
<code>true</code> if this <code>RenderingHints</code>
*
{@code RenderingHints}
is to be tested.
* @return
{@code true} if this {@code RenderingHints}
* contains a mapping for the specified key.
* @exception
<code>ClassCastException</code>
if the key can not
* be cast to
<code>RenderingHints.Key</code>
* @exception
ClassCastException
if the key can not
* be cast to
{@code RenderingHints.Key}
*/
public
boolean
containsKey
(
Object
key
)
{
return
hintmap
.
containsKey
((
Key
)
key
);
...
...
@@ -1039,10 +1039,10 @@ public class RenderingHints
* Returns the value to which the specified key is mapped.
* @param key a rendering hint key
* @return the value to which the key is mapped in this object or
*
<code>null</code>
if the key is not mapped to any value in
*
{@code null}
if the key is not mapped to any value in
* this object.
* @exception
<code>ClassCastException</code>
if the key can not
* be cast to
<code>RenderingHints.Key</code>
* @exception
ClassCastException
if the key can not
* be cast to
{@code RenderingHints.Key}
* @see #put(Object, Object)
*/
public
Object
get
(
Object
key
)
{
...
...
@@ -1050,20 +1050,20 @@ public class RenderingHints
}
/**
* Maps the specified
<code>key</code>
to the specified
*
<code>value</code> in this <code>RenderingHints</code>
object.
* Neither the key nor the value can be
<code>null</code>
.
* The value can be retrieved by calling the
<code>get</code>
method
* Maps the specified
{@code key}
to the specified
*
{@code value} in this {@code RenderingHints}
object.
* Neither the key nor the value can be
{@code null}
.
* The value can be retrieved by calling the
{@code get}
method
* with a key that is equal to the original key.
* @param key the rendering hint key.
* @param value the rendering hint value.
* @return the previous value of the specified key in this object
* or
<code>null</code>
if it did not have one.
* @exception
<code>NullPointerException</code>
if the key is
*
<code>null</code>
.
* @exception
<code>ClassCastException</code>
if the key can not
* be cast to
<code>RenderingHints.Key</code>
* @exception
<code>IllegalArgumentException</code>
if the
* or
{@code null}
if it did not have one.
* @exception
NullPointerException
if the key is
*
{@code null}
.
* @exception
ClassCastException
if the key can not
* be cast to
{@code RenderingHints.Key}
* @exception
IllegalArgumentException
if the
* {@link Key#isCompatibleValue(java.lang.Object)
* Key.isCompatibleValue()}
* method of the specified key returns false for the
...
...
@@ -1102,13 +1102,13 @@ public class RenderingHints
/**
* Removes the key and its corresponding value from this
*
<code>RenderingHints</code>
object. This method does nothing if the
* key is not in this
<code>RenderingHints</code>
object.
*
{@code RenderingHints}
object. This method does nothing if the
* key is not in this
{@code RenderingHints}
object.
* @param key the rendering hints key that needs to be removed
* @exception
<code>ClassCastException</code>
if the key can not
* be cast to
<code>RenderingHints.Key</code>
* @exception
ClassCastException
if the key can not
* be cast to
{@code RenderingHints.Key}
* @return the value to which the key had previously been mapped in this
*
<code>RenderingHints</code> object, or <code>null</code>
*
{@code RenderingHints} object, or {@code null}
* if the key did not have a mapping.
*/
public
Object
remove
(
Object
key
)
{
...
...
@@ -1116,18 +1116,18 @@ public class RenderingHints
}
/**
* Copies all of the mappings from the specified
<code>Map</code>
* to this
<code>RenderingHints</code>
. These mappings replace
* any mappings that this
<code>RenderingHints</code>
had for any
* of the keys currently in the specified
<code>Map</code>
.
* @param m the specified
<code>Map</code>
* @exception
<code>ClassCastException</code>
class of a key or value
* in the specified
<code>Map</code>
prevents it from being
* stored in this
<code>RenderingHints</code>
.
* @exception
<code>IllegalArgumentException</code>
some aspect
* of a key or value in the specified
<code>Map</code>
* Copies all of the mappings from the specified
{@code Map}
* to this
{@code RenderingHints}
. These mappings replace
* any mappings that this
{@code RenderingHints}
had for any
* of the keys currently in the specified
{@code Map}
.
* @param m the specified
{@code Map}
* @exception
ClassCastException
class of a key or value
* in the specified
{@code Map}
prevents it from being
* stored in this
{@code RenderingHints}
.
* @exception
IllegalArgumentException
some aspect
* of a key or value in the specified
{@code Map}
* prevents it from being stored in
* this
<code>RenderingHints</code>
.
* this
{@code RenderingHints}
.
*/
public
void
putAll
(
Map
<?,?>
m
)
{
// ## javac bug?
...
...
src/share/classes/java/awt/font/NumericShaper.java
浏览文件 @
e782f663
...
...
@@ -1212,7 +1212,7 @@ public final class NumericShaper implements java.io.Serializable {
* For example, to check if a shaper shapes to Arabic, you would use the
* following:
* <blockquote>
*
<code>if ((shaper.getRanges() & shaper.ARABIC) != 0) { ... </code>
*
{@code if ((shaper.getRanges() & shaper.ARABIC) != 0) { ... }
* </blockquote>
*
* <p>Note that this method supports only the bit mask-based
...
...
src/share/classes/java/awt/font/TextAttribute.java
浏览文件 @
e782f663
...
...
@@ -66,7 +66,7 @@ import java.util.HashMap;
* <LI>a description of the effect.
* </UL>
* <p>
* <H
4>Values</H4
>
* <H
3>Values</H3
>
* <UL>
* <LI>The values of attributes must always be immutable.
* <LI>Where value limitations are given, any value outside of that
...
...
@@ -96,7 +96,6 @@ import java.util.HashMap;
*
* <h4>Summary of attributes</h4>
* <p>
* <font size="-1">
* <table style="float:center" border="0" cellspacing="0" cellpadding="2" width="%95"
* summary="Key, value type, principal constants, and default value
* behavior of all TextAttributes">
...
...
@@ -110,9 +109,9 @@ import java.util.HashMap;
* <td valign="TOP">{@link #FAMILY}</td>
* <td valign="TOP">String</td>
* <td valign="TOP">See Font {@link java.awt.Font#DIALOG DIALOG},
{@link java.awt.Font#DIALOG_INPUT DIALOG_INPUT},<br> {@link java.awt.Font#SERIF SERIF},
{@link java.awt.Font#SANS_SERIF SANS_SERIF}, and {@link java.awt.Font#MONOSPACED MONOSPACED}.
</td>
*
{@link java.awt.Font#DIALOG_INPUT DIALOG_INPUT},<br> {@link java.awt.Font#SERIF SERIF},
*
{@link java.awt.Font#SANS_SERIF SANS_SERIF}, and {@link java.awt.Font#MONOSPACED MONOSPACED}.
*
</td>
* <td valign="TOP">"Default" (use platform default)</td>
* </tr>
* <tr style="background-color:#eeeeff">
...
...
@@ -248,7 +247,6 @@ import java.util.HashMap;
* <td valign="TOP">0 (do not add tracking)</td>
* </tr>
* </table>
* </font>
*
* @see java.awt.Font
* @see java.awt.font.TextLayout
...
...
src/share/classes/java/awt/geom/FlatteningPathIterator.java
浏览文件 @
e782f663
...
...
@@ -109,7 +109,7 @@ public class FlatteningPathIterator implements PathIterator {
* control points and the flattened curve
* @param limit the maximum number of recursive subdivisions
* allowed for any curved segment
* @exception
<code>IllegalArgumentException</code>
if
* @exception
IllegalArgumentException
if
* <code>flatness</code> or <code>limit</code>
* is less than zero
*/
...
...
@@ -336,7 +336,7 @@ public class FlatteningPathIterator implements PathIterator {
* @param coords an array that holds the data returned from
* this method
* @return the path segment type of the current path segment.
* @exception
<code>NoSuchElementException</code>
if there
* @exception
NoSuchElementException
if there
* are no more elements in the flattening path to be
* returned.
* @see PathIterator#SEG_MOVETO
...
...
@@ -371,7 +371,7 @@ public class FlatteningPathIterator implements PathIterator {
* @param coords an array that holds the data returned from
* this method
* @return the path segment type of the current path segment.
* @exception
<code>NoSuchElementException</code>
if there
* @exception
NoSuchElementException
if there
* are no more elements in the flattening path to be
* returned.
* @see PathIterator#SEG_MOVETO
...
...
src/share/classes/java/awt/geom/Path2D.java
浏览文件 @
e782f663
...
...
@@ -794,7 +794,7 @@ public abstract class Path2D implements Shape, Cloneable {
* ({@link #WIND_EVEN_ODD WIND_EVEN_ODD} or
* {@link #WIND_NON_ZERO WIND_NON_ZERO})
* <li>followed by
*
NP (or unlimited if NP < 0
) sets of values consisting of
*
{@code NP} (or unlimited if {@code NP < 0}
) sets of values consisting of
* a single byte indicating a path segment type
* followed by one or more pairs of float or double
* values representing the coordinates of the path segment
...
...
@@ -1520,7 +1520,7 @@ public abstract class Path2D implements Shape, Cloneable {
* ({@link #WIND_EVEN_ODD WIND_EVEN_ODD} or
* {@link #WIND_NON_ZERO WIND_NON_ZERO})
* <li>followed by
*
NP (or unlimited if NP < 0
) sets of values consisting of
*
{@code NP} (or unlimited if {@code NP < 0}
) sets of values consisting of
* a single byte indicating a path segment type
* followed by one or more pairs of float or double
* values representing the coordinates of the path segment
...
...
src/share/classes/java/awt/image/MultiPixelPackedSampleModel.java
浏览文件 @
e782f663
...
...
@@ -348,7 +348,7 @@ public class MultiPixelPackedSampleModel extends SampleModel
* data
* @return the specified band containing the sample of the specified
* pixel.
* @exception ArrayIndexOutOfBoundException if the specified
* @exception ArrayIndexOutOfBound
s
Exception if the specified
* coordinates are not in bounds.
* @see #setSample(int, int, int, int, DataBuffer)
*/
...
...
src/share/classes/java/awt/print/Book.java
浏览文件 @
e782f663
...
...
@@ -129,7 +129,7 @@ public class Book implements Pageable {
* @param painter the <code>Printable</code> instance that
* renders the page
* @param page the size and orientation of the page
* @throws
<code>NullPointerException</code>
* @throws
NullPointerException
* If the <code>painter</code> or <code>page</code>
* argument is <code>null</code>
*/
...
...
@@ -146,7 +146,7 @@ public class Book implements Pageable {
* @param page the size and orientation of the page
* @param numPages the number of pages to be added to the
* this <code>Book</code>.
* @throws
<code>NullPointerException</code>
* @throws
NullPointerException
* If the <code>painter</code> or <code>page</code>
* argument is <code>null</code>
*/
...
...
src/share/classes/java/awt/print/PageFormat.java
浏览文件 @
e782f663
...
...
@@ -286,7 +286,7 @@ public class PageFormat implements Cloneable
* <code>PageFormat</code>.
* @param paper the <code>Paper</code> object to which to set
* the <code>Paper</code> object for this <code>PageFormat</code>.
* @exception
<code>NullPointerException</code>
* @exception
NullPointerException
* a null paper instance was passed as a parameter.
* @see #getPaper
*/
...
...
src/share/classes/java/awt/print/Printable.java
浏览文件 @
e782f663
...
...
@@ -76,7 +76,7 @@ import java.awt.Graphics;
* <li>With the exception of re-imaging an entire document for multiple
* collated copies, the increasing page index order means that when
* page N is requested if a client needs to calculate page break position,
* it may safely discard any state related to pages
<
N, and make current
* it may safely discard any state related to pages
<
N, and make current
* that for page N. "State" usually is just the calculated position in the
* document that corresponds to the start of the page.
*
...
...
src/share/classes/java/awt/print/PrinterJob.java
浏览文件 @
e782f663
...
...
@@ -113,7 +113,7 @@ public abstract class PrinterJob {
* A convenience method which locates factories for stream print
* services which can image 2D graphics.
* Sample usage :
* <pre>
* <pre>
{@code
* FileOutputStream outstream;
* StreamPrintService psPrinter;
* String psMimeType = "application/postscript";
...
...
@@ -131,7 +131,7 @@ public abstract class PrinterJob {
* e.printStackTrace();
* }
* }
* </pre>
*
}
</pre>
* Services returned from this method may be installed on
* <code>PrinterJob</code> instances which support print services.
* Calling this method is equivalent to calling
...
...
src/solaris/classes/sun/font/XRTextRenderer.java
浏览文件 @
e782f663
...
...
@@ -36,6 +36,10 @@ import sun.java2d.xr.*;
* @author Clemens Eisserer
*/
public
class
XRTextRenderer
extends
GlyphListPipe
{
// Workarround for a bug in libXrender.
// In case the number of glyphs of an ELT is a multiple of 254,
// a few garbage bytes are sent to the XServer causing hangs.
static
final
int
MAX_ELT_GLYPH_COUNT
=
253
;
XRGlyphCache
glyphCache
;
XRCompositeManager
maskBuffer
;
...
...
@@ -92,8 +96,11 @@ public class XRTextRenderer extends GlyphListPipe {
int
posX
=
0
,
posY
=
0
;
if
(
gl
.
usePositions
()
||
(
cacheEntry
.
getXAdvance
()
!=
((
float
)
cacheEntry
.
getXOff
())
||
cacheEntry
.
getYAdvance
()
!=
((
float
)
cacheEntry
.
getYOff
()))
||
eltIndex
<
0
||
glyphSet
!=
activeGlyphSet
)
{
||
cacheEntry
.
getXAdvance
()
!=
((
float
)
cacheEntry
.
getXOff
())
||
cacheEntry
.
getYAdvance
()
!=
((
float
)
cacheEntry
.
getYOff
())
||
glyphSet
!=
activeGlyphSet
||
eltIndex
<
0
||
eltList
.
getCharCnt
(
eltIndex
)
==
MAX_ELT_GLYPH_COUNT
)
{
eltIndex
=
eltList
.
getNextIndex
();
eltList
.
setCharCnt
(
eltIndex
,
1
);
...
...
@@ -101,7 +108,7 @@ public class XRTextRenderer extends GlyphListPipe {
eltList
.
setGlyphSet
(
eltIndex
,
glyphSet
);
if
(
gl
.
usePositions
())
{
//
/*In this case advX only stores rounding errors*/
//
In this case advX only stores rounding errors
float
x
=
positions
[
i
*
2
]
+
advX
;
float
y
=
positions
[
i
*
2
+
1
]
+
advY
;
posX
=
(
int
)
Math
.
floor
(
x
);
...
...
@@ -120,16 +127,14 @@ public class XRTextRenderer extends GlyphListPipe {
posX
=
(
int
)
Math
.
floor
(
advX
);
posY
=
(
int
)
Math
.
floor
(
advY
);
// Advance of ELT = difference between stored
// relative
// Advance of ELT = difference between stored relative
// positioning information and required float.
advX
+=
(
cacheEntry
.
getXAdvance
()
-
cacheEntry
.
getXOff
());
advY
+=
(
cacheEntry
.
getYAdvance
()
-
cacheEntry
.
getYOff
());
}
/*
* Offset of the current glyph is the difference to the last
* glyph and this one
*/
// Offset of the current glyph is the difference
// to the last glyph and this one
eltList
.
setXOff
(
eltIndex
,
(
posX
-
oldPosX
));
eltList
.
setYOff
(
eltIndex
,
(
posY
-
oldPosY
));
...
...
src/solaris/classes/sun/java2d/xr/XRSurfaceData.java
浏览文件 @
e782f663
...
...
@@ -245,7 +245,17 @@ public abstract class XRSurfaceData extends XSurfaceData {
ColorModel
cm
,
Image
image
,
long
drawable
,
int
transparency
)
{
int
depth
=
transparency
>
Transparency
.
OPAQUE
?
32
:
24
;
int
depth
;
// If we have a 32 bit color model for the window it needs
// alpha to support translucency of the window so we need
// to upgrade what was requested for the surface.
if
(
gc
.
getColorModel
().
getPixelSize
()
==
32
)
{
depth
=
32
;
transparency
=
Transparency
.
TRANSLUCENT
;
}
else
{
depth
=
transparency
>
Transparency
.
OPAQUE
?
32
:
24
;
}
if
(
depth
==
24
)
{
cm
=
new
DirectColorModel
(
depth
,
0x00FF0000
,
0x0000FF00
,
0x000000FF
);
...
...
src/solaris/classes/sun/print/IPPPrintService.java
浏览文件 @
e782f663
...
...
@@ -44,6 +44,7 @@ import javax.print.event.PrintServiceAttributeListener;
import
java.net.URI
;
import
java.net.URISyntaxException
;
import
java.net.URL
;
import
java.net.URLConnection
;
import
java.net.HttpURLConnection
;
import
java.io.File
;
import
java.io.InputStream
;
...
...
@@ -1607,14 +1608,16 @@ public class IPPPrintService implements PrintService, SunPrinterJobService {
public
static
HttpURLConnection
getIPPConnection
(
URL
url
)
{
HttpURLConnection
connection
;
URLConnection
urlc
;
try
{
connection
=
(
HttpURLConnection
)
url
.
openConnection
();
urlc
=
url
.
openConnection
();
}
catch
(
java
.
io
.
IOException
ioe
)
{
return
null
;
}
if
(!(
connection
instanceof
HttpURLConnection
))
{
if
(!(
urlc
instanceof
HttpURLConnection
))
{
return
null
;
}
connection
=
(
HttpURLConnection
)
urlc
;
connection
.
setUseCaches
(
false
);
connection
.
setDefaultUseCaches
(
false
);
connection
.
setDoInput
(
true
);
...
...
src/solaris/classes/sun/print/UnixPrintServiceLookup.java
浏览文件 @
e782f663
...
...
@@ -620,7 +620,7 @@ public class UnixPrintServiceLookup extends PrintServiceLookup
if
(
CUPSPrinter
.
isCupsRunning
())
{
try
{
PrintService
defaultPS
;
if
(
psuri
!=
null
)
{
if
(
(
psuri
!=
null
)
&&
!
psuri
.
startsWith
(
"file"
)
)
{
defaultPS
=
new
IPPPrintService
(
defaultPrinter
,
psuri
,
true
);
}
else
{
...
...
test/java/awt/Graphics2D/DrawString/TextRenderingTest.java
0 → 100644
浏览文件 @
e782f663
/*
* Copyright (c) 2013, 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.
*/
import
java.awt.Color
;
import
java.awt.Graphics2D
;
import
java.awt.GraphicsConfiguration
;
import
java.awt.GraphicsEnvironment
;
import
java.awt.GradientPaint
;
import
java.awt.geom.Point2D
;
import
java.awt.Font
;
import
java.awt.image.BufferedImage
;
import
java.awt.image.VolatileImage
;
/*
* @test
* @bug 7189452 8024767
* @summary Check if source offset for text rendering is handled correctly
* (shouldn't see the text on a similarly colored background).
* @author a.stepanov
* @run main TextRenderingTest
*/
public
class
TextRenderingTest
{
private
static
final
int
width
=
450
;
private
static
final
int
height
=
150
;
public
static
void
main
(
final
String
[]
args
)
{
GraphicsEnvironment
ge
=
GraphicsEnvironment
.
getLocalGraphicsEnvironment
();
GraphicsConfiguration
gc
=
ge
.
getDefaultScreenDevice
().
getDefaultConfiguration
();
VolatileImage
vi
=
gc
.
createCompatibleVolatileImage
(
width
,
height
);
while
(
true
)
{
vi
.
validate
(
gc
);
Graphics2D
g2d
=
vi
.
createGraphics
();
g2d
.
setColor
(
Color
.
white
);
g2d
.
fillRect
(
0
,
0
,
width
,
height
);
g2d
.
setPaint
(
new
GradientPaint
(
new
Point2D
.
Float
(
0
,
height
/
2
),
Color
.
white
,
new
Point2D
.
Float
(
width
,
height
/
2
),
Color
.
black
));
g2d
.
fillRect
(
0
,
0
,
width
,
height
);
String
fnt
=
g2d
.
getFont
().
getFamily
();
g2d
.
setFont
(
new
Font
(
fnt
,
Font
.
PLAIN
,
100
));
g2d
.
drawString
(
"IIIIIIIIII"
,
100
,
100
);
// draw text with offset
g2d
.
dispose
();
if
(
vi
.
validate
(
gc
)
!=
VolatileImage
.
IMAGE_OK
)
{
try
{
Thread
.
sleep
(
100
);
}
catch
(
InterruptedException
e
)
{}
continue
;
}
if
(
vi
.
contentsLost
())
{
try
{
Thread
.
sleep
(
100
);
}
catch
(
InterruptedException
e
)
{}
continue
;
}
break
;
}
BufferedImage
bi
=
vi
.
getSnapshot
();
// the text shifted shouldn't be visible onto a painted rectangle!
// so the check: color component (blue) must decrease monotonously
int
prev
=
Integer
.
MAX_VALUE
;
for
(
int
x
=
0
;
x
<
width
;
++
x
)
{
int
color
=
bi
.
getRGB
(
x
,
height
/
2
);
int
b
=
color
&
0xFF
;
if
(
b
>
prev
)
{
throw
new
RuntimeException
(
"test failed: can see the text rendered!"
);
}
prev
=
b
;
}
}
}
test/java/awt/Graphics2D/DrawString/XRenderElt254TextTest.java
0 → 100644
浏览文件 @
e782f663
/*
* Copyright (c) 2008, 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.
*/
import
java.awt.*
;
import
java.awt.MultipleGradientPaint.*
;
import
java.awt.image.*
;
import
java.io.*
;
import
javax.imageio.*
;
import
javax.swing.*
;
/**
* @test
* @bug 8028722
* @summary tests wether drawString with 254 characters causes the xrender
* pipeline to hang.
* @author ceisserer
*/
public
class
XRenderElt254TextTest
extends
Frame
implements
Runnable
{
public
volatile
boolean
success
=
false
;
public
void
run
()
{
Image
dstImg
=
getGraphicsConfiguration
().
createCompatibleVolatileImage
(
400
,
400
);
Graphics2D
g
=
(
Graphics2D
)
dstImg
.
getGraphics
();
StringBuilder
strBuilder
=
new
StringBuilder
(
254
);
for
(
int
c
=
0
;
c
<
254
;
c
++)
{
strBuilder
.
append
(
'a'
);
}
for
(
int
i
=
0
;
i
<
100
;
i
++)
{
g
.
drawString
(
strBuilder
.
toString
(),
20
,
20
);
Toolkit
.
getDefaultToolkit
().
sync
();
}
success
=
true
;
}
public
static
void
main
(
String
[]
args
)
throws
Exception
{
XRenderElt254TextTest
test
=
new
XRenderElt254TextTest
();
new
Thread
(
test
).
start
();
for
(
int
i
=
0
;
i
<
30
;
i
++)
{
Thread
.
sleep
(
1000
);
if
(
test
.
success
)
{
return
;
// Test finished successful
}
}
throw
new
RuntimeException
(
"Test Failed"
);
}
}
test/java/awt/print/PageFormat/PageFormatFromAttributes.java
浏览文件 @
e782f663
...
...
@@ -23,7 +23,7 @@
/*
* @test
* @bug 4500750 6848799
* @bug 4500750 6848799
8028584
* @summary Tests creating page format from attributes
* @run main PageFormatFromAttributes
*/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录