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

Unified Diff: chrome/browser/ui/views/infobars/infobar_background.cc

Issue 1826653002: Draw infobar arrow border with width of 1px on any scale factor. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: format Created 4 years, 8 months 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
Index: chrome/browser/ui/views/infobars/infobar_background.cc
diff --git a/chrome/browser/ui/views/infobars/infobar_background.cc b/chrome/browser/ui/views/infobars/infobar_background.cc
index 7e9fe105f810af8ee28893f3064b0fc34bf69ece..8e732f7bad715db346865243ac35821ecf4e25e9 100644
--- a/chrome/browser/ui/views/infobars/infobar_background.cc
+++ b/chrome/browser/ui/views/infobars/infobar_background.cc
@@ -8,14 +8,15 @@
#include "chrome/browser/ui/views/infobars/infobar_view.h"
#include "components/infobars/core/infobar.h"
#include "third_party/skia/include/effects/SkGradientShader.h"
+#include "ui/base/material_design/material_design_controller.h"
#include "ui/gfx/canvas.h"
#include "ui/gfx/color_utils.h"
+#include "ui/gfx/scoped_canvas.h"
#include "ui/views/view.h"
InfoBarBackground::InfoBarBackground(
infobars::InfoBarDelegate::Type infobar_type)
- : separator_color_(SK_ColorBLACK),
- top_color_(infobars::InfoBar::GetTopColor(infobar_type)),
+ : top_color_(infobars::InfoBar::GetTopColor(infobar_type)),
bottom_color_(infobars::InfoBar::GetBottomColor(infobar_type)) {
SetNativeControlColor(
color_utils::AlphaBlend(top_color_, bottom_color_, 128));
@@ -25,25 +26,31 @@ InfoBarBackground::~InfoBarBackground() {
}
void InfoBarBackground::Paint(gfx::Canvas* canvas, views::View* view) const {
+ if (ui::MaterialDesignController::IsModeMaterial()) {
+ PaintMd(canvas, view);
+ return;
+ }
+
SkPoint gradient_points[2];
gradient_points[0].iset(0, 0);
gradient_points[1].iset(0, view->height());
- SkColor gradient_colors[2] = { top_color_, bottom_color_ };
+ SkColor gradient_colors[2] = {top_color_, bottom_color_};
SkPaint paint;
paint.setStrokeWidth(
SkIntToScalar(InfoBarContainerDelegate::kSeparatorLineHeight));
paint.setStyle(SkPaint::kFill_Style);
paint.setStrokeCap(SkPaint::kRound_Cap);
paint.setShader(SkGradientShader::MakeLinear(
- gradient_points, gradient_colors, NULL, 2, SkShader::kClamp_TileMode));
+ gradient_points, gradient_colors, nullptr, 2, SkShader::kClamp_TileMode));
- InfoBarView* infobar = static_cast<InfoBarView*>(view);
SkCanvas* canvas_skia = canvas->sk_canvas();
+ InfoBarView* infobar = static_cast<InfoBarView*>(view);
canvas_skia->drawPath(infobar->fill_path(), paint);
- paint.setShader(NULL);
- paint.setColor(SkColorSetA(separator_color_,
- SkColorGetA(gradient_colors[0])));
+ paint.setShader(nullptr);
+ SkColor separator_color =
+ infobar->container_delegate()->GetInfoBarSeparatorColor();
+ paint.setColor(SkColorSetA(separator_color, SkColorGetA(gradient_colors[0])));
paint.setStyle(SkPaint::kStroke_Style);
// Anti-alias the path so it doesn't look goofy when the edges are not at 45
// degree angles, but don't anti-alias anything else, especially not the fill,
@@ -57,5 +64,74 @@ void InfoBarBackground::Paint(gfx::Canvas* canvas, views::View* view) const {
gfx::Rect(0,
view->height() - InfoBarContainerDelegate::kSeparatorLineHeight,
view->width(), InfoBarContainerDelegate::kSeparatorLineHeight),
- separator_color_);
+ separator_color);
+}
+
+void InfoBarBackground::PaintMd(gfx::Canvas* canvas, views::View* view) const {
+ InfoBarView* infobar = static_cast<InfoBarView*>(view);
+ const infobars::InfoBarContainer::Delegate* delegate =
+ infobar->container_delegate();
+ SkPath stroke_path, fill_path;
+ SkColor separator_color = SK_ColorBLACK;
+ if (delegate) {
+ separator_color = delegate->GetInfoBarSeparatorColor();
+ int arrow_x;
+ if (delegate->DrawInfoBarArrows(&arrow_x) && infobar->arrow_height() > 0) {
+ SkScalar arrow_fill_height = SkIntToScalar(infobar->arrow_height());
+ SkScalar arrow_fill_half_width =
+ SkIntToScalar(infobar->arrow_half_width());
+ stroke_path.moveTo(SkIntToScalar(arrow_x) - arrow_fill_half_width,
+ SkIntToScalar(infobar->arrow_height()));
+ stroke_path.rLineTo(arrow_fill_half_width, -arrow_fill_height);
+ stroke_path.rLineTo(arrow_fill_half_width, arrow_fill_height);
+
+ fill_path = stroke_path;
+ fill_path.close();
+ }
+ }
+ fill_path.addRect(0, SkIntToScalar(infobar->arrow_height()),
+ SkIntToScalar(infobar->width()),
+ SkIntToScalar(infobar->height()));
+
+ gfx::ScopedCanvas scoped(canvas);
+ // Undo the scale factor so we can stroke with a width of 1px (not 1dp).
+ const float scale = canvas->UndoDeviceScaleFactor();
+ // View bounds are in dp. Manually scale for px.
+ gfx::SizeF view_size_px = gfx::ScaleSize(gfx::SizeF(view->size()), scale);
+
+ SkPaint fill;
+ fill.setStyle(SkPaint::kFill_Style);
+ fill.setColor(top_color_);
+
+ SkCanvas* canvas_skia = canvas->sk_canvas();
+ // The paths provided by the above calculations are in dp. Manually scale for
+ // px.
+ SkMatrix dsf_transform;
+ dsf_transform.setScale(SkFloatToScalar(scale), SkFloatToScalar(scale));
+ fill_path.transform(dsf_transform);
+ // In order to affect exactly the pixels we want, the fill and stroke paths
+ // need to go through the pixel centers instead of along the pixel
+ // edges/corners. Skia considers integral coordinates to be the edges between
+ // pixels, so offset by 0.5 to get to the centers.
+ fill_path.offset(SK_ScalarHalf, SK_ScalarHalf);
+ canvas_skia->drawPath(fill_path, fill);
+
+ SkPaint stroke;
+ stroke.setStyle(SkPaint::kStroke_Style);
+ const int kSeparatorThicknessPx = 1;
+ stroke.setStrokeWidth(SkIntToScalar(kSeparatorThicknessPx));
+ stroke.setColor(separator_color);
+ stroke_path.transform(dsf_transform);
+ stroke_path.offset(SK_ScalarHalf, SK_ScalarHalf);
+
+ // The arrow part of the top separator. (The rest was drawn by the toolbar or
+ // the infobar above this one.)
+ stroke.setAntiAlias(true);
+ canvas_skia->drawPath(stroke_path, stroke);
+ // Bottom separator.
+ stroke.setAntiAlias(false);
+ SkScalar y = SkIntToScalar(view_size_px.height() - kSeparatorThicknessPx) +
+ SK_ScalarHalf;
+ SkScalar w = SkIntToScalar(view_size_px.width());
+ canvas_skia->drawLine(0, y, w, y, stroke);
}
« no previous file with comments | « chrome/browser/ui/views/infobars/infobar_background.h ('k') | chrome/browser/ui/views/infobars/infobar_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698