Is there a way to get the actual bounding box of a glyph in ActionScript?

前端 未结 3 805
一生所求
一生所求 2021-01-15 04:44

I\'m learning ActionScript/Flash. I love to play with text, and have done a lot of that kind of thing with the superb Java2D API.

One of the things I like to know i

相关标签:
3条回答
  • 2021-01-15 05:18

    Richard is on the right track, but BitmapData.getColorBounds() is much faster and accurate... I've used it a couple of times, and optimized for your specific needs its not as slow as one might think.

    Cory's suggestion of using flash.text.engine is probably the "correct" way to go, but I warn you that flash.text.engine is VERY (very!) hard to use compared to TextField.

    0 讨论(0)
  • 2021-01-15 05:24

    Not reasonably possible in Flash 9 -- Richard's answer is a clever work-around, though probably completely unsuitable for production code (as he mentions) :)

    If you have access to Flash 10, check out the new text engine classes, particularly TextLine.

    0 讨论(0)
  • 2021-01-15 05:40

    I'm afraid all the methods that are available on TextField are supposed to do what you have already found them to do. Unless performance is key in your application (i.e. unless you intend to do this very often) maybe one option would be to draw the text field to a BitmapData, and find the topmost, leftmost, et c colored pixels within the bounding box retrieved by getCharBoundaries()?

    var i : int;
    var rect : Rectangle;
    var top_left : Point;
    var btm_right : Point;
    
    var bmp : BitmapData = new BitmapData(tf.width, tf.height, false, 0xffffff);
    bmp.draw(tf);
    
    rect = tf.getCharBoundaries(4);
    top_left = new Point(Infinity, Infinity);
    btm_right = new Point(-Infinity, -Infinity);
    
    for (i=rect.x; i<rect.right; i++) {
      var j : int;
    
      for (j=rect.y; j<rect.bottom; j++) {
        var px : uint = bmp.getPixel(i, j);
    
        // Check if pixel is black, i.e. belongs to glyph, and if so, whether it
        // extends the previous bounds
        if (px == 0) {
          top_left.x = Math.min(top_left.x, i);
          top_left.y = Math.min(top_left.y, j);
          btm_right.x = Math.max(btm_right.x, i);
          btm_right.y = Math.max(btm_right.y, j);
        }
      }
    }
    
    var actualRect : Rectangle = new Rectangle(top_left.x, top_left.y);
    actualRect.width = btm_right.x - top_left.x;
    actualRect.height = btm_right.y - top_left.y;
    

    This code should loop through all the pixels that were deemed part of the glyph rectangle by getCharBoundaries(). If a pixel is not black, it gets discarded. If black, the code checks whether the pixels extends further up, down, right or left than any pixel that has previuosly been checked in the loop.

    Obviously, this is not optimal code, with nested loops and unnecessary point objects. Hopefully though, the code is readable enough, and you are able to make out the parts that can most easily be optimized.

    You might also want to introduce some threshold value instead of ignoring any pixel that is not pitch black.

    0 讨论(0)
提交回复
热议问题