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

Side by Side Diff: components/view_manager/display_manager.cc

Issue 1082723005: Fix html_viewer crash in cc when logging into gmail. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 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
« no previous file with comments | « components/view_manager/BUILD.gn ('k') | mojo/converters/surfaces/surfaces_type_converters.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 #include "components/view_manager/display_manager.h" 5 #include "components/view_manager/display_manager.h"
6 6
7 #include "base/numerics/safe_conversions.h" 7 #include "base/numerics/safe_conversions.h"
8 #include "components/view_manager/connection_manager.h" 8 #include "components/view_manager/connection_manager.h"
9 #include "components/view_manager/server_view.h" 9 #include "components/view_manager/server_view.h"
10 #include "components/view_manager/view_coordinate_conversions.h" 10 #include "components/view_manager/view_coordinate_conversions.h"
11 #include "mojo/converters/geometry/geometry_type_converters.h" 11 #include "mojo/converters/geometry/geometry_type_converters.h"
12 #include "mojo/converters/surfaces/surfaces_type_converters.h" 12 #include "mojo/converters/surfaces/surfaces_type_converters.h"
13 #include "mojo/converters/surfaces/surfaces_utils.h"
13 #include "mojo/converters/transform/transform_type_converters.h" 14 #include "mojo/converters/transform/transform_type_converters.h"
14 #include "third_party/mojo/src/mojo/public/cpp/application/application_connectio n.h" 15 #include "third_party/mojo/src/mojo/public/cpp/application/application_connectio n.h"
15 #include "third_party/mojo/src/mojo/public/cpp/application/application_impl.h" 16 #include "third_party/mojo/src/mojo/public/cpp/application/application_impl.h"
16 #include "third_party/mojo_services/src/gpu/public/interfaces/gpu.mojom.h" 17 #include "third_party/mojo_services/src/gpu/public/interfaces/gpu.mojom.h"
17 #include "third_party/mojo_services/src/surfaces/public/cpp/surfaces_utils.h"
18 #include "third_party/mojo_services/src/surfaces/public/interfaces/quads.mojom.h " 18 #include "third_party/mojo_services/src/surfaces/public/interfaces/quads.mojom.h "
19 #include "third_party/mojo_services/src/surfaces/public/interfaces/surfaces.mojo m.h" 19 #include "third_party/mojo_services/src/surfaces/public/interfaces/surfaces.mojo m.h"
20 20
21 using mojo::Rect; 21 using mojo::Rect;
22 using mojo::Size; 22 using mojo::Size;
23 23
24 namespace view_manager { 24 namespace view_manager {
25 namespace { 25 namespace {
26 26
27 void DrawViewTree(mojo::Pass* pass, 27 void DrawViewTree(mojo::Pass* pass,
(...skipping 26 matching lines...) Expand all
54 auto surface_quad = mojo::Quad::New(); 54 auto surface_quad = mojo::Quad::New();
55 surface_quad->material = mojo::Material::MATERIAL_SURFACE_CONTENT; 55 surface_quad->material = mojo::Material::MATERIAL_SURFACE_CONTENT;
56 surface_quad->rect = Rect::From(bounds_at_origin); 56 surface_quad->rect = Rect::From(bounds_at_origin);
57 surface_quad->opaque_rect = Rect::From(bounds_at_origin); 57 surface_quad->opaque_rect = Rect::From(bounds_at_origin);
58 surface_quad->visible_rect = Rect::From(bounds_at_origin); 58 surface_quad->visible_rect = Rect::From(bounds_at_origin);
59 surface_quad->needs_blending = true; 59 surface_quad->needs_blending = true;
60 surface_quad->shared_quad_state_index = 60 surface_quad->shared_quad_state_index =
61 base::saturated_cast<int32_t>(pass->shared_quad_states.size()); 61 base::saturated_cast<int32_t>(pass->shared_quad_states.size());
62 surface_quad->surface_quad_state = surface_quad_state.Pass(); 62 surface_quad->surface_quad_state = surface_quad_state.Pass();
63 63
64 auto sqs = CreateDefaultSQS(*Size::From(view->bounds().size())); 64 auto sqs = mojo::CreateDefaultSQS(view->bounds().size());
65 sqs->blend_mode = mojo::SK_XFERMODE_kSrcOver_Mode; 65 sqs->blend_mode = mojo::SK_XFERMODE_kSrcOver_Mode;
66 sqs->opacity = combined_opacity; 66 sqs->opacity = combined_opacity;
67 sqs->content_to_target_transform = mojo::Transform::From(node_transform); 67 sqs->content_to_target_transform = mojo::Transform::From(node_transform);
68 68
69 pass->quads.push_back(surface_quad.Pass()); 69 pass->quads.push_back(surface_quad.Pass());
70 pass->shared_quad_states.push_back(sqs.Pass()); 70 pass->shared_quad_states.push_back(sqs.Pass());
71 } 71 }
72 72
73 } // namespace 73 } // namespace
74 74
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after
128 128
129 void DefaultDisplayManager::SetViewportSize(const gfx::Size& size) { 129 void DefaultDisplayManager::SetViewportSize(const gfx::Size& size) {
130 native_viewport_->SetSize(Size::From(size)); 130 native_viewport_->SetSize(Size::From(size));
131 } 131 }
132 132
133 const mojo::ViewportMetrics& DefaultDisplayManager::GetViewportMetrics() { 133 const mojo::ViewportMetrics& DefaultDisplayManager::GetViewportMetrics() {
134 return metrics_; 134 return metrics_;
135 } 135 }
136 136
137 void DefaultDisplayManager::Draw() { 137 void DefaultDisplayManager::Draw() {
138 Rect rect; 138 gfx::Rect rect(metrics_.size->width, metrics_.size->height);
139 rect.width = metrics_.size->width; 139 auto pass = mojo::CreateDefaultPass(1, rect);
140 rect.height = metrics_.size->height;
141 auto pass = CreateDefaultPass(1, rect);
142 pass->damage_rect = Rect::From(dirty_rect_); 140 pass->damage_rect = Rect::From(dirty_rect_);
143 141
144 DrawViewTree(pass.get(), connection_manager_->root(), gfx::Vector2d(), 1.0f); 142 DrawViewTree(pass.get(), connection_manager_->root(), gfx::Vector2d(), 1.0f);
145 143
146 auto frame = mojo::Frame::New(); 144 auto frame = mojo::Frame::New();
147 frame->passes.push_back(pass.Pass()); 145 frame->passes.push_back(pass.Pass());
148 frame->resources.resize(0u); 146 frame->resources.resize(0u);
149 frame_pending_ = true; 147 frame_pending_ = true;
150 display_->SubmitFrame( 148 display_->SubmitFrame(
151 frame.Pass(), 149 frame.Pass(),
(...skipping 26 matching lines...) Expand all
178 &DefaultDisplayManager::OnMetricsChanged, weak_factory_.GetWeakPtr())); 176 &DefaultDisplayManager::OnMetricsChanged, weak_factory_.GetWeakPtr()));
179 } 177 }
180 178
181 void DefaultDisplayManager::OnConnectionError() { 179 void DefaultDisplayManager::OnConnectionError() {
182 // This is called when the native_viewport is torn down before 180 // This is called when the native_viewport is torn down before
183 // ~DefaultDisplayManager may be called. 181 // ~DefaultDisplayManager may be called.
184 native_viewport_closed_callback_.Run(); 182 native_viewport_closed_callback_.Run();
185 } 183 }
186 184
187 } // namespace view_manager 185 } // namespace view_manager
OLDNEW
« no previous file with comments | « components/view_manager/BUILD.gn ('k') | mojo/converters/surfaces/surfaces_type_converters.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698