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

Side by Side Diff: ui/views/layout/layout_delegate.cc

Issue 2758323002: Broke out layout metric information from ViewsDelegate to LayoutProvider (Closed)
Patch Set: Addressed Feedback. Renamed ViewsLayoutDelegate to LayoutDelegate and ChromeViewsLayoutDelegate to … Created 3 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "ui/views/layout/layout_delegate.h"
6
7 #include "base/logging.h"
8 #include "base/memory/ptr_util.h"
9 #include "ui/base/material_design/material_design_controller.h"
10 #include "ui/views/layout/layout_constants.h"
11 #include "ui/views/views_delegate.h"
12
13 namespace views {
14
15 namespace {
16 static LayoutDelegate* g_layout_delegate = nullptr;
17 static DefaultTypographyProvider g_typography_provider;
18 }
19
20 LayoutDelegate::LayoutDelegate() {
21 g_layout_delegate = this;
22 }
23
24 LayoutDelegate::~LayoutDelegate() {
25 if (this == g_layout_delegate)
26 g_layout_delegate = nullptr;
27 }
28
29 // static
30 LayoutDelegate* LayoutDelegate::Get() {
31 return g_layout_delegate;
32 }
33
34 gfx::Insets LayoutDelegate::GetInsetsMetric(InsetsMetric metric) const {
35 switch (metric) {
36 case InsetsMetric::DIALOG_BUTTON:
37 return gfx::Insets(0, kButtonHEdgeMarginNew, kButtonVEdgeMarginNew,
38 kButtonHEdgeMarginNew);
39 case InsetsMetric::DIALOG_FRAME_VIEW:
40 return gfx::Insets(kPanelVertMargin, kButtonHEdgeMarginNew, 0,
41 kButtonHEdgeMarginNew);
42 case InsetsMetric::BUBBLE_DIALOG:
43 return gfx::Insets(kPanelVertMargin, kPanelHorizMargin);
44 case InsetsMetric::PANEL:
45 return gfx::Insets(kPanelVertMargin, kButtonHEdgeMarginNew);
46 case InsetsMetric::VECTOR_IMAGE_BUTTON:
47 return gfx::Insets(kVectorButtonExtraTouchSize);
48 }
49 NOTREACHED();
50 return gfx::Insets();
51 }
52
53 int LayoutDelegate::GetDistanceMetric(DistanceMetric metric) const {
54 switch (metric) {
55 case DistanceMetric::CLOSE_BUTTON_MARGIN:
56 return kCloseButtonMargin;
57 case DistanceMetric::RELATED_BUTTON_HORIZONTAL:
58 return kRelatedButtonHSpacing;
59 case DistanceMetric::RELATED_CONTROL_HORIZONTAL:
60 return kRelatedControlHorizontalSpacing;
61 case DistanceMetric::RELATED_CONTROL_VERTICAL:
62 return kRelatedControlVerticalSpacing;
63 case DistanceMetric::DIALOG_BUTTON_MINIMUM_WIDTH:
64 return kDialogMinimumButtonWidth;
65 case DistanceMetric::BUTTON_HORIZONTAL_PADDING:
66 return kButtonHorizontalPadding;
67 }
68 NOTREACHED();
69 return 0;
70 }
71
72 const TypographyProvider& LayoutDelegate::GetTypographyProvider() const {
73 return g_typography_provider;
74 }
75
76 } // namespace views
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698