diff options
author | reed <reed@google.com> | 2014-11-19 06:59:41 -0800 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2014-11-19 06:59:41 -0800 |
commit | 7e76bff26e7c74902841ca4f607eb0b24a833a4a (patch) | |
tree | cb2f55b88a3ec2b3838dc9003808af03b6700e1d /src/core/SkBBHFactory.cpp | |
parent | ec03a4608025106ea3f21353865c7d302c0a13c6 (diff) |
allow pictures to have a full bounds
BUG=skia:
Review URL: https://codereview.chromium.org/736583004
Diffstat (limited to 'src/core/SkBBHFactory.cpp')
-rw-r--r-- | src/core/SkBBHFactory.cpp | 13 |
1 files changed, 9 insertions, 4 deletions
diff --git a/src/core/SkBBHFactory.cpp b/src/core/SkBBHFactory.cpp index 22f816c4d9..4b9ae558e2 100644 --- a/src/core/SkBBHFactory.cpp +++ b/src/core/SkBBHFactory.cpp @@ -9,15 +9,20 @@ #include "SkRTree.h" #include "SkTileGrid.h" - -SkBBoxHierarchy* SkRTreeFactory::operator()(int width, int height) const { - SkScalar aspectRatio = SkScalarDiv(SkIntToScalar(width), SkIntToScalar(height)); +SkBBoxHierarchy* SkRTreeFactory::operator()(const SkRect& bounds) const { + SkScalar aspectRatio = bounds.width() / bounds.height(); return SkNEW_ARGS(SkRTree, (aspectRatio)); } -SkBBoxHierarchy* SkTileGridFactory::operator()(int width, int height) const { +SkBBoxHierarchy* SkTileGridFactory::operator()(const SkRect& bounds) const { SkASSERT(fInfo.fMargin.width() >= 0); SkASSERT(fInfo.fMargin.height() >= 0); + + // We want a conservative answer for the size... + const SkIRect ibounds = bounds.roundOut(); + const int width = ibounds.width(); + const int height = ibounds.height(); + // Note: SkIRects are non-inclusive of the right() column and bottom() row. // For example, an SkIRect at 0,0 with a size of (1,1) will only have // content at pixel (0,0) and will report left=0 and right=1, hence the |