| OLD | NEW |
| 1 // Copyright 2011 The Chromium Authors. All rights reserved. | 1 // Copyright 2011 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "cc/tiled_layer.h" | 5 #include "cc/tiled_layer.h" |
| 6 | 6 |
| 7 #include "base/basictypes.h" | 7 #include "base/basictypes.h" |
| 8 #include "build/build_config.h" | 8 #include "build/build_config.h" |
| 9 #include "cc/layer_impl.h" | 9 #include "cc/layer_impl.h" |
| 10 #include "cc/layer_tree_host.h" | 10 #include "cc/layer_tree_host.h" |
| 11 #include "cc/overdraw_metrics.h" | 11 #include "cc/overdraw_metrics.h" |
| 12 #include "cc/tiled_layer_impl.h" | 12 #include "cc/tiled_layer_impl.h" |
| 13 #include "third_party/khronos/GLES2/gl2.h" | 13 #include "third_party/khronos/GLES2/gl2.h" |
| 14 #include "ui/gfx/rect_conversions.h" | 14 #include "ui/gfx/rect_conversions.h" |
| 15 | 15 |
| 16 using namespace std; | 16 using namespace std; |
| 17 using WebKit::WebTransformationMatrix; | |
| 18 | 17 |
| 19 namespace cc { | 18 namespace cc { |
| 20 | 19 |
| 21 // Maximum predictive expansion of the visible area. | 20 // Maximum predictive expansion of the visible area. |
| 22 static const int maxPredictiveTilesCount = 2; | 21 static const int maxPredictiveTilesCount = 2; |
| 23 | 22 |
| 24 // Number of rows/columns of tiles to pre-paint. | 23 // Number of rows/columns of tiles to pre-paint. |
| 25 // We should increase these further as all textures are | 24 // We should increase these further as all textures are |
| 26 // prioritized and we insure performance doesn't suffer. | 25 // prioritized and we insure performance doesn't suffer. |
| 27 static const int prepaintRows = 4; | 26 static const int prepaintRows = 4; |
| (...skipping 449 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 477 | 476 |
| 478 // Offset from paint rectangle to this tile's dirty rectangle. | 477 // Offset from paint rectangle to this tile's dirty rectangle. |
| 479 gfx::Vector2d paintOffset = sourceRect.origin() - paintRect.origin()
; | 478 gfx::Vector2d paintOffset = sourceRect.origin() - paintRect.origin()
; |
| 480 CHECK(paintOffset.x() >= 0); | 479 CHECK(paintOffset.x() >= 0); |
| 481 CHECK(paintOffset.y() >= 0); | 480 CHECK(paintOffset.y() >= 0); |
| 482 CHECK(paintOffset.x() + sourceRect.width() <= paintRect.width()); | 481 CHECK(paintOffset.x() + sourceRect.width() <= paintRect.width()); |
| 483 CHECK(paintOffset.y() + sourceRect.height() <= paintRect.height()); | 482 CHECK(paintOffset.y() + sourceRect.height() <= paintRect.height()); |
| 484 | 483 |
| 485 tile->updaterResource()->update(queue, sourceRect, destOffset, tile-
>partialUpdate, stats); | 484 tile->updaterResource()->update(queue, sourceRect, destOffset, tile-
>partialUpdate, stats); |
| 486 if (occlusion) | 485 if (occlusion) |
| 487 occlusion->overdrawMetrics().didUpload(WebTransformationMatrix()
, sourceRect, tile->opaqueRect()); | 486 occlusion->overdrawMetrics().didUpload(gfx::Transform(), sourceR
ect, tile->opaqueRect()); |
| 488 | 487 |
| 489 } | 488 } |
| 490 } | 489 } |
| 491 } | 490 } |
| 492 | 491 |
| 493 // This picks a small animated layer to be anything less than one viewport. This | 492 // This picks a small animated layer to be anything less than one viewport. This |
| 494 // is specifically for page transitions which are viewport-sized layers. The ext
ra | 493 // is specifically for page transitions which are viewport-sized layers. The ext
ra |
| 495 // tile of padding is due to these layers being slightly larger than the viewpor
t | 494 // tile of padding is due to these layers being slightly larger than the viewpor
t |
| 496 // in some cases. | 495 // in some cases. |
| 497 bool TiledLayer::isSmallAnimatedLayer() const | 496 bool TiledLayer::isSmallAnimatedLayer() const |
| (...skipping 255 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 753 gfx::Rect prepaintRect = visibleContentRect(); | 752 gfx::Rect prepaintRect = visibleContentRect(); |
| 754 prepaintRect.Inset(-m_tiler->tileSize().width() * prepaintColumns, | 753 prepaintRect.Inset(-m_tiler->tileSize().width() * prepaintColumns, |
| 755 -m_tiler->tileSize().height() * prepaintRows); | 754 -m_tiler->tileSize().height() * prepaintRows); |
| 756 gfx::Rect contentRect(gfx::Point(), contentBounds()); | 755 gfx::Rect contentRect(gfx::Point(), contentBounds()); |
| 757 prepaintRect.Intersect(contentRect); | 756 prepaintRect.Intersect(contentRect); |
| 758 | 757 |
| 759 return prepaintRect; | 758 return prepaintRect; |
| 760 } | 759 } |
| 761 | 760 |
| 762 } // namespace cc | 761 } // namespace cc |
| OLD | NEW |