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

Side by Side Diff: content/browser/renderer_host/render_widget_host_view_android.cc

Issue 577273003: Add new latency_info for tracking browser composite time. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Sievers Review Created 6 years, 2 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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 "content/browser/renderer_host/render_widget_host_view_android.h" 5 #include "content/browser/renderer_host/render_widget_host_view_android.h"
6 6
7 #include <android/bitmap.h> 7 #include <android/bitmap.h>
8 8
9 #include "base/android/build_info.h" 9 #include "base/android/build_info.h"
10 #include "base/basictypes.h" 10 #include "base/basictypes.h"
(...skipping 1287 matching lines...) Expand 10 before | Expand all | Expand 10 after
1298 observing_root_window_ = false; 1298 observing_root_window_ = false;
1299 content_view_core_->GetWindowAndroid()->RemoveObserver(this); 1299 content_view_core_->GetWindowAndroid()->RemoveObserver(this);
1300 } 1300 }
1301 1301
1302 void RenderWidgetHostViewAndroid::SendBeginFrame(base::TimeTicks frame_time, 1302 void RenderWidgetHostViewAndroid::SendBeginFrame(base::TimeTicks frame_time,
1303 base::TimeDelta vsync_period) { 1303 base::TimeDelta vsync_period) {
1304 TRACE_EVENT1("cc", "RenderWidgetHostViewAndroid::SendBeginFrame", 1304 TRACE_EVENT1("cc", "RenderWidgetHostViewAndroid::SendBeginFrame",
1305 "frame_time_us", frame_time.ToInternalValue()); 1305 "frame_time_us", frame_time.ToInternalValue());
1306 base::TimeTicks display_time = frame_time + vsync_period; 1306 base::TimeTicks display_time = frame_time + vsync_period;
1307 1307
1308 // TODO(brianderson): Use adaptive draw-time estimation. 1308 base::TimeTicks deadline =
1309 base::TimeDelta estimated_browser_composite_time = 1309 display_time - host_->GetEstimatedBrowserCompositeTime();
1310 base::TimeDelta::FromMicroseconds(
1311 (1.0f * base::Time::kMicrosecondsPerSecond) / (3.0f * 60));
1312
1313 base::TimeTicks deadline = display_time - estimated_browser_composite_time;
1314 1310
1315 host_->Send(new ViewMsg_BeginFrame( 1311 host_->Send(new ViewMsg_BeginFrame(
1316 host_->GetRoutingID(), 1312 host_->GetRoutingID(),
1317 cc::BeginFrameArgs::Create(frame_time, deadline, vsync_period))); 1313 cc::BeginFrameArgs::Create(frame_time, deadline, vsync_period)));
1318 } 1314 }
1319 1315
1320 bool RenderWidgetHostViewAndroid::Animate(base::TimeTicks frame_time) { 1316 bool RenderWidgetHostViewAndroid::Animate(base::TimeTicks frame_time) {
1321 bool needs_animate = 1317 bool needs_animate =
1322 overscroll_effect_ ? overscroll_effect_->Animate(frame_time) : false; 1318 overscroll_effect_ ? overscroll_effect_->Animate(frame_time) : false;
1323 if (selection_controller_) 1319 if (selection_controller_)
(...skipping 452 matching lines...) Expand 10 before | Expand all | Expand 10 after
1776 results->orientationAngle = display.RotationAsDegree(); 1772 results->orientationAngle = display.RotationAsDegree();
1777 results->orientationType = 1773 results->orientationType =
1778 RenderWidgetHostViewBase::GetOrientationTypeForMobile(display); 1774 RenderWidgetHostViewBase::GetOrientationTypeForMobile(display);
1779 gfx::DeviceDisplayInfo info; 1775 gfx::DeviceDisplayInfo info;
1780 results->depth = info.GetBitsPerPixel(); 1776 results->depth = info.GetBitsPerPixel();
1781 results->depthPerComponent = info.GetBitsPerComponent(); 1777 results->depthPerComponent = info.GetBitsPerComponent();
1782 results->isMonochrome = (results->depthPerComponent == 0); 1778 results->isMonochrome = (results->depthPerComponent == 0);
1783 } 1779 }
1784 1780
1785 } // namespace content 1781 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/renderer_host/render_widget_host_impl.cc ('k') | content/common/gpu/image_transport_surface.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698