Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/base/invalidation_region.h" | 5 #include "cc/base/invalidation_region.h" |
| 6 | 6 |
| 7 #include "base/metrics/histogram.h" | 7 #include "base/metrics/histogram.h" |
| 8 | 8 |
| 9 namespace { | 9 namespace { |
| 10 | 10 |
| 11 const int kMaxInvalidationRectCount = 256; | 11 const int kMaxInvalidationRectCount = 256; |
| 12 | 12 |
| 13 } // namespace | 13 } // namespace |
| 14 | 14 |
| 15 namespace cc { | 15 namespace cc { |
| 16 | 16 |
| 17 InvalidationRegion::InvalidationRegion() {} | 17 InvalidationRegion::InvalidationRegion() {} |
| 18 | 18 |
| 19 InvalidationRegion::~InvalidationRegion() {} | 19 InvalidationRegion::~InvalidationRegion() {} |
| 20 | 20 |
| 21 void InvalidationRegion::Swap(Region* region) { | 21 void InvalidationRegion::Swap(Region* region) { |
| 22 FinalizePendingRects(); | |
| 22 region_.Swap(region); | 23 region_.Swap(region); |
| 23 } | 24 } |
| 24 | 25 |
| 25 void InvalidationRegion::Clear() { | 26 void InvalidationRegion::Clear() { |
| 27 pending_rects_.clear(); | |
| 26 region_.Clear(); | 28 region_.Clear(); |
| 27 } | 29 } |
| 28 | 30 |
| 29 void InvalidationRegion::Union(const gfx::Rect& rect) { | 31 void InvalidationRegion::Union(const gfx::Rect& rect) { |
| 30 region_.Union(rect); | 32 if (pending_rects_.size() >= kMaxInvalidationRectCount) |
|
vmiura
2016/06/10 05:35:48
I just realized after this change, we never get (p
| |
| 31 SimplifyIfNeeded(); | 33 pending_rects_[0].Union(rect); |
| 34 else | |
| 35 pending_rects_.push_back(rect); | |
| 32 } | 36 } |
| 33 | 37 |
| 34 void InvalidationRegion::SimplifyIfNeeded() { | 38 void InvalidationRegion::FinalizePendingRects() { |
| 35 if (region_.GetRegionComplexity() > kMaxInvalidationRectCount) | 39 if (pending_rects_.empty()) |
| 36 region_ = region_.bounds(); | 40 return; |
| 41 | |
| 42 if (region_.GetRegionComplexity() + pending_rects_.size() > | |
| 43 kMaxInvalidationRectCount) { | |
| 44 gfx::Rect pending_bounds = region_.bounds(); | |
| 45 for (auto& rect : pending_rects_) | |
| 46 pending_bounds.Union(rect); | |
| 47 region_ = pending_bounds; | |
| 48 } else { | |
| 49 for (auto& rect : pending_rects_) | |
| 50 region_.Union(rect); | |
| 51 } | |
| 52 | |
| 53 pending_rects_.clear(); | |
| 37 } | 54 } |
| 38 | 55 |
| 39 } // namespace cc | 56 } // namespace cc |
| OLD | NEW |