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

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

Issue 2758323002: Broke out layout metric information from ViewsDelegate to LayoutProvider (Closed)
Patch Set: LayoutDelegate -> LayoutProvider 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_provider.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 LayoutProvider* g_layout_delegate = nullptr;
sky 2017/04/12 22:43:57 We generally don't use static in cases like this.
kylix_rd 2017/04/13 16:45:42 Done.
17 }
18
19 LayoutProvider::LayoutProvider() {
20 g_layout_delegate = this;
sky 2017/04/12 22:43:57 DCHECK(g_layout_delegate == nullptr)?
kylix_rd 2017/04/13 16:45:42 This cannot be done because there are cases where
21 }
22
23 LayoutProvider::~LayoutProvider() {
24 if (this == g_layout_delegate)
25 g_layout_delegate = nullptr;
26 }
27
28 // static
29 LayoutProvider* LayoutProvider::Get() {
30 return g_layout_delegate;
31 }
32
33 gfx::Insets LayoutProvider::GetInsetsMetric(int metric) const {
34 DCHECK_LT(metric, VIEWS_INSETS_MAX);
35 switch (metric) {
36 case InsetsMetric::INSETS_DIALOG_BUTTON:
37 return gfx::Insets(0, kButtonHEdgeMarginNew, kButtonVEdgeMarginNew,
38 kButtonHEdgeMarginNew);
39 case InsetsMetric::INSETS_DIALOG_TITLE:
40 return gfx::Insets(kPanelVertMargin, kButtonHEdgeMarginNew, 0,
41 kButtonHEdgeMarginNew);
42 case InsetsMetric::INSETS_BUBBLE_CONTENTS:
43 return gfx::Insets(kPanelVertMargin, kPanelHorizMargin);
44 case InsetsMetric::INSETS_PANEL:
45 return gfx::Insets(kPanelVertMargin, kButtonHEdgeMarginNew);
46 case InsetsMetric::INSETS_VECTOR_IMAGE_BUTTON:
47 return gfx::Insets(kVectorButtonExtraTouchSize);
48 }
49 NOTREACHED();
50 return gfx::Insets();
51 }
52
53 int LayoutProvider::GetDistanceMetric(int metric) const {
54 DCHECK_GE(metric, VIEWS_INSETS_MAX);
55 switch (metric) {
56 case DistanceMetric::DISTANCE_CLOSE_BUTTON_MARGIN:
57 return kCloseButtonMargin;
58 case DistanceMetric::DISTANCE_RELATED_BUTTON_HORIZONTAL:
59 return kRelatedButtonHSpacing;
60 case DistanceMetric::DISTANCE_RELATED_CONTROL_HORIZONTAL:
61 return kRelatedControlHorizontalSpacing;
62 case DistanceMetric::DISTANCE_RELATED_CONTROL_VERTICAL:
63 return kRelatedControlVerticalSpacing;
64 case DistanceMetric::DISTANCE_DIALOG_BUTTON_MINIMUM_WIDTH:
65 return kDialogMinimumButtonWidth;
66 case DistanceMetric::DISTANCE_BUTTON_HORIZONTAL_PADDING:
67 return kButtonHorizontalPadding;
68 }
69 NOTREACHED();
70 return 0;
71 }
72
73 const TypographyProvider& LayoutProvider::GetTypographyProvider() const {
74 return typography_provider_;
75 }
76
77 } // namespace views
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698