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

Side by Side Diff: cc/resources/tile.cc

Issue 13665003: cc: Moved contents_swizzled out of TileManager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 7 years, 8 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
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 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/resources/tile.h" 5 #include "cc/resources/tile.h"
6 6
7 #include "base/stringprintf.h" 7 #include "base/stringprintf.h"
8 #include "cc/resources/tile_manager.h" 8 #include "cc/resources/tile_manager.h"
9 #include "third_party/khronos/GLES2/gl2.h" 9 #include "third_party/khronos/GLES2/gl2.h"
10 10
11 namespace cc { 11 namespace cc {
12 12
13 Tile::Tile(TileManager* tile_manager, 13 Tile::Tile(TileManager* tile_manager,
14 PicturePileImpl* picture_pile, 14 PicturePileImpl* picture_pile,
15 gfx::Size tile_size, 15 gfx::Size tile_size,
16 GLenum format, 16 GLenum format,
17 gfx::Rect content_rect, 17 gfx::Rect content_rect,
18 gfx::Rect opaque_rect, 18 gfx::Rect opaque_rect,
19 float contents_scale, 19 float contents_scale,
20 int layer_id) 20 int layer_id)
21 : tile_manager_(tile_manager), 21 : tile_manager_(tile_manager),
22 tile_size_(tile_size), 22 tile_size_(tile_size),
23 format_(format),
24 content_rect_(content_rect), 23 content_rect_(content_rect),
25 contents_scale_(contents_scale), 24 contents_scale_(contents_scale),
26 opaque_rect_(opaque_rect), 25 opaque_rect_(opaque_rect),
27 layer_id_(layer_id) { 26 layer_id_(layer_id) {
28 set_picture_pile(picture_pile); 27 set_picture_pile(picture_pile);
28 drawing_info().set_resource_format(format);
29 tile_manager_->RegisterTile(this); 29 tile_manager_->RegisterTile(this);
30 } 30 }
31 31
32 Tile::~Tile() { 32 Tile::~Tile() {
33 tile_manager_->UnregisterTile(this); 33 tile_manager_->UnregisterTile(this);
34 } 34 }
35 35
36 scoped_ptr<base::Value> Tile::AsValue() const { 36 scoped_ptr<base::Value> Tile::AsValue() const {
37 scoped_ptr<base::DictionaryValue> res(new base::DictionaryValue()); 37 scoped_ptr<base::DictionaryValue> res(new base::DictionaryValue());
38 res->SetString("id", base::StringPrintf("%p", this)); 38 res->SetString("id", base::StringPrintf("%p", this));
39 res->SetString("picture_pile", base::StringPrintf("%p", 39 res->SetString("picture_pile", base::StringPrintf("%p",
40 picture_pile_.get())); 40 picture_pile_.get()));
41 res->SetDouble("contents_scale", contents_scale_); 41 res->SetDouble("contents_scale", contents_scale_);
42 res->Set("priority.0", priority_[ACTIVE_TREE].AsValue().release()); 42 res->Set("priority.0", priority_[ACTIVE_TREE].AsValue().release());
43 res->Set("priority.1", priority_[PENDING_TREE].AsValue().release()); 43 res->Set("priority.1", priority_[PENDING_TREE].AsValue().release());
44 res->Set("managed_state", managed_state_.AsValue().release()); 44 res->Set("managed_state", managed_state_.AsValue().release());
45 return res.PassAs<base::Value>(); 45 return res.PassAs<base::Value>();
46 } 46 }
47 47
48 void Tile::SetPriority(WhichTree tree, const TilePriority& priority) { 48 void Tile::SetPriority(WhichTree tree, const TilePriority& priority) {
49 if (priority_[tree] == priority) 49 if (priority_[tree] == priority)
50 return; 50 return;
51 51
52 tile_manager_->WillModifyTilePriority(this, tree, priority); 52 tile_manager_->WillModifyTilePriority(this, tree, priority);
53 priority_[tree] = priority; 53 priority_[tree] = priority;
54 } 54 }
55 55
56 } // namespace cc 56 } // namespace cc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698