diff options
author | aa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-25 21:50:56 +0000 |
---|---|---|
committer | aa@chromium.org <aa@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-25 21:50:56 +0000 |
commit | fa9a74f565c1c99e64b9dd0e65b63d75e55f11e7 (patch) | |
tree | d745d79c9753bb7fea4e3a77ecd2a680003df1e7 | |
parent | 66d202e51a6b195d0b738d3f6cfcf23059ce5534 (diff) | |
download | chromium_src-fa9a74f565c1c99e64b9dd0e65b63d75e55f11e7.zip chromium_src-fa9a74f565c1c99e64b9dd0e65b63d75e55f11e7.tar.gz chromium_src-fa9a74f565c1c99e64b9dd0e65b63d75e55f11e7.tar.bz2 |
Make --show-extensions-on-top look exactly, pixel-for-pixel
identical to the bookmark bar.
Used the same semi-transparent image for the button background
that the bookmarkbar uses, so that it will work for themes.
The upside of this is that we look the same as the bookmark bar. The downside is that we look the same as the bookmark bar (which currently looks pretty bad with some themes).
However, with the default theme, I think that the bookmark bar currently looks better than our toolstrips. The UI team should probably create some images that look good with different themes for the bookmark bar, then we can update this again.
Review URL: http://codereview.chromium.org/225025
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@27258 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/views/extensions/extension_shelf.cc | 19 | ||||
-rw-r--r-- | chrome/browser/views/extensions/extension_shelf.h | 4 | ||||
-rw-r--r-- | chrome/renderer/resources/extension_toolstrip.css | 41 |
3 files changed, 40 insertions, 24 deletions
diff --git a/chrome/browser/views/extensions/extension_shelf.cc b/chrome/browser/views/extensions/extension_shelf.cc index efab520..10ce48d 100644 --- a/chrome/browser/views/extensions/extension_shelf.cc +++ b/chrome/browser/views/extensions/extension_shelf.cc @@ -31,7 +31,8 @@ namespace { // Margins around the content. -static const int kTopMargin = 2; +static const int kTopMarginWhenExtensionsOnTop = 1; +static const int kTopMarginWhenExtensionsOnBottom = 2; static const int kBottomMargin = 2; static const int kLeftMargin = 0; static const int kRightMargin = 0; @@ -59,9 +60,6 @@ static const int kNewtabVerticalPadding = 12; static const int kNewtabExtraHorMargin = 2; static const int kNewtabExtraVerMargin = 2; -// Height of the toolstrip within the shelf. -static const int kToolstripHeight = kShelfHeight - (kTopMargin + kBottomMargin); - // Padding for the title inside the handle. static const int kHandlePadding = 4; @@ -636,7 +634,8 @@ void ExtensionShelf::Toolstrip::Collapse(const GURL& url) { mole_animation_->Hide(); gfx::Size extension_size = view()->GetPreferredSize(); - extension_size.set_height(kToolstripHeight); + extension_size.set_height( + kShelfHeight - (shelf_->top_margin() + kBottomMargin)); view()->SetPreferredSize(extension_size); if (!url.is_empty() && url != host_->GetURL()) { @@ -684,6 +683,12 @@ ExtensionShelf::ExtensionShelf(Browser* browser) model_(browser->extension_shelf_model()), fullscreen_(false) { SetID(VIEW_ID_DEV_EXTENSION_SHELF); + + if (IsOnTop()) + top_margin_ = kTopMarginWhenExtensionsOnTop; + else + top_margin_ = kTopMarginWhenExtensionsOnBottom; + model_->AddObserver(this); LoadFromModel(); EnableCanvasFlippingForRTLUI(true); @@ -1035,8 +1040,8 @@ gfx::Size ExtensionShelf::LayoutItems(bool compute_bounds_only) { gfx::Size prefsize; int x = kLeftMargin; - int y = kTopMargin; - int content_height = kShelfHeight - kTopMargin - kBottomMargin; + int y = top_margin_; + int content_height = kShelfHeight - top_margin_ - kBottomMargin; int max_x = width() - kRightMargin; if (OnNewTabPage()) { diff --git a/chrome/browser/views/extensions/extension_shelf.h b/chrome/browser/views/extensions/extension_shelf.h index 450e025..08de605 100644 --- a/chrome/browser/views/extensions/extension_shelf.h +++ b/chrome/browser/views/extensions/extension_shelf.h @@ -36,6 +36,8 @@ class ExtensionShelf : public DetachableToolbarView, // Toggles a preference for whether to always show the extension shelf. static void ToggleWhenExtensionShelfVisible(Profile* profile); + int top_margin() { return top_margin_; } + // DetachableToolbarView methods: virtual bool IsOnTop() const; virtual bool IsDetached() const; @@ -130,6 +132,8 @@ class ExtensionShelf : public DetachableToolbarView, // page. bool OnNewTabPage() const; + int top_margin_; + NotificationRegistrar registrar_; // Background bitmap to draw under extension views. diff --git a/chrome/renderer/resources/extension_toolstrip.css b/chrome/renderer/resources/extension_toolstrip.css index cb99470..a798239 100644 --- a/chrome/renderer/resources/extension_toolstrip.css +++ b/chrome/renderer/resources/extension_toolstrip.css @@ -48,10 +48,12 @@ body>style { div.toolstrip-button { -webkit-box-orient:horizontal; -webkit-box-align:center; - border:6px solid transparent; + -webkit-box-sizing:border-box; + border:7px solid transparent; font:menu; background:transparent; line-height:100%; + height:100%; padding:0; } @@ -60,34 +62,39 @@ div.toolstrip-button>img { width:16px; height:16px; /** - * We inset the image slightly vertically, so that the button can be shorter - * than would otherwise be possibe with our fat borders. + * We inset the image slightly, so that the button can be shorter + * than would otherwise be possibe with our fat borders. The 5px right border + * just creates the spacing between the icon and the text. */ - margin:-1px 5px -1px 0; + margin:-2px 5px -2px -1px; } div.toolstrip-button>span { display:-webkit-box; - margin-right:1px; - /** - * Hack: WebKit appears to measure text height slightly differently than we do - * in native code, making us not line up when centering, so we shift ourselves - * up one pixel to match. - */ + margin-right:1px;
+ /**
+ * Hack: WebKit appears to measure text height slightly differently than we do
+ * in native code, making us not line up when centering, so we shift ourselves
+ * up one pixel to match.
+ */
margin-top:-1px; } /** - * TODO(aa): It would be nice if these border images could be stored in Chrome - * as, normal images even if those images are just translated into data URLs at - * runtime. + * NOTE: These images were created by pasting src/app/resources/textbutton_* + * into a 15px square 9 grid. If they look funky, check to see if they match + * the bookmark buttons. If they don't, they probably need to be regenerated. + * + * TODO(aa): It would be neat-o if these were generated magically from the + * underlying images. Since the dimensions of the images are arbitrary, though, + * it would be tricky. */ div.toolstrip-button:hover { - border-width:6px; - -webkit-border-image:url() 6 round round; + border-width:7px; + -webkit-border-image:url() 7 round round; } div.toolstrip-button:active { - border-width:6px; - -webkit-border-image:url() 6 round round; + border-width:7px; + -webkit-border-image:url() 7 round round; } |