Chromium Code Reviews| Index: chrome/renderer/chrome_render_view_observer.cc |
| diff --git a/chrome/renderer/chrome_render_view_observer.cc b/chrome/renderer/chrome_render_view_observer.cc |
| index 55b3ddad597430a0fecc7289d7e2a316f4912cdc..360fc5518779227003505579357db58eaf6986ac 100644 |
| --- a/chrome/renderer/chrome_render_view_observer.cc |
| +++ b/chrome/renderer/chrome_render_view_observer.cc |
| @@ -22,6 +22,7 @@ |
| #include "chrome/renderer/chrome_render_process_observer.h" |
| #include "chrome/renderer/content_settings_observer.h" |
| #include "chrome/renderer/extensions/extension_dispatcher.h" |
| +#include "chrome/renderer/extensions/extension_helper.h" |
| #include "chrome/renderer/external_host_bindings.h" |
| #include "chrome/renderer/frame_sniffer.h" |
| #include "chrome/renderer/prerender/prerender_helper.h" |
| @@ -29,6 +30,7 @@ |
| #include "chrome/renderer/translate_helper.h" |
| #include "chrome/renderer/webview_color_overlay.h" |
| #include "content/public/common/bindings_policy.h" |
| +#include "content/public/common/view_type.h" |
| #include "content/public/renderer/render_view.h" |
| #include "content/public/renderer/content_renderer_client.h" |
| #include "net/base/data_url.h" |
| @@ -93,6 +95,10 @@ static const size_t kMaxIndexChars = 65535; |
| static const int kThumbnailWidth = 212; |
| static const int kThumbnailHeight = 132; |
| +// The default layout width for pages when fixed layout is enabled. |
| +static const int kDefaultLayoutWidth = 980; |
| +static const int kDefaultLayoutHeight = 640; |
| + |
| // Constants for UMA statistic collection. |
| static const char kWWWDotGoogleDotCom[] = "www.google.com"; |
| static const char kMailDotGoogleDotCom[] = "mail.google.com"; |
| @@ -372,6 +378,27 @@ void ChromeRenderViewObserver::OnSetAsInterstitial() { |
| } |
| void ChromeRenderViewObserver::Navigate(const GURL& url) { |
| + ExtensionHelper* extension_helper = ExtensionHelper::Get(render_view()); |
|
Aaron Boodman
2012/01/20 18:49:23
What are you trying to do here? It looks to me lik
|
| + bool is_tab_contents = extension_helper && |
| + extension_helper->view_type() == content::VIEW_TYPE_TAB_CONTENTS; |
|
darin (slow to review)
2012/01/20 19:10:20
it seems a little hacky to be using something from
Fady Samuel
2012/01/20 21:05:04
I don't know what the answer to that question is..
jam
2012/01/20 21:08:05
code in the renderer doesn't generally know about
|
| + const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
| + // Only use fixed layout on tab contents. |
| + if (is_tab_contents && cmd_line->HasSwitch(switches::kEnableFixedLayout)) { |
| + WebSize viewSize = render_view()->GetWebView()->size(); |
|
darin (slow to review)
2012/01/20 19:10:20
nit: view_size
Fady Samuel
2012/01/20 21:05:04
Done.
|
| + int layoutHeight = |
|
darin (slow to review)
2012/01/20 19:10:20
nit: layout_height
Fady Samuel
2012/01/20 21:05:04
Done.
|
| + viewSize.height ? |
| + viewSize.height * kDefaultLayoutWidth / viewSize.width : |
| + kDefaultLayoutHeight; |
| + WebSize layout_size(kDefaultLayoutWidth, layoutHeight); |
| + render_view()->GetWebView()->enableFixedLayoutMode(true); |
| + render_view()->GetWebView()->setFixedLayoutSize(layout_size); |
| + render_view()->GetWebView()-> |
| + setShouldLayoutFixedElementsRelativeToFrame(true); |
|
darin (slow to review)
2012/01/20 19:10:20
isn't this done through WebSettings now?
Fady Samuel
2012/01/20 21:05:04
Patch hasn't landed yet. Will fix now. But once i
|
| + } else { |
| + render_view()->GetWebView()->enableFixedLayoutMode(false); |
| + render_view()->GetWebView()-> |
| + setShouldLayoutFixedElementsRelativeToFrame(false); |
| + } |
| // Execute cache clear operations that were postponed until a navigation |
| // event (including tab reload). |
| if (chrome_render_process_observer_) |