| OLD | NEW |
| 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/renderer/render_thread_impl.h" | 5 #include "content/renderer/render_thread_impl.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <limits> | 8 #include <limits> |
| 9 #include <map> | 9 #include <map> |
| 10 #include <vector> | 10 #include <vector> |
| 11 | 11 |
| 12 #include "base/allocator/allocator_extension.h" | 12 #include "base/allocator/allocator_extension.h" |
| 13 #include "base/command_line.h" | 13 #include "base/command_line.h" |
| 14 #include "base/debug/trace_event.h" | 14 #include "base/debug/trace_event.h" |
| 15 #include "base/lazy_instance.h" | 15 #include "base/lazy_instance.h" |
| 16 #include "base/logging.h" | 16 #include "base/logging.h" |
| 17 #include "base/memory/discardable_memory.h" |
| 17 #include "base/metrics/field_trial.h" | 18 #include "base/metrics/field_trial.h" |
| 18 #include "base/metrics/histogram.h" | 19 #include "base/metrics/histogram.h" |
| 19 #include "base/metrics/stats_table.h" | 20 #include "base/metrics/stats_table.h" |
| 20 #include "base/path_service.h" | 21 #include "base/path_service.h" |
| 21 #include "base/shared_memory.h" | 22 #include "base/shared_memory.h" |
| 22 #include "base/strings/string16.h" | 23 #include "base/strings/string16.h" |
| 23 #include "base/strings/string_number_conversions.h" // Temporary | 24 #include "base/strings/string_number_conversions.h" // Temporary |
| 24 #include "base/strings/utf_string_conversions.h" | 25 #include "base/strings/utf_string_conversions.h" |
| 25 #include "base/threading/thread_local.h" | 26 #include "base/threading/thread_local.h" |
| 26 #include "base/threading/thread_restrictions.h" | 27 #include "base/threading/thread_restrictions.h" |
| (...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 #include "content/renderer/media/audio_renderer_mixer_manager.h" | 65 #include "content/renderer/media/audio_renderer_mixer_manager.h" |
| 65 #include "content/renderer/media/media_stream_center.h" | 66 #include "content/renderer/media/media_stream_center.h" |
| 66 #include "content/renderer/media/media_stream_dependency_factory.h" | 67 #include "content/renderer/media/media_stream_dependency_factory.h" |
| 67 #include "content/renderer/media/peer_connection_tracker.h" | 68 #include "content/renderer/media/peer_connection_tracker.h" |
| 68 #include "content/renderer/media/video_capture_impl_manager.h" | 69 #include "content/renderer/media/video_capture_impl_manager.h" |
| 69 #include "content/renderer/media/video_capture_message_filter.h" | 70 #include "content/renderer/media/video_capture_message_filter.h" |
| 70 #include "content/renderer/memory_benchmarking_extension.h" | 71 #include "content/renderer/memory_benchmarking_extension.h" |
| 71 #include "content/renderer/p2p/socket_dispatcher.h" | 72 #include "content/renderer/p2p/socket_dispatcher.h" |
| 72 #include "content/renderer/plugin_channel_host.h" | 73 #include "content/renderer/plugin_channel_host.h" |
| 73 #include "content/renderer/render_process_impl.h" | 74 #include "content/renderer/render_process_impl.h" |
| 75 #include "content/renderer/render_process_visibility_manager.h" |
| 74 #include "content/renderer/render_view_impl.h" | 76 #include "content/renderer/render_view_impl.h" |
| 75 #include "content/renderer/renderer_webkitplatformsupport_impl.h" | 77 #include "content/renderer/renderer_webkitplatformsupport_impl.h" |
| 76 #include "content/renderer/skia_benchmarking_extension.h" | 78 #include "content/renderer/skia_benchmarking_extension.h" |
| 77 #include "grit/content_resources.h" | 79 #include "grit/content_resources.h" |
| 78 #include "ipc/ipc_channel_handle.h" | 80 #include "ipc/ipc_channel_handle.h" |
| 79 #include "ipc/ipc_forwarding_message_filter.h" | 81 #include "ipc/ipc_forwarding_message_filter.h" |
| 80 #include "ipc/ipc_platform_file.h" | 82 #include "ipc/ipc_platform_file.h" |
| 81 #include "media/base/audio_hardware_config.h" | 83 #include "media/base/audio_hardware_config.h" |
| 82 #include "media/base/media.h" | 84 #include "media/base/media.h" |
| 83 #include "net/base/net_errors.h" | 85 #include "net/base/net_errors.h" |
| (...skipping 506 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 590 | 592 |
| 591 void RenderThreadImpl::SetResourceDispatcherDelegate( | 593 void RenderThreadImpl::SetResourceDispatcherDelegate( |
| 592 ResourceDispatcherDelegate* delegate) { | 594 ResourceDispatcherDelegate* delegate) { |
| 593 resource_dispatcher()->set_delegate(delegate); | 595 resource_dispatcher()->set_delegate(delegate); |
| 594 } | 596 } |
| 595 | 597 |
| 596 void RenderThreadImpl::WidgetHidden() { | 598 void RenderThreadImpl::WidgetHidden() { |
| 597 DCHECK(hidden_widget_count_ < widget_count_); | 599 DCHECK(hidden_widget_count_ < widget_count_); |
| 598 hidden_widget_count_++; | 600 hidden_widget_count_++; |
| 599 | 601 |
| 602 RenderProcessVisibilityManager* manager = |
| 603 RenderProcessVisibilityManager::GetInstance(); |
| 604 manager->WidgetVisibilityChanged(false); |
| 605 |
| 600 if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) { | 606 if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) { |
| 601 return; | 607 return; |
| 602 } | 608 } |
| 603 | 609 |
| 604 if (widget_count_ && hidden_widget_count_ == widget_count_) | 610 if (widget_count_ && hidden_widget_count_ == widget_count_) |
| 605 ScheduleIdleHandler(kInitialIdleHandlerDelayMs); | 611 ScheduleIdleHandler(kInitialIdleHandlerDelayMs); |
| 606 } | 612 } |
| 607 | 613 |
| 608 void RenderThreadImpl::WidgetRestored() { | 614 void RenderThreadImpl::WidgetRestored() { |
| 609 DCHECK_GT(hidden_widget_count_, 0); | 615 DCHECK_GT(hidden_widget_count_, 0); |
| 610 hidden_widget_count_--; | 616 hidden_widget_count_--; |
| 617 |
| 618 RenderProcessVisibilityManager* manager = |
| 619 RenderProcessVisibilityManager::GetInstance(); |
| 620 manager->WidgetVisibilityChanged(true); |
| 621 |
| 611 if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) { | 622 if (!GetContentClient()->renderer()->RunIdleHandlerWhenWidgetsHidden()) { |
| 612 return; | 623 return; |
| 613 } | 624 } |
| 614 | 625 |
| 615 ScheduleIdleHandler(kLongIdleHandlerDelayMs); | 626 ScheduleIdleHandler(kLongIdleHandlerDelayMs); |
| 616 } | 627 } |
| 617 | 628 |
| 618 void RenderThreadImpl::EnsureWebKitInitialized() { | 629 void RenderThreadImpl::EnsureWebKitInitialized() { |
| 619 if (webkit_platform_support_) | 630 if (webkit_platform_support_) |
| 620 return; | 631 return; |
| (...skipping 624 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1245 | 1256 |
| 1246 void RenderThreadImpl::SetFlingCurveParameters( | 1257 void RenderThreadImpl::SetFlingCurveParameters( |
| 1247 const std::vector<float>& new_touchpad, | 1258 const std::vector<float>& new_touchpad, |
| 1248 const std::vector<float>& new_touchscreen) { | 1259 const std::vector<float>& new_touchscreen) { |
| 1249 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, | 1260 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, |
| 1250 new_touchscreen); | 1261 new_touchscreen); |
| 1251 | 1262 |
| 1252 } | 1263 } |
| 1253 | 1264 |
| 1254 } // namespace content | 1265 } // namespace content |
| OLD | NEW |