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/web_contents/web_contents_impl.h" | 5 #include "content/browser/web_contents/web_contents_impl.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <cmath> | 9 #include <cmath> |
| 10 #include <utility> | 10 #include <utility> |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 105 #include "content/public/common/content_constants.h" | 105 #include "content/public/common/content_constants.h" |
| 106 #include "content/public/common/content_switches.h" | 106 #include "content/public/common/content_switches.h" |
| 107 #include "content/public/common/page_zoom.h" | 107 #include "content/public/common/page_zoom.h" |
| 108 #include "content/public/common/result_codes.h" | 108 #include "content/public/common/result_codes.h" |
| 109 #include "content/public/common/security_style.h" | 109 #include "content/public/common/security_style.h" |
| 110 #include "content/public/common/url_constants.h" | 110 #include "content/public/common/url_constants.h" |
| 111 #include "content/public/common/url_utils.h" | 111 #include "content/public/common/url_utils.h" |
| 112 #include "content/public/common/web_preferences.h" | 112 #include "content/public/common/web_preferences.h" |
| 113 #include "mojo/common/url_type_converters.h" | 113 #include "mojo/common/url_type_converters.h" |
| 114 #include "mojo/converters/geometry/geometry_type_converters.h" | 114 #include "mojo/converters/geometry/geometry_type_converters.h" |
| 115 #include "net/base/url_util.h" | |
| 115 #include "net/http/http_cache.h" | 116 #include "net/http/http_cache.h" |
| 116 #include "net/http/http_transaction_factory.h" | 117 #include "net/http/http_transaction_factory.h" |
| 117 #include "net/url_request/url_request_context.h" | 118 #include "net/url_request/url_request_context.h" |
| 118 #include "net/url_request/url_request_context_getter.h" | 119 #include "net/url_request/url_request_context_getter.h" |
| 119 #include "skia/public/type_converters.h" | 120 #include "skia/public/type_converters.h" |
| 120 #include "third_party/WebKit/public/web/WebSandboxFlags.h" | 121 #include "third_party/WebKit/public/web/WebSandboxFlags.h" |
| 121 #include "third_party/skia/include/core/SkBitmap.h" | 122 #include "third_party/skia/include/core/SkBitmap.h" |
| 122 #include "ui/base/layout.h" | 123 #include "ui/base/layout.h" |
| 123 #include "ui/gfx/display.h" | 124 #include "ui/gfx/display.h" |
| 124 #include "ui/gfx/screen.h" | 125 #include "ui/gfx/screen.h" |
| (...skipping 727 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 852 SetAccessibilityMode(RemoveAccessibilityModeFrom(accessibility_mode_, mode)); | 853 SetAccessibilityMode(RemoveAccessibilityModeFrom(accessibility_mode_, mode)); |
| 853 } | 854 } |
| 854 | 855 |
| 855 void WebContentsImpl::RequestAXTreeSnapshot(AXTreeSnapshotCallback callback) { | 856 void WebContentsImpl::RequestAXTreeSnapshot(AXTreeSnapshotCallback callback) { |
| 856 // TODO(dmazzoni): http://crbug.com/475608 This only returns the | 857 // TODO(dmazzoni): http://crbug.com/475608 This only returns the |
| 857 // accessibility tree from the main frame and everything in the | 858 // accessibility tree from the main frame and everything in the |
| 858 // same site instance. | 859 // same site instance. |
| 859 GetMainFrame()->RequestAXTreeSnapshot(callback); | 860 GetMainFrame()->RequestAXTreeSnapshot(callback); |
| 860 } | 861 } |
| 861 | 862 |
| 863 void WebContentsImpl::SetTemporaryZoomLevel(double level, bool is_temporary) { | |
|
ncarter (slow)
2016/04/11 22:17:03
is_temporary -> temporary_zoom_enabled
wjmaclean
2016/04/13 18:47:46
Done.
| |
| 864 SendPageMessage(new PageMsg_SetZoomLevel( | |
| 865 MSG_ROUTING_NONE, | |
| 866 is_temporary ? ZOOM_SET_TEMPORARY : ZOOM_CLEAR_TEMPORARY, level)); | |
| 867 } | |
| 868 | |
| 869 void WebContentsImpl::UpdateZoom(double level) { | |
| 870 // Individual frames may still ignore the new zoom level if their RenderView | |
| 871 // contains a plugin document or if it uses a temporary zoom level. | |
| 872 SendPageMessage(new PageMsg_SetZoomLevel( | |
| 873 MSG_ROUTING_NONE, ZOOM_USE_CURRENT_TEMPORARY_MODE, level)); | |
| 874 } | |
| 875 | |
| 876 void WebContentsImpl::UpdateZoomIfNecessary(const std::string& scheme, | |
| 877 const std::string& host, | |
| 878 double level) { | |
| 879 NavigationEntry* entry = GetController().GetLastCommittedEntry(); | |
| 880 if (!entry) | |
| 881 return; | |
| 882 | |
| 883 GURL url = HostZoomMap::GetURLFromEntry(entry); | |
| 884 if (host != net::GetHostOrSpecFromURL(url) || | |
| 885 (!scheme.empty() && scheme != url.scheme())) { | |
| 886 return; | |
| 887 } | |
| 888 | |
| 889 UpdateZoom(level); | |
| 890 } | |
| 891 | |
| 862 WebUI* WebContentsImpl::CreateSubframeWebUI(const GURL& url, | 892 WebUI* WebContentsImpl::CreateSubframeWebUI(const GURL& url, |
| 863 const std::string& frame_name) { | 893 const std::string& frame_name) { |
| 864 DCHECK(!frame_name.empty()); | 894 DCHECK(!frame_name.empty()); |
| 865 return CreateWebUI(url, frame_name); | 895 return CreateWebUI(url, frame_name); |
| 866 } | 896 } |
| 867 | 897 |
| 868 WebUI* WebContentsImpl::GetWebUI() const { | 898 WebUI* WebContentsImpl::GetWebUI() const { |
| 869 WebUI* commited_web_ui = GetCommittedWebUI(); | 899 WebUI* commited_web_ui = GetCommittedWebUI(); |
| 870 return commited_web_ui ? commited_web_ui | 900 return commited_web_ui ? commited_web_ui |
| 871 : GetRenderManager()->GetNavigatingWebUI(); | 901 : GetRenderManager()->GetNavigatingWebUI(); |
| (...skipping 3705 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 4577 CreateRenderWidgetHostViewForRenderManager(render_view_host); | 4607 CreateRenderWidgetHostViewForRenderManager(render_view_host); |
| 4578 | 4608 |
| 4579 // Make sure we use the correct starting page_id in the new RenderView. | 4609 // Make sure we use the correct starting page_id in the new RenderView. |
| 4580 UpdateMaxPageIDIfNecessary(render_view_host); | 4610 UpdateMaxPageIDIfNecessary(render_view_host); |
| 4581 int32_t max_page_id = | 4611 int32_t max_page_id = |
| 4582 GetMaxPageIDForSiteInstance(render_view_host->GetSiteInstance()); | 4612 GetMaxPageIDForSiteInstance(render_view_host->GetSiteInstance()); |
| 4583 | 4613 |
| 4584 if (!static_cast<RenderViewHostImpl*>(render_view_host) | 4614 if (!static_cast<RenderViewHostImpl*>(render_view_host) |
| 4585 ->CreateRenderView(opener_frame_routing_id, proxy_routing_id, | 4615 ->CreateRenderView(opener_frame_routing_id, proxy_routing_id, |
| 4586 max_page_id, replicated_frame_state, | 4616 max_page_id, replicated_frame_state, |
| 4587 created_with_opener_)) { | 4617 created_with_opener_, |
| 4618 HostZoomMap::GetZoomLevel(this))) { | |
| 4588 return false; | 4619 return false; |
| 4589 } | 4620 } |
| 4590 | 4621 |
| 4591 SetHistoryOffsetAndLengthForView(render_view_host, | 4622 SetHistoryOffsetAndLengthForView(render_view_host, |
| 4592 controller_.GetLastCommittedEntryIndex(), | 4623 controller_.GetLastCommittedEntryIndex(), |
| 4593 controller_.GetEntryCount()); | 4624 controller_.GetEntryCount()); |
| 4594 | 4625 |
| 4595 #if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_ANDROID) | 4626 #if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_ANDROID) |
| 4596 // Force a ViewMsg_Resize to be sent, needed to make plugins show up on | 4627 // Force a ViewMsg_Resize to be sent, needed to make plugins show up on |
| 4597 // linux. See crbug.com/83941. | 4628 // linux. See crbug.com/83941. |
| (...skipping 238 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 4836 else | 4867 else |
| 4837 WasHidden(); | 4868 WasHidden(); |
| 4838 } | 4869 } |
| 4839 | 4870 |
| 4840 void WebContentsImpl::SetJavaScriptDialogManagerForTesting( | 4871 void WebContentsImpl::SetJavaScriptDialogManagerForTesting( |
| 4841 JavaScriptDialogManager* dialog_manager) { | 4872 JavaScriptDialogManager* dialog_manager) { |
| 4842 dialog_manager_ = dialog_manager; | 4873 dialog_manager_ = dialog_manager; |
| 4843 } | 4874 } |
| 4844 | 4875 |
| 4845 } // namespace content | 4876 } // namespace content |
| OLD | NEW |