Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(237)

Side by Side Diff: cc/test/test_occlusion_tracker.h

Issue 202523002: cc: Replace Region with SimpleEnclosedRegion for occlusion tracking (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: simpleregion: . Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #ifndef CC_TEST_TEST_OCCLUSION_TRACKER_H_ 5 #ifndef CC_TEST_TEST_OCCLUSION_TRACKER_H_
6 #define CC_TEST_TEST_OCCLUSION_TRACKER_H_ 6 #define CC_TEST_TEST_OCCLUSION_TRACKER_H_
7 7
8 #include "cc/layers/render_surface.h" 8 #include "cc/layers/render_surface.h"
9 #include "cc/layers/render_surface_impl.h" 9 #include "cc/layers/render_surface_impl.h"
10 #include "cc/trees/occlusion_tracker.h" 10 #include "cc/trees/occlusion_tracker.h"
11 11
12 namespace cc { 12 namespace cc {
13 13
14 // A subclass to expose the total current occlusion. 14 // A subclass to expose the total current occlusion.
15 template <typename LayerType> 15 template <typename LayerType>
16 class TestOcclusionTracker : public OcclusionTracker<LayerType> { 16 class TestOcclusionTracker : public OcclusionTracker<LayerType> {
17 public: 17 public:
18 explicit TestOcclusionTracker(const gfx::Rect& screen_scissor_rect) 18 explicit TestOcclusionTracker(const gfx::Rect& screen_scissor_rect)
19 : OcclusionTracker<LayerType>(screen_scissor_rect) {} 19 : OcclusionTracker<LayerType>(screen_scissor_rect) {}
20 20
21 Region occlusion_from_inside_target() const { 21 SimpleEnclosedRegion occlusion_from_inside_target() const {
22 return OcclusionTracker<LayerType>::stack_.back() 22 return OcclusionTracker<LayerType>::stack_.back()
23 .occlusion_from_inside_target; 23 .occlusion_from_inside_target;
24 } 24 }
25 Region occlusion_from_outside_target() const { 25 SimpleEnclosedRegion occlusion_from_outside_target() const {
26 return OcclusionTracker<LayerType>::stack_.back() 26 return OcclusionTracker<LayerType>::stack_.back()
27 .occlusion_from_outside_target; 27 .occlusion_from_outside_target;
28 } 28 }
29 29
30 Region occlusion_on_contributing_surface_from_inside_target() const { 30 SimpleEnclosedRegion occlusion_on_contributing_surface_from_inside_target()
31 const {
31 size_t stack_size = OcclusionTracker<LayerType>::stack_.size(); 32 size_t stack_size = OcclusionTracker<LayerType>::stack_.size();
32 if (stack_size < 2) 33 if (stack_size < 2)
33 return Region(); 34 return SimpleEnclosedRegion();
34 return OcclusionTracker<LayerType>::stack_[stack_size - 2] 35 return OcclusionTracker<LayerType>::stack_[stack_size - 2]
35 .occlusion_from_inside_target; 36 .occlusion_from_inside_target;
36 } 37 }
37 Region occlusion_on_contributing_surface_from_outside_target() const { 38 SimpleEnclosedRegion occlusion_on_contributing_surface_from_outside_target()
39 const {
38 size_t stack_size = OcclusionTracker<LayerType>::stack_.size(); 40 size_t stack_size = OcclusionTracker<LayerType>::stack_.size();
39 if (stack_size < 2) 41 if (stack_size < 2)
40 return Region(); 42 return SimpleEnclosedRegion();
41 return OcclusionTracker<LayerType>::stack_[stack_size - 2] 43 return OcclusionTracker<LayerType>::stack_[stack_size - 2]
42 .occlusion_from_outside_target; 44 .occlusion_from_outside_target;
43 } 45 }
44 46
45 void set_occlusion_from_outside_target(const Region& region) { 47 void set_occlusion_from_outside_target(const SimpleEnclosedRegion& region) {
46 OcclusionTracker<LayerType>::stack_.back().occlusion_from_outside_target = 48 OcclusionTracker<LayerType>::stack_.back().occlusion_from_outside_target =
47 region; 49 region;
48 } 50 }
49 void set_occlusion_from_inside_target(const Region& region) { 51 void set_occlusion_from_inside_target(const SimpleEnclosedRegion& region) {
50 OcclusionTracker<LayerType>::stack_.back().occlusion_from_inside_target = 52 OcclusionTracker<LayerType>::stack_.back().occlusion_from_inside_target =
51 region; 53 region;
52 } 54 }
53 }; 55 };
54 56
55 } // namespace cc 57 } // namespace cc
56 58
57 #endif // CC_TEST_TEST_OCCLUSION_TRACKER_H_ 59 #endif // CC_TEST_TEST_OCCLUSION_TRACKER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698