OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "ash/common/system/chromeos/palette/common_palette_tool.h" | 5 #include "ash/common/system/chromeos/palette/common_palette_tool.h" |
6 | 6 |
7 #include "ash/common/shelf/shelf_constants.h" | 7 #include "ash/common/shelf/shelf_constants.h" |
8 #include "ash/common/system/chromeos/palette/palette_ids.h" | 8 #include "ash/common/system/chromeos/palette/palette_ids.h" |
9 #include "ash/common/system/chromeos/palette/palette_tool_manager.h" | 9 #include "ash/common/system/chromeos/palette/palette_tool_manager.h" |
10 #include "ash/common/system/tray/hover_highlight_view.h" | 10 #include "ash/common/system/tray/hover_highlight_view.h" |
| 11 #include "ash/common/system/tray/tray_constants.h" |
11 #include "ash/common/system/tray/view_click_listener.h" | 12 #include "ash/common/system/tray/view_click_listener.h" |
12 #include "base/logging.h" | 13 #include "base/logging.h" |
13 #include "base/metrics/histogram_macros.h" | 14 #include "base/metrics/histogram_macros.h" |
14 #include "base/strings/utf_string_conversions.h" | 15 #include "base/strings/utf_string_conversions.h" |
15 #include "grit/ash_resources.h" | 16 #include "grit/ash_resources.h" |
16 #include "ui/base/resource/resource_bundle.h" | 17 #include "ui/base/resource/resource_bundle.h" |
17 #include "ui/gfx/color_palette.h" | 18 #include "ui/gfx/color_palette.h" |
18 #include "ui/gfx/paint_vector_icon.h" | 19 #include "ui/gfx/paint_vector_icon.h" |
19 #include "ui/gfx/vector_icons_public.h" | 20 #include "ui/gfx/vector_icons_public.h" |
20 #include "ui/views/border.h" | 21 #include "ui/views/border.h" |
21 | 22 |
22 namespace ash { | 23 namespace ash { |
23 namespace { | 24 namespace { |
24 | 25 |
25 // Size of the icons in DP. | |
26 const int kIconSize = 20; | |
27 | |
28 // Distance between the icon and the check from the egdes in DP. | |
29 const int kMarginFromEdges = 14; | |
30 | |
31 // Extra distance between the icon and the left edge in DP. | |
32 const int kExtraMarginFromLeftEdge = 4; | |
33 | |
34 // Distance between the icon and the name of the tool in DP. | |
35 const int kMarginBetweenIconAndText = 18; | |
36 | |
37 void AddHistogramTimes(PaletteToolId id, base::TimeDelta duration) { | 26 void AddHistogramTimes(PaletteToolId id, base::TimeDelta duration) { |
38 if (id == PaletteToolId::LASER_POINTER) { | 27 if (id == PaletteToolId::LASER_POINTER) { |
39 UMA_HISTOGRAM_CUSTOM_TIMES("Ash.Shelf.Palette.InLaserPointerMode", duration, | 28 UMA_HISTOGRAM_CUSTOM_TIMES("Ash.Shelf.Palette.InLaserPointerMode", duration, |
40 base::TimeDelta::FromMilliseconds(100), | 29 base::TimeDelta::FromMilliseconds(100), |
41 base::TimeDelta::FromHours(1), 50); | 30 base::TimeDelta::FromHours(1), 50); |
42 } else if (id == PaletteToolId::MAGNIFY) { | 31 } else if (id == PaletteToolId::MAGNIFY) { |
43 UMA_HISTOGRAM_CUSTOM_TIMES("Ash.Shelf.Palette.InMagnifyMode", duration, | 32 UMA_HISTOGRAM_CUSTOM_TIMES("Ash.Shelf.Palette.InMagnifyMode", duration, |
44 base::TimeDelta::FromMilliseconds(100), | 33 base::TimeDelta::FromMilliseconds(100), |
45 base::TimeDelta::FromHours(1), 50); | 34 base::TimeDelta::FromHours(1), 50); |
46 } | 35 } |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
91 delegate()->RecordPaletteModeCancellation( | 80 delegate()->RecordPaletteModeCancellation( |
92 PaletteToolIdToPaletteModeCancelType(GetToolId(), | 81 PaletteToolIdToPaletteModeCancelType(GetToolId(), |
93 false /*is_switched*/)); | 82 false /*is_switched*/)); |
94 } else { | 83 } else { |
95 delegate()->EnableTool(GetToolId()); | 84 delegate()->EnableTool(GetToolId()); |
96 } | 85 } |
97 } | 86 } |
98 | 87 |
99 views::View* CommonPaletteTool::CreateDefaultView(const base::string16& name) { | 88 views::View* CommonPaletteTool::CreateDefaultView(const base::string16& name) { |
100 gfx::ImageSkia icon = | 89 gfx::ImageSkia icon = |
101 CreateVectorIcon(GetPaletteIcon(), kIconSize, gfx::kChromeIconGrey); | 90 CreateVectorIcon(GetPaletteIcon(), kMenuIconSize, gfx::kChromeIconGrey); |
102 gfx::ImageSkia check = CreateVectorIcon(gfx::VectorIconId::CHECK_CIRCLE, | 91 gfx::ImageSkia check = CreateVectorIcon(gfx::VectorIconId::CHECK_CIRCLE, |
103 kIconSize, gfx::kGoogleGreen700); | 92 kMenuIconSize, gfx::kGoogleGreen700); |
104 | 93 |
105 highlight_view_ = new HoverHighlightView(this); | 94 highlight_view_ = new HoverHighlightView(this); |
106 highlight_view_->SetBorder( | 95 highlight_view_->SetBorder( |
107 views::Border::CreateEmptyBorder(0, kExtraMarginFromLeftEdge, 0, 0)); | 96 views::Border::CreateEmptyBorder(0, kMenuSeparatorVerticalPadding, 0, 0)); |
108 highlight_view_->AddIconAndLabelCustomSize(icon, name, false, kIconSize, | 97 const int interior_button_padding = (kMenuButtonSize - kMenuIconSize) / 2; |
109 kMarginFromEdges, | 98 highlight_view_->AddIconAndLabelCustomSize( |
110 kMarginBetweenIconAndText); | 99 icon, name, false, kMenuIconSize, interior_button_padding, |
111 highlight_view_->AddRightIcon(check, kIconSize); | 100 interior_button_padding + kMenuSeparatorVerticalPadding); |
| 101 highlight_view_->AddRightIcon(check, kMenuIconSize); |
112 | 102 |
113 if (enabled()) | 103 if (enabled()) |
114 highlight_view_->SetHighlight(true); | 104 highlight_view_->SetHighlight(true); |
115 else | 105 else |
116 highlight_view_->SetRightIconVisible(false); | 106 highlight_view_->SetRightIconVisible(false); |
117 | 107 |
118 return highlight_view_; | 108 return highlight_view_; |
119 } | 109 } |
120 | 110 |
121 } // namespace ash | 111 } // namespace ash |
OLD | NEW |