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

Unified Diff: chrome/renderer/render_view.cc

Issue 437077: Remember zoom on a per-host basis.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 11 years 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/renderer/render_view.h ('k') | chrome/test/testing_profile.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/renderer/render_view.cc
===================================================================
--- chrome/renderer/render_view.cc (revision 33695)
+++ chrome/renderer/render_view.cc (working copy)
@@ -436,6 +436,8 @@
IPC_MESSAGE_HANDLER(ViewMsg_Find, OnFind)
IPC_MESSAGE_HANDLER(ViewMsg_DeterminePageText, OnDeterminePageText)
IPC_MESSAGE_HANDLER(ViewMsg_Zoom, OnZoom)
+ IPC_MESSAGE_HANDLER(ViewMsg_SetZoomLevelForLoadingHost,
+ OnSetZoomLevelForLoadingHost)
IPC_MESSAGE_HANDLER(ViewMsg_SetPageEncoding, OnSetPageEncoding)
IPC_MESSAGE_HANDLER(ViewMsg_ResetPageEncodingToDefault,
OnResetPageEncodingToDefault)
@@ -1043,6 +1045,17 @@
if (!frame->parent()) {
// Top-level navigation.
+ // Set zoom level.
+ HostZoomLevels::iterator host =
+ host_zoom_levels_.find(GURL(request.url()).host());
+ if (host != host_zoom_levels_.end()) {
+ webview()->setZoomLevel(false, host->second);
+ // This zoom level was merely recorded transiently for this load. We can
+ // erase it now. If at some point we reload this page, the browser will
+ // send us a new, up-to-date zoom level.
+ host_zoom_levels_.erase(host);
+ }
+
// Update contents MIME type for main frame.
params.contents_mime_type = ds->response().mimeType().utf8();
@@ -2132,14 +2145,13 @@
std::vector<GURL> redirects;
GetRedirectChain(data_source, &redirects);
if (redirects.size() >= 2) {
- Send(new ViewHostMsg_DidRedirectProvisionalLoad(
- routing_id_, page_id_, redirects[redirects.size() - 2],
- redirects[redirects.size() - 1]));
+ Send(new ViewHostMsg_DidRedirectProvisionalLoad(routing_id_, page_id_,
+ redirects[redirects.size() - 2], redirects.back()));
}
}
-void RenderView::didFailProvisionalLoad(
- WebFrame* frame, const WebURLError& error) {
+void RenderView::didFailProvisionalLoad(WebFrame* frame,
+ const WebURLError& error) {
// Notify the browser that we failed a provisional load with an error.
//
// Note: It is important this notification occur before DidStopLoading so the
@@ -2220,8 +2232,8 @@
}
}
-void RenderView::didCommitProvisionalLoad(
- WebFrame* frame, bool is_new_navigation) {
+void RenderView::didCommitProvisionalLoad(WebFrame* frame,
+ bool is_new_navigation) {
NavigationState* navigation_state =
NavigationState::FromDataSource(frame->dataSource());
@@ -2963,23 +2975,27 @@
Send(new ViewHostMsg_DnsPrefetch(host_names));
}
-void RenderView::OnZoom(int function) {
- static const bool kZoomIsTextOnly = false;
- switch (function) {
- case PageZoom::SMALLER:
- webview()->zoomOut(kZoomIsTextOnly);
- break;
- case PageZoom::STANDARD:
- webview()->zoomDefault();
- break;
- case PageZoom::LARGER:
- webview()->zoomIn(kZoomIsTextOnly);
- break;
- default:
- NOTREACHED();
- }
+void RenderView::OnZoom(PageZoom::Function function) {
+ if (!webview()) // Not sure if this can happen, but no harm in being safe.
+ return;
+
+ int zoom_level = webview()->zoomLevel();
+ int new_zoom_level = webview()->setZoomLevel(false,
+ (function == PageZoom::RESET) ? 0 : (zoom_level + function));
+
+ // Tell the browser which host got zoomed so it can update the saved values.
+ // Pages like the safe browsing interstitial can have empty hosts; don't
+ // record those.
+ std::string host(GURL(webview()->mainFrame()->url()).host());
+ if (!host.empty())
+ Send(new ViewHostMsg_DidZoomHost(host, new_zoom_level));
}
+void RenderView::OnSetZoomLevelForLoadingHost(std::string host,
+ int zoom_level) {
+ host_zoom_levels_[host] = zoom_level;
+}
+
void RenderView::OnSetPageEncoding(const std::string& encoding_name) {
webview()->setPageEncoding(WebString::fromUTF8(encoding_name));
}
« no previous file with comments | « chrome/renderer/render_view.h ('k') | chrome/test/testing_profile.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698