Chromium Code Reviews| 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/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 578 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 589 | 589 |
| 590 bool RenderWidgetHostViewAndroid::IsSurfaceAvailableForCopy() const { | 590 bool RenderWidgetHostViewAndroid::IsSurfaceAvailableForCopy() const { |
| 591 return HasValidFrame(); | 591 return HasValidFrame(); |
| 592 } | 592 } |
| 593 | 593 |
| 594 void RenderWidgetHostViewAndroid::Show() { | 594 void RenderWidgetHostViewAndroid::Show() { |
| 595 if (is_showing_) | 595 if (is_showing_) |
| 596 return; | 596 return; |
| 597 | 597 |
| 598 is_showing_ = true; | 598 is_showing_ = true; |
| 599 if (layer_.get()) | 599 ShowInternal(); |
| 600 layer_->SetHideLayerAndSubtree(false); | |
| 601 | |
| 602 if (overscroll_controller_) | |
| 603 overscroll_controller_->Enable(); | |
| 604 | |
| 605 frame_evictor_->SetVisible(true); | |
| 606 | |
| 607 if (!host_ || !host_->is_hidden()) | |
| 608 return; | |
| 609 | |
| 610 host_->WasShown(ui::LatencyInfo()); | |
| 611 | |
| 612 if (content_view_core_) { | |
| 613 StartObservingRootWindow(); | |
| 614 RequestVSyncUpdate(BEGIN_FRAME); | |
| 615 } | |
| 616 } | 600 } |
| 617 | 601 |
| 618 void RenderWidgetHostViewAndroid::Hide() { | 602 void RenderWidgetHostViewAndroid::Hide() { |
| 619 if (!is_showing_) | 603 if (!is_showing_) |
| 620 return; | 604 return; |
| 621 | 605 |
| 622 is_showing_ = false; | 606 is_showing_ = false; |
| 623 if (layer_.get() && locks_on_frame_count_ == 0) | |
| 624 layer_->SetHideLayerAndSubtree(true); | |
| 625 | 607 |
| 626 if (overscroll_controller_) | 608 bool hide_frontbuffer = true; |
| 627 overscroll_controller_->Disable(); | 609 bool stop_observing_root_window = true; |
| 628 | 610 HideInternal(hide_frontbuffer, stop_observing_root_window); |
| 629 frame_evictor_->SetVisible(false); | |
| 630 // We don't know if we will ever get a frame if we are hiding the renderer, so | |
| 631 // we need to cancel all requests | |
| 632 AbortPendingReadbackRequests(); | |
| 633 | |
| 634 RunAckCallbacks(cc::SurfaceDrawStatus::DRAW_SKIPPED); | |
| 635 | |
| 636 if (!host_ || host_->is_hidden()) | |
| 637 return; | |
| 638 | |
| 639 // Inform the renderer that we are being hidden so it can reduce its resource | |
| 640 // utilization. | |
| 641 host_->WasHidden(); | |
| 642 | |
| 643 StopObservingRootWindow(); | |
| 644 } | 611 } |
| 645 | 612 |
| 646 bool RenderWidgetHostViewAndroid::IsShowing() { | 613 bool RenderWidgetHostViewAndroid::IsShowing() { |
| 647 // ContentViewCoreImpl represents the native side of the Java | 614 // ContentViewCoreImpl represents the native side of the Java |
| 648 // ContentViewCore. It being NULL means that it is not attached | 615 // ContentViewCore. It being NULL means that it is not attached |
| 649 // to the View system yet, so we treat this RWHVA as hidden. | 616 // to the View system yet, so we treat this RWHVA as hidden. |
| 650 return is_showing_ && content_view_core_; | 617 return is_showing_ && content_view_core_; |
| 651 } | 618 } |
| 652 | 619 |
| 653 void RenderWidgetHostViewAndroid::LockCompositingSurface() { | 620 void RenderWidgetHostViewAndroid::LockCompositingSurface() { |
| (...skipping 826 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1480 web_contents_impl->media_web_contents_observer()->OnFrameInfoUpdated(); | 1447 web_contents_impl->media_web_contents_observer()->OnFrameInfoUpdated(); |
| 1481 } | 1448 } |
| 1482 #endif // defined(VIDEO_HOLE) | 1449 #endif // defined(VIDEO_HOLE) |
| 1483 } | 1450 } |
| 1484 | 1451 |
| 1485 void RenderWidgetHostViewAndroid::AcceleratedSurfaceInitialized(int route_id) { | 1452 void RenderWidgetHostViewAndroid::AcceleratedSurfaceInitialized(int route_id) { |
| 1486 // TODO: remove need for the surface id here | 1453 // TODO: remove need for the surface id here |
| 1487 accelerated_surface_route_id_ = route_id; | 1454 accelerated_surface_route_id_ = route_id; |
| 1488 } | 1455 } |
| 1489 | 1456 |
| 1457 void RenderWidgetHostViewAndroid::ShowInternal() { | |
| 1458 DCHECK(is_showing_); | |
| 1459 if (!host_ || !host_->is_hidden()) | |
| 1460 return; | |
| 1461 | |
| 1462 if (layer_.get()) | |
| 1463 layer_->SetHideLayerAndSubtree(false); | |
| 1464 | |
| 1465 frame_evictor_->SetVisible(true); | |
| 1466 | |
| 1467 if (overscroll_controller_) | |
| 1468 overscroll_controller_->Enable(); | |
| 1469 | |
| 1470 host_->WasShown(ui::LatencyInfo()); | |
| 1471 | |
| 1472 if (content_view_core_) { | |
| 1473 StartObservingRootWindow(); | |
| 1474 RequestVSyncUpdate(BEGIN_FRAME); | |
| 1475 } | |
| 1476 } | |
| 1477 | |
| 1478 void RenderWidgetHostViewAndroid::HideInternal( | |
| 1479 bool hide_frontbuffer, | |
| 1480 bool stop_observing_root_window) { | |
| 1481 if (hide_frontbuffer) { | |
| 1482 if (layer_.get() && locks_on_frame_count_ == 0) | |
| 1483 layer_->SetHideLayerAndSubtree(true); | |
| 1484 | |
| 1485 frame_evictor_->SetVisible(false); | |
| 1486 } | |
| 1487 | |
| 1488 if (stop_observing_root_window) | |
| 1489 StopObservingRootWindow(); | |
| 1490 | |
| 1491 if (overscroll_controller_) | |
| 1492 overscroll_controller_->Disable(); | |
| 1493 | |
| 1494 // We don't know if we will ever get a frame if we are hiding the renderer, so | |
| 1495 // we need to cancel all requests | |
| 1496 AbortPendingReadbackRequests(); | |
| 1497 | |
| 1498 RunAckCallbacks(cc::SurfaceDrawStatus::DRAW_SKIPPED); | |
| 1499 | |
| 1500 if (!host_ || host_->is_hidden()) | |
|
no sievers
2015/03/20 21:48:25
Can you move this up to line 1487 though?
jdduke (slow)
2015/03/20 22:48:18
I'll move it up to 1491. I can't move it to 1487,
| |
| 1501 return; | |
| 1502 | |
| 1503 // Inform the renderer that we are being hidden so it can reduce its resource | |
| 1504 // utilization. | |
| 1505 host_->WasHidden(); | |
| 1506 } | |
| 1507 | |
| 1490 void RenderWidgetHostViewAndroid::AttachLayers() { | 1508 void RenderWidgetHostViewAndroid::AttachLayers() { |
| 1491 if (!content_view_core_) | 1509 if (!content_view_core_) |
| 1492 return; | 1510 return; |
| 1493 if (!layer_.get()) | 1511 if (!layer_.get()) |
| 1494 return; | 1512 return; |
| 1495 | 1513 |
| 1496 content_view_core_->AttachLayer(layer_); | 1514 content_view_core_->AttachLayer(layer_); |
| 1497 if (overscroll_controller_) | 1515 if (overscroll_controller_) |
| 1498 overscroll_controller_->Enable(); | 1516 overscroll_controller_->Enable(); |
| 1499 layer_->SetHideLayerAndSubtree(!is_showing_); | 1517 layer_->SetHideLayerAndSubtree(!is_showing_); |
| (...skipping 11 matching lines...) Expand all Loading... | |
| 1511 overscroll_controller_->Disable(); | 1529 overscroll_controller_->Disable(); |
| 1512 } | 1530 } |
| 1513 | 1531 |
| 1514 void RenderWidgetHostViewAndroid::RequestVSyncUpdate(uint32 requests) { | 1532 void RenderWidgetHostViewAndroid::RequestVSyncUpdate(uint32 requests) { |
| 1515 // The synchronous compositor does not requre BeginFrame messages. | 1533 // The synchronous compositor does not requre BeginFrame messages. |
| 1516 if (!using_browser_compositor_) | 1534 if (!using_browser_compositor_) |
| 1517 requests &= FLUSH_INPUT; | 1535 requests &= FLUSH_INPUT; |
| 1518 | 1536 |
| 1519 bool should_request_vsync = !outstanding_vsync_requests_ && requests; | 1537 bool should_request_vsync = !outstanding_vsync_requests_ && requests; |
| 1520 outstanding_vsync_requests_ |= requests; | 1538 outstanding_vsync_requests_ |= requests; |
| 1539 | |
| 1540 // If the host has been hidden, defer vsync requests until it is shown | |
| 1541 // again via |Show()|. | |
| 1542 if (!host_ || host_->is_hidden()) | |
| 1543 return; | |
| 1544 | |
| 1521 // Note that if we're not currently observing the root window, outstanding | 1545 // Note that if we're not currently observing the root window, outstanding |
| 1522 // vsync requests will be pushed if/when we resume observing in | 1546 // vsync requests will be pushed if/when we resume observing in |
| 1523 // |StartObservingRootWindow()|. | 1547 // |StartObservingRootWindow()|. |
| 1524 if (observing_root_window_ && should_request_vsync) | 1548 if (observing_root_window_ && should_request_vsync) |
| 1525 content_view_core_->GetWindowAndroid()->RequestVSyncUpdate(); | 1549 content_view_core_->GetWindowAndroid()->RequestVSyncUpdate(); |
| 1526 } | 1550 } |
| 1527 | 1551 |
| 1528 void RenderWidgetHostViewAndroid::StartObservingRootWindow() { | 1552 void RenderWidgetHostViewAndroid::StartObservingRootWindow() { |
| 1529 DCHECK(content_view_core_); | 1553 DCHECK(content_view_core_); |
| 1554 DCHECK(is_showing_); | |
| 1530 if (observing_root_window_) | 1555 if (observing_root_window_) |
| 1531 return; | 1556 return; |
| 1532 | 1557 |
| 1533 observing_root_window_ = true; | 1558 observing_root_window_ = true; |
| 1534 content_view_core_->GetWindowAndroid()->AddObserver(this); | 1559 content_view_core_->GetWindowAndroid()->AddObserver(this); |
| 1535 | 1560 |
| 1536 // Clear existing vsync requests to allow a request to the new window. | 1561 // Clear existing vsync requests to allow a request to the new window. |
| 1537 uint32 outstanding_vsync_requests = outstanding_vsync_requests_; | 1562 uint32 outstanding_vsync_requests = outstanding_vsync_requests_; |
| 1538 outstanding_vsync_requests_ = 0; | 1563 outstanding_vsync_requests_ = 0; |
| 1539 RequestVSyncUpdate(outstanding_vsync_requests); | 1564 RequestVSyncUpdate(outstanding_vsync_requests); |
| (...skipping 280 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1820 if (content_view_core_) | 1845 if (content_view_core_) |
| 1821 obj = content_view_core_->GetJavaObject(); | 1846 obj = content_view_core_->GetJavaObject(); |
| 1822 manager->ToBrowserAccessibilityManagerAndroid()->SetContentViewCore(obj); | 1847 manager->ToBrowserAccessibilityManagerAndroid()->SetContentViewCore(obj); |
| 1823 } | 1848 } |
| 1824 | 1849 |
| 1825 AttachLayers(); | 1850 AttachLayers(); |
| 1826 | 1851 |
| 1827 if (!content_view_core_) | 1852 if (!content_view_core_) |
| 1828 return; | 1853 return; |
| 1829 | 1854 |
| 1830 StartObservingRootWindow(); | 1855 if (is_showing_) |
| 1856 StartObservingRootWindow(); | |
| 1831 | 1857 |
| 1832 if (resize) | 1858 if (resize) |
| 1833 WasResized(); | 1859 WasResized(); |
| 1834 | 1860 |
| 1835 if (!selection_controller_) | 1861 if (!selection_controller_) |
| 1836 selection_controller_ = CreateSelectionController(this, content_view_core_); | 1862 selection_controller_ = CreateSelectionController(this, content_view_core_); |
| 1837 | 1863 |
| 1838 if (!overscroll_controller_ && | 1864 if (!overscroll_controller_ && |
| 1839 content_view_core_->GetWindowAndroid()->GetCompositor()) { | 1865 content_view_core_->GetWindowAndroid()->GetCompositor()) { |
| 1840 overscroll_controller_ = CreateOverscrollController(content_view_core_); | 1866 overscroll_controller_ = CreateOverscrollController(content_view_core_); |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 1861 web_gesture.modifiers == blink::WebInputEvent::ShiftKey) { | 1887 web_gesture.modifiers == blink::WebInputEvent::ShiftKey) { |
| 1862 web_gesture.modifiers = 0; | 1888 web_gesture.modifiers = 0; |
| 1863 } | 1889 } |
| 1864 SendGestureEvent(web_gesture); | 1890 SendGestureEvent(web_gesture); |
| 1865 } | 1891 } |
| 1866 | 1892 |
| 1867 void RenderWidgetHostViewAndroid::OnCompositingDidCommit() { | 1893 void RenderWidgetHostViewAndroid::OnCompositingDidCommit() { |
| 1868 RunAckCallbacks(cc::SurfaceDrawStatus::DRAWN); | 1894 RunAckCallbacks(cc::SurfaceDrawStatus::DRAWN); |
| 1869 } | 1895 } |
| 1870 | 1896 |
| 1897 void RenderWidgetHostViewAndroid::OnVisibilityChanged(bool visible) { | |
| 1898 DCHECK(is_showing_); | |
| 1899 if (visible) { | |
| 1900 ShowInternal(); | |
| 1901 } else { | |
| 1902 bool hide_frontbuffer = true; | |
| 1903 bool stop_observing_root_window = false; | |
| 1904 HideInternal(hide_frontbuffer, stop_observing_root_window); | |
| 1905 } | |
| 1906 } | |
| 1907 | |
| 1871 void RenderWidgetHostViewAndroid::OnAttachCompositor() { | 1908 void RenderWidgetHostViewAndroid::OnAttachCompositor() { |
| 1872 DCHECK(content_view_core_); | 1909 DCHECK(content_view_core_); |
| 1873 if (!overscroll_controller_) | 1910 if (!overscroll_controller_) |
| 1874 overscroll_controller_ = CreateOverscrollController(content_view_core_); | 1911 overscroll_controller_ = CreateOverscrollController(content_view_core_); |
| 1875 } | 1912 } |
| 1876 | 1913 |
| 1877 void RenderWidgetHostViewAndroid::OnDetachCompositor() { | 1914 void RenderWidgetHostViewAndroid::OnDetachCompositor() { |
| 1878 DCHECK(content_view_core_); | 1915 DCHECK(content_view_core_); |
| 1879 DCHECK(using_browser_compositor_); | 1916 DCHECK(using_browser_compositor_); |
| 1880 RunAckCallbacks(cc::SurfaceDrawStatus::DRAW_SKIPPED); | 1917 RunAckCallbacks(cc::SurfaceDrawStatus::DRAW_SKIPPED); |
| 1881 overscroll_controller_.reset(); | 1918 overscroll_controller_.reset(); |
| 1882 } | 1919 } |
| 1883 | 1920 |
| 1884 void RenderWidgetHostViewAndroid::OnVSync(base::TimeTicks frame_time, | 1921 void RenderWidgetHostViewAndroid::OnVSync(base::TimeTicks frame_time, |
| 1885 base::TimeDelta vsync_period) { | 1922 base::TimeDelta vsync_period) { |
| 1886 TRACE_EVENT0("cc,benchmark", "RenderWidgetHostViewAndroid::OnVSync"); | 1923 TRACE_EVENT0("cc,benchmark", "RenderWidgetHostViewAndroid::OnVSync"); |
| 1887 if (!host_) | 1924 if (!host_ || host_->is_hidden()) |
| 1888 return; | 1925 return; |
| 1889 | 1926 |
| 1890 const uint32 current_vsync_requests = outstanding_vsync_requests_; | 1927 const uint32 current_vsync_requests = outstanding_vsync_requests_; |
| 1891 outstanding_vsync_requests_ = 0; | 1928 outstanding_vsync_requests_ = 0; |
| 1892 | 1929 |
| 1893 if (current_vsync_requests & FLUSH_INPUT) | 1930 if (current_vsync_requests & FLUSH_INPUT) |
| 1894 host_->FlushInput(); | 1931 host_->FlushInput(); |
| 1895 | 1932 |
| 1896 if (current_vsync_requests & BEGIN_FRAME || | 1933 if (current_vsync_requests & BEGIN_FRAME || |
| 1897 current_vsync_requests & PERSISTENT_BEGIN_FRAME) { | 1934 current_vsync_requests & PERSISTENT_BEGIN_FRAME) { |
| 1898 SendBeginFrame(frame_time, vsync_period); | 1935 SendBeginFrame(frame_time, vsync_period); |
| 1899 } | 1936 } |
| 1900 | 1937 |
| 1901 if (current_vsync_requests & PERSISTENT_BEGIN_FRAME) | 1938 if (current_vsync_requests & PERSISTENT_BEGIN_FRAME) |
| 1902 RequestVSyncUpdate(PERSISTENT_BEGIN_FRAME); | 1939 RequestVSyncUpdate(PERSISTENT_BEGIN_FRAME); |
| 1903 } | 1940 } |
| 1904 | 1941 |
| 1905 void RenderWidgetHostViewAndroid::OnAnimate(base::TimeTicks begin_frame_time) { | 1942 void RenderWidgetHostViewAndroid::OnAnimate(base::TimeTicks begin_frame_time) { |
| 1906 if (Animate(begin_frame_time)) | 1943 if (Animate(begin_frame_time)) |
| 1907 SetNeedsAnimate(); | 1944 SetNeedsAnimate(); |
| 1908 } | 1945 } |
| 1909 | 1946 |
| 1947 void RenderWidgetHostViewAndroid::OnActivityResumed() { | |
| 1948 DCHECK(is_showing_); | |
| 1949 ShowInternal(); | |
| 1950 } | |
| 1951 | |
| 1952 void RenderWidgetHostViewAndroid::OnActivityPaused() { | |
| 1953 DCHECK(is_showing_); | |
| 1954 bool hide_frontbuffer = false; | |
| 1955 bool stop_observing_root_window = false; | |
| 1956 HideInternal(hide_frontbuffer, stop_observing_root_window); | |
| 1957 } | |
| 1958 | |
| 1910 void RenderWidgetHostViewAndroid::OnLostResources() { | 1959 void RenderWidgetHostViewAndroid::OnLostResources() { |
| 1911 ReleaseLocksOnSurface(); | 1960 ReleaseLocksOnSurface(); |
| 1912 if (layer_.get()) | 1961 if (layer_.get()) |
| 1913 DestroyDelegatedContent(); | 1962 DestroyDelegatedContent(); |
| 1914 DCHECK(ack_callbacks_.empty()); | 1963 DCHECK(ack_callbacks_.empty()); |
| 1915 // We should not loose a frame if we have readback requests pending. | 1964 // We should not loose a frame if we have readback requests pending. |
| 1916 DCHECK(readbacks_waiting_for_frame_.empty()); | 1965 DCHECK(readbacks_waiting_for_frame_.empty()); |
| 1917 } | 1966 } |
| 1918 | 1967 |
| 1919 // static | 1968 // static |
| (...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2047 results->orientationAngle = display.RotationAsDegree(); | 2096 results->orientationAngle = display.RotationAsDegree(); |
| 2048 results->orientationType = | 2097 results->orientationType = |
| 2049 RenderWidgetHostViewBase::GetOrientationTypeForMobile(display); | 2098 RenderWidgetHostViewBase::GetOrientationTypeForMobile(display); |
| 2050 gfx::DeviceDisplayInfo info; | 2099 gfx::DeviceDisplayInfo info; |
| 2051 results->depth = info.GetBitsPerPixel(); | 2100 results->depth = info.GetBitsPerPixel(); |
| 2052 results->depthPerComponent = info.GetBitsPerComponent(); | 2101 results->depthPerComponent = info.GetBitsPerComponent(); |
| 2053 results->isMonochrome = (results->depthPerComponent == 0); | 2102 results->isMonochrome = (results->depthPerComponent == 0); |
| 2054 } | 2103 } |
| 2055 | 2104 |
| 2056 } // namespace content | 2105 } // namespace content |
| OLD | NEW |