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

Side by Side Diff: content/renderer/gpu/render_widget_compositor.cc

Issue 1408123005: Android Webview IPC-based sync compositing (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix win compile Created 5 years, 1 month 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) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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 "content/renderer/gpu/render_widget_compositor.h" 5 #include "content/renderer/gpu/render_widget_compositor.h"
6 6
7 #include <limits> 7 #include <limits>
8 #include <string> 8 #include <string>
9 9
10 #include "base/command_line.h" 10 #include "base/command_line.h"
(...skipping 354 matching lines...) Expand 10 before | Expand all | Expand 10 after
365 cc::switches::kSlowDownRasterScaleFactor, 365 cc::switches::kSlowDownRasterScaleFactor,
366 kMinSlowDownScaleFactor, 366 kMinSlowDownScaleFactor,
367 kMaxSlowDownScaleFactor, 367 kMaxSlowDownScaleFactor,
368 &settings.initial_debug_state.slow_down_raster_scale_factor); 368 &settings.initial_debug_state.slow_down_raster_scale_factor);
369 } 369 }
370 370
371 settings.strict_layer_property_change_checking = 371 settings.strict_layer_property_change_checking =
372 cmd->HasSwitch(cc::switches::kStrictLayerPropertyChangeChecking); 372 cmd->HasSwitch(cc::switches::kStrictLayerPropertyChangeChecking);
373 373
374 #if defined(OS_ANDROID) 374 #if defined(OS_ANDROID)
375 SynchronousCompositorFactory* synchronous_compositor_factory = 375 DCHECK(!SynchronousCompositorFactory::GetInstance() ||
376 SynchronousCompositorFactory::GetInstance(); 376 !cmd->HasSwitch(switches::kIPCSyncCompositing));
377 bool using_synchronous_compositor =
378 SynchronousCompositorFactory::GetInstance() ||
379 cmd->HasSwitch(switches::kIPCSyncCompositing);
377 380
378 // We can't use GPU rasterization on low-end devices, because the Ganesh 381 // We can't use GPU rasterization on low-end devices, because the Ganesh
379 // cache would consume too much memory. 382 // cache would consume too much memory.
380 if (base::SysInfo::IsLowEndDevice()) 383 if (base::SysInfo::IsLowEndDevice())
381 settings.gpu_rasterization_enabled = false; 384 settings.gpu_rasterization_enabled = false;
382 settings.using_synchronous_renderer_compositor = 385 settings.using_synchronous_renderer_compositor = using_synchronous_compositor;
383 synchronous_compositor_factory;
384 settings.record_full_layer = widget_->DoesRecordFullLayer(); 386 settings.record_full_layer = widget_->DoesRecordFullLayer();
385 if (synchronous_compositor_factory) { 387 if (using_synchronous_compositor) {
386 // Android WebView uses system scrollbars, so make ours invisible. 388 // Android WebView uses system scrollbars, so make ours invisible.
387 settings.scrollbar_animator = cc::LayerTreeSettings::NO_ANIMATOR; 389 settings.scrollbar_animator = cc::LayerTreeSettings::NO_ANIMATOR;
388 settings.solid_color_scrollbar_color = SK_ColorTRANSPARENT; 390 settings.solid_color_scrollbar_color = SK_ColorTRANSPARENT;
389 } else { 391 } else {
390 settings.scrollbar_animator = cc::LayerTreeSettings::LINEAR_FADE; 392 settings.scrollbar_animator = cc::LayerTreeSettings::LINEAR_FADE;
391 settings.scrollbar_fade_delay_ms = 300; 393 settings.scrollbar_fade_delay_ms = 300;
392 settings.scrollbar_fade_resize_delay_ms = 2000; 394 settings.scrollbar_fade_resize_delay_ms = 2000;
393 settings.scrollbar_fade_duration_ms = 300; 395 settings.scrollbar_fade_duration_ms = 300;
394 settings.solid_color_scrollbar_color = SkColorSetARGB(128, 128, 128, 128); 396 settings.solid_color_scrollbar_color = SkColorSetARGB(128, 128, 128, 128);
395 } 397 }
396 settings.renderer_settings.highp_threshold_min = 2048; 398 settings.renderer_settings.highp_threshold_min = 2048;
397 // Android WebView handles root layer flings itself. 399 // Android WebView handles root layer flings itself.
398 settings.ignore_root_layer_flings = 400 settings.ignore_root_layer_flings = using_synchronous_compositor;
399 synchronous_compositor_factory;
400 // Memory policy on Android WebView does not depend on whether device is 401 // Memory policy on Android WebView does not depend on whether device is
401 // low end, so always use default policy. 402 // low end, so always use default policy.
402 bool use_low_memory_policy = 403 bool use_low_memory_policy =
403 base::SysInfo::IsLowEndDevice() && !synchronous_compositor_factory; 404 base::SysInfo::IsLowEndDevice() && !using_synchronous_compositor;
404 // RGBA_4444 textures are only enabled by default for low end devices 405 // RGBA_4444 textures are only enabled by default for low end devices
405 // and are disabled for Android WebView as it doesn't support the format. 406 // and are disabled for Android WebView as it doesn't support the format.
406 settings.renderer_settings.use_rgba_4444_textures = use_low_memory_policy; 407 settings.renderer_settings.use_rgba_4444_textures = use_low_memory_policy;
407 if (use_low_memory_policy) { 408 if (use_low_memory_policy) {
408 // On low-end we want to be very carefull about killing other 409 // On low-end we want to be very carefull about killing other
409 // apps. So initially we use 50% more memory to avoid flickering 410 // apps. So initially we use 50% more memory to avoid flickering
410 // or raster-on-demand. 411 // or raster-on-demand.
411 settings.max_memory_for_prepaint_percentage = 67; 412 settings.max_memory_for_prepaint_percentage = 67;
412 } else { 413 } else {
413 // On other devices we have increased memory excessively to avoid 414 // On other devices we have increased memory excessively to avoid
414 // raster-on-demand already, so now we reserve 50% _only_ to avoid 415 // raster-on-demand already, so now we reserve 50% _only_ to avoid
415 // raster-on-demand, and use 50% of the memory otherwise. 416 // raster-on-demand, and use 50% of the memory otherwise.
416 settings.max_memory_for_prepaint_percentage = 50; 417 settings.max_memory_for_prepaint_percentage = 50;
417 } 418 }
418 // Webview does not own the surface so should not clear it. 419 // Webview does not own the surface so should not clear it.
419 settings.renderer_settings.should_clear_root_render_pass = 420 settings.renderer_settings.should_clear_root_render_pass =
420 !synchronous_compositor_factory; 421 !using_synchronous_compositor;
421 422
422 // TODO(danakj): Only do this on low end devices. 423 // TODO(danakj): Only do this on low end devices.
423 settings.create_low_res_tiling = true; 424 settings.create_low_res_tiling = true;
424 425
425 settings.use_external_begin_frame_source = true; 426 settings.use_external_begin_frame_source = true;
426 427
427 #elif !defined(OS_MACOSX) 428 #elif !defined(OS_MACOSX)
428 if (ui::IsOverlayScrollbarEnabled()) { 429 if (ui::IsOverlayScrollbarEnabled()) {
429 settings.scrollbar_animator = cc::LayerTreeSettings::THINNING; 430 settings.scrollbar_animator = cc::LayerTreeSettings::THINNING;
430 settings.solid_color_scrollbar_color = SkColorSetARGB(128, 128, 128, 128); 431 settings.solid_color_scrollbar_color = SkColorSetARGB(128, 128, 128, 128);
(...skipping 650 matching lines...) Expand 10 before | Expand all | Expand 10 after
1081 #endif 1082 #endif
1082 return actual; 1083 return actual;
1083 } 1084 }
1084 1085
1085 void RenderWidgetCompositor::SetPaintedDeviceScaleFactor( 1086 void RenderWidgetCompositor::SetPaintedDeviceScaleFactor(
1086 float device_scale) { 1087 float device_scale) {
1087 layer_tree_host_->SetPaintedDeviceScaleFactor(device_scale); 1088 layer_tree_host_->SetPaintedDeviceScaleFactor(device_scale);
1088 } 1089 }
1089 1090
1090 } // namespace content 1091 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/android/synchronous_compositor_proxy.cc ('k') | content/renderer/input/input_handler_manager_client.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698