当前位置: 首页>>代码示例>>Java>>正文


Java LayoutPathImpl.mapShape方法代码示例

本文整理汇总了Java中sun.font.LayoutPathImpl.mapShape方法的典型用法代码示例。如果您正苦于以下问题:Java LayoutPathImpl.mapShape方法的具体用法?Java LayoutPathImpl.mapShape怎么用?Java LayoutPathImpl.mapShape使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在sun.font.LayoutPathImpl的用法示例。


在下文中一共展示了LayoutPathImpl.mapShape方法的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: getOutline

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns a <code>Shape</code> representing the outline of this
 * <code>TextLayout</code>.
 * @param tx an optional {@link AffineTransform} to apply to the
 *     outline of this <code>TextLayout</code>.
 * @return a <code>Shape</code> that is the outline of this
 *     <code>TextLayout</code>.  This is in standard coordinates.
 */
public Shape getOutline(AffineTransform tx) {
    ensureCache();
    Shape result = textLine.getOutline(tx);
    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = lp.mapShape(result);
    }
    return result;
}
 
开发者ID:SunburstApps,项目名称:OpenJSharp,代码行数:18,代码来源:TextLayout.java

示例2: getOutline

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns a {@code Shape} representing the outline of this
 * {@code TextLayout}.
 * @param tx an optional {@link AffineTransform} to apply to the
 *     outline of this {@code TextLayout}.
 * @return a {@code Shape} that is the outline of this
 *     {@code TextLayout}.  This is in standard coordinates.
 */
public Shape getOutline(AffineTransform tx) {
    ensureCache();
    Shape result = textLine.getOutline(tx);
    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = lp.mapShape(result);
    }
    return result;
}
 
开发者ID:AdoptOpenJDK,项目名称:openjdk-jdk10,代码行数:18,代码来源:TextLayout.java

示例3: pathToShape

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
private static GeneralPath pathToShape(double[] path, boolean close, LayoutPathImpl lp) {
    GeneralPath result = new GeneralPath(GeneralPath.WIND_EVEN_ODD, path.length);
    result.moveTo((float)path[0], (float)path[1]);
    for (int i = 2; i < path.length; i += 2) {
        result.lineTo((float)path[i], (float)path[i+1]);
    }
    if (close) {
        result.closePath();
    }

    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result);
    }
    return result;
}
 
开发者ID:campolake,项目名称:openjdk9,代码行数:16,代码来源:TextLayout.java

示例4: getVisualHighlightShape

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns a path enclosing the visual selection in the specified range,
 * extended to {@code bounds}.
 * <p>
 * If the selection includes the leftmost (topmost) position, the selection
 * is extended to the left (top) of {@code bounds}.  If the
 * selection includes the rightmost (bottommost) position, the selection
 * is extended to the right (bottom) of the bounds.  The height
 * (width on vertical lines) of the selection is always extended to
 * {@code bounds}.
 * <p>
 * Although the selection is always contiguous, the logically selected
 * text can be discontiguous on lines with mixed-direction text.  The
 * logical ranges of text selected can be retrieved using
 * {@code getLogicalRangesForVisualSelection}.  For example,
 * consider the text 'ABCdef' where capital letters indicate
 * right-to-left text, rendered on a right-to-left line, with a visual
 * selection from 0L (the leading edge of 'A') to 3T (the trailing edge
 * of 'd').  The text appears as follows, with bold underlined areas
 * representing the selection:
 * <br><pre>
 *    d<u><b>efCBA  </b></u>
 * </pre>
 * The logical selection ranges are 0-3, 4-6 (ABC, ef) because the
 * visually contiguous text is logically discontiguous.  Also note that
 * since the rightmost position on the layout (to the right of 'A') is
 * selected, the selection is extended to the right of the bounds.
 * @param firstEndpoint one end of the visual selection
 * @param secondEndpoint the other end of the visual selection
 * @param bounds the bounding rectangle to which to extend the selection.
 *     This is in baseline-relative coordinates.
 * @return a {@code Shape} enclosing the selection.  This is in
 *     standard coordinates.
 * @see #getLogicalRangesForVisualSelection(TextHitInfo, TextHitInfo)
 * @see #getLogicalHighlightShape(int, int, Rectangle2D)
 */
public Shape getVisualHighlightShape(TextHitInfo firstEndpoint,
                                    TextHitInfo secondEndpoint,
                                    Rectangle2D bounds)
{
    ensureCache();

    checkTextHit(firstEndpoint);
    checkTextHit(secondEndpoint);

    if(bounds == null) {
            throw new IllegalArgumentException("Null Rectangle2D passed to TextLayout.getVisualHighlightShape()");
    }

    GeneralPath result = new GeneralPath(GeneralPath.WIND_EVEN_ODD);

    int firstCaret = hitToCaret(firstEndpoint);
    int secondCaret = hitToCaret(secondEndpoint);

    result.append(caretBoundingShape(firstCaret, secondCaret, bounds),
                  false);

    if (firstCaret == 0 || secondCaret == 0) {
        GeneralPath ls = leftShape(bounds);
        if (!ls.getBounds().isEmpty())
            result.append(ls, false);
    }

    if (firstCaret == characterCount || secondCaret == characterCount) {
        GeneralPath rs = rightShape(bounds);
        if (!rs.getBounds().isEmpty()) {
            result.append(rs, false);
        }
    }

    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result); // dlf cast safe?
    }

    return  result;
}
 
开发者ID:campolake,项目名称:openjdk9,代码行数:78,代码来源:TextLayout.java

示例5: getBlackBoxBounds

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns the black box bounds of the characters in the specified range.
 * The black box bounds is an area consisting of the union of the bounding
 * boxes of all the glyphs corresponding to the characters between start
 * and limit.  This area can be disjoint.
 * @param firstEndpoint one end of the character range
 * @param secondEndpoint the other end of the character range.  Can be
 * less than {@code firstEndpoint}.
 * @return a {@code Shape} enclosing the black box bounds.  This is
 *     in standard coordinates.
 */
public Shape getBlackBoxBounds(int firstEndpoint, int secondEndpoint) {
    ensureCache();

    if (firstEndpoint > secondEndpoint) {
        int t = firstEndpoint;
        firstEndpoint = secondEndpoint;
        secondEndpoint = t;
    }

    if (firstEndpoint < 0 || secondEndpoint > characterCount) {
        throw new IllegalArgumentException("Invalid range passed to TextLayout.getBlackBoxBounds()");
    }

    /*
     * return an area that consists of the bounding boxes of all the
     * characters from firstEndpoint to limit
     */

    GeneralPath result = new GeneralPath(GeneralPath.WIND_NON_ZERO);

    if (firstEndpoint < characterCount) {
        for (int logIndex = firstEndpoint;
                    logIndex < secondEndpoint;
                    logIndex++) {

            Rectangle2D r = textLine.getCharBounds(logIndex);
            if (!r.isEmpty()) {
                result.append(r, false);
            }
        }
    }

    if (dx != 0 || dy != 0) {
        AffineTransform tx = AffineTransform.getTranslateInstance(dx, dy);
        result = (GeneralPath)tx.createTransformedShape(result);
    }
    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result);
    }

    //return new Highlight(result, false);
    return result;
}
 
开发者ID:campolake,项目名称:openjdk9,代码行数:56,代码来源:TextLayout.java

示例6: getVisualHighlightShape

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns a path enclosing the visual selection in the specified range,
 * extended to <code>bounds</code>.
 * <p>
 * If the selection includes the leftmost (topmost) position, the selection
 * is extended to the left (top) of <code>bounds</code>.  If the
 * selection includes the rightmost (bottommost) position, the selection
 * is extended to the right (bottom) of the bounds.  The height
 * (width on vertical lines) of the selection is always extended to
 * <code>bounds</code>.
 * <p>
 * Although the selection is always contiguous, the logically selected
 * text can be discontiguous on lines with mixed-direction text.  The
 * logical ranges of text selected can be retrieved using
 * <code>getLogicalRangesForVisualSelection</code>.  For example,
 * consider the text 'ABCdef' where capital letters indicate
 * right-to-left text, rendered on a right-to-left line, with a visual
 * selection from 0L (the leading edge of 'A') to 3T (the trailing edge
 * of 'd').  The text appears as follows, with bold underlined areas
 * representing the selection:
 * <br><pre>
 *    d<u><b>efCBA  </b></u>
 * </pre>
 * The logical selection ranges are 0-3, 4-6 (ABC, ef) because the
 * visually contiguous text is logically discontiguous.  Also note that
 * since the rightmost position on the layout (to the right of 'A') is
 * selected, the selection is extended to the right of the bounds.
 * @param firstEndpoint one end of the visual selection
 * @param secondEndpoint the other end of the visual selection
 * @param bounds the bounding rectangle to which to extend the selection.
 *     This is in baseline-relative coordinates.
 * @return a <code>Shape</code> enclosing the selection.  This is in
 *     standard coordinates.
 * @see #getLogicalRangesForVisualSelection(TextHitInfo, TextHitInfo)
 * @see #getLogicalHighlightShape(int, int, Rectangle2D)
 */
public Shape getVisualHighlightShape(TextHitInfo firstEndpoint,
                                    TextHitInfo secondEndpoint,
                                    Rectangle2D bounds)
{
    ensureCache();

    checkTextHit(firstEndpoint);
    checkTextHit(secondEndpoint);

    if(bounds == null) {
            throw new IllegalArgumentException("Null Rectangle2D passed to TextLayout.getVisualHighlightShape()");
    }

    GeneralPath result = new GeneralPath(GeneralPath.WIND_EVEN_ODD);

    int firstCaret = hitToCaret(firstEndpoint);
    int secondCaret = hitToCaret(secondEndpoint);

    result.append(caretBoundingShape(firstCaret, secondCaret, bounds),
                  false);

    if (firstCaret == 0 || secondCaret == 0) {
        GeneralPath ls = leftShape(bounds);
        if (!ls.getBounds().isEmpty())
            result.append(ls, false);
    }

    if (firstCaret == characterCount || secondCaret == characterCount) {
        GeneralPath rs = rightShape(bounds);
        if (!rs.getBounds().isEmpty()) {
            result.append(rs, false);
        }
    }

    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result); // dlf cast safe?
    }

    return  result;
}
 
开发者ID:Java8-CNAPI-Team,项目名称:Java8CN,代码行数:78,代码来源:TextLayout.java

示例7: getBlackBoxBounds

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns the black box bounds of the characters in the specified range.
 * The black box bounds is an area consisting of the union of the bounding
 * boxes of all the glyphs corresponding to the characters between start
 * and limit.  This area can be disjoint.
 * @param firstEndpoint one end of the character range
 * @param secondEndpoint the other end of the character range.  Can be
 * less than <code>firstEndpoint</code>.
 * @return a <code>Shape</code> enclosing the black box bounds.  This is
 *     in standard coordinates.
 */
public Shape getBlackBoxBounds(int firstEndpoint, int secondEndpoint) {
    ensureCache();

    if (firstEndpoint > secondEndpoint) {
        int t = firstEndpoint;
        firstEndpoint = secondEndpoint;
        secondEndpoint = t;
    }

    if (firstEndpoint < 0 || secondEndpoint > characterCount) {
        throw new IllegalArgumentException("Invalid range passed to TextLayout.getBlackBoxBounds()");
    }

    /*
     * return an area that consists of the bounding boxes of all the
     * characters from firstEndpoint to limit
     */

    GeneralPath result = new GeneralPath(GeneralPath.WIND_NON_ZERO);

    if (firstEndpoint < characterCount) {
        for (int logIndex = firstEndpoint;
                    logIndex < secondEndpoint;
                    logIndex++) {

            Rectangle2D r = textLine.getCharBounds(logIndex);
            if (!r.isEmpty()) {
                result.append(r, false);
            }
        }
    }

    if (dx != 0 || dy != 0) {
        AffineTransform tx = AffineTransform.getTranslateInstance(dx, dy);
        result = (GeneralPath)tx.createTransformedShape(result);
    }
    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result);
    }

    //return new Highlight(result, false);
    return result;
}
 
开发者ID:Java8-CNAPI-Team,项目名称:Java8CN,代码行数:56,代码来源:TextLayout.java

示例8: getVisualHighlightShape

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns a path enclosing the visual selection in the specified range,
 * extended to <code>bounds</code>.
 * <p>
 * If the selection includes the leftmost (topmost) position, the selection
 * is extended to the left (top) of <code>bounds</code>.  If the 
 * selection includes the rightmost (bottommost) position, the selection
 * is extended to the right (bottom) of the bounds.  The height 
 * (width on vertical lines) of the selection is always extended to 
 * <code>bounds</code>.
 * <p>
 * Although the selection is always contiguous, the logically selected
 * text can be discontiguous on lines with mixed-direction text.  The
 * logical ranges of text selected can be retrieved using
 * <code>getLogicalRangesForVisualSelection</code>.  For example, 
 * consider the text 'ABCdef' where capital letters indicate 
 * right-to-left text, rendered on a right-to-left line, with a visual
 * selection from 0L (the leading edge of 'A') to 3T (the trailing edge
 * of 'd').  The text appears as follows, with bold underlined areas
 * representing the selection:
 * <br><pre>
 *    d<u><b>efCBA  </b></u>
 * </pre>
 * The logical selection ranges are 0-3, 4-6 (ABC, ef) because the
 * visually contiguous text is logically discontiguous.  Also note that
 * since the rightmost position on the layout (to the right of 'A') is
 * selected, the selection is extended to the right of the bounds.
 * @param firstEndpoint one end of the visual selection
 * @param secondEndpoint the other end of the visual selection
 * @param bounds the bounding rectangle to which to extend the selection.
 *     This is in baseline-relative coordinates.
 * @return a <code>Shape</code> enclosing the selection.  This is in
 *     standard coordinates.
 * @see #getLogicalRangesForVisualSelection(TextHitInfo, TextHitInfo)
 * @see #getLogicalHighlightShape(int, int, Rectangle2D)
 */
public Shape getVisualHighlightShape(TextHitInfo firstEndpoint,
                                    TextHitInfo secondEndpoint,
                                    Rectangle2D bounds)
{
    ensureCache();

    checkTextHit(firstEndpoint);
    checkTextHit(secondEndpoint);

    if(bounds == null) {
            throw new IllegalArgumentException("Null Rectangle2D passed to TextLayout.getVisualHighlightShape()");
    }

    GeneralPath result = new GeneralPath(GeneralPath.WIND_EVEN_ODD);

    int firstCaret = hitToCaret(firstEndpoint);
    int secondCaret = hitToCaret(secondEndpoint);

    result.append(caretBoundingShape(firstCaret, secondCaret, bounds),
                  false);

    if (firstCaret == 0 || secondCaret == 0) {
        GeneralPath ls = leftShape(bounds);
        if (!ls.getBounds().isEmpty())
            result.append(ls, false);
    }

    if (firstCaret == characterCount || secondCaret == characterCount) {
        GeneralPath rs = rightShape(bounds);
        if (!rs.getBounds().isEmpty()) {
            result.append(rs, false);
        }
    }

    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result); // dlf cast safe?
    }

    return  result;
}
 
开发者ID:jgaltidor,项目名称:VarJ,代码行数:78,代码来源:TextLayout.java

示例9: getBlackBoxBounds

import sun.font.LayoutPathImpl; //导入方法依赖的package包/类
/**
 * Returns the black box bounds of the characters in the specified range.
 * The black box bounds is an area consisting of the union of the bounding
 * boxes of all the glyphs corresponding to the characters between start
 * and limit.  This area can be disjoint.
 * @param firstEndpoint one end of the character range
 * @param secondEndpoint the other end of the character range.  Can be
 * less than <code>firstEndpoint</code>.
 * @return a <code>Shape</code> enclosing the black box bounds.  This is
 *     in standard coordinates.
 */
public Shape getBlackBoxBounds(int firstEndpoint, int secondEndpoint) {
    ensureCache();

    if (firstEndpoint > secondEndpoint) {
        int t = firstEndpoint;
        firstEndpoint = secondEndpoint;
        secondEndpoint = t;
    }

    if (firstEndpoint < 0 || secondEndpoint > characterCount) {
        throw new IllegalArgumentException("Invalid range passed to TextLayout.getBlackBoxBounds()");
    }

    /*
     * return an area that consists of the bounding boxes of all the
     * characters from firstEndpoint to limit
     */
 
    GeneralPath result = new GeneralPath(GeneralPath.WIND_NON_ZERO);

    if (firstEndpoint < characterCount) {
        for (int logIndex = firstEndpoint;
                    logIndex < secondEndpoint;
                    logIndex++) {

            Rectangle2D r = textLine.getCharBounds(logIndex);
            if (!r.isEmpty()) {
                result.append(r, false);
            }
        }
    }

    if (dx != 0 || dy != 0) {
        AffineTransform tx = AffineTransform.getTranslateInstance(dx, dy);
        result = (GeneralPath)tx.createTransformedShape(result);
    }
    LayoutPathImpl lp = textLine.getLayoutPath();
    if (lp != null) {
        result = (GeneralPath)lp.mapShape(result);
    }

    //return new Highlight(result, false);
    return result;
}
 
开发者ID:jgaltidor,项目名称:VarJ,代码行数:56,代码来源:TextLayout.java


注:本文中的sun.font.LayoutPathImpl.mapShape方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。