Index: content/renderer/render_view_impl.cc |
diff --git a/content/renderer/render_view_impl.cc b/content/renderer/render_view_impl.cc |
index 9544dad2c9917564839e0132361c33248c429ba1..5f1a3c1af6b0816f404b7b5a25e78bed4d5fb8ba 100644 |
--- a/content/renderer/render_view_impl.cc |
+++ b/content/renderer/render_view_impl.cc |
@@ -647,6 +647,7 @@ RenderViewImpl::RenderViewImpl(RenderViewImplParams* params) |
history_list_length_(0), |
frames_in_progress_(0), |
target_url_status_(TARGET_NONE), |
+ uses_temporary_zoom_level_(false), |
#if defined(OS_ANDROID) |
top_controls_constraints_(cc::BOTH), |
#endif |
@@ -1077,6 +1078,8 @@ bool RenderViewImpl::OnMessageReceived(const IPC::Message& message) { |
IPC_MESSAGE_HANDLER(ViewMsg_Zoom, OnZoom) |
IPC_MESSAGE_HANDLER(ViewMsg_SetZoomLevelForLoadingURL, |
OnSetZoomLevelForLoadingURL) |
+ IPC_MESSAGE_HANDLER(ViewMsg_SetZoomLevelForView, |
+ OnSetZoomLevelForView) |
IPC_MESSAGE_HANDLER(ViewMsg_SetPageEncoding, OnSetPageEncoding) |
IPC_MESSAGE_HANDLER(ViewMsg_ResetPageEncodingToDefault, |
OnResetPageEncodingToDefault) |
@@ -2640,6 +2643,14 @@ void RenderViewImpl::OnSetZoomLevelForLoadingURL(const GURL& url, |
#endif |
} |
+void RenderViewImpl::OnSetZoomLevelForView(bool uses_temporary_zoom_level, |
+ double level) { |
+ uses_temporary_zoom_level_ = uses_temporary_zoom_level; |
+ |
+ webview()->hidePopups(); |
+ webview()->setZoomLevel(level); |
+} |
+ |
void RenderViewImpl::OnSetPageEncoding(const std::string& encoding_name) { |
webview()->setPageEncoding(WebString::fromUTF8(encoding_name)); |
} |