1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ui/views/controls/menu/menu_config.h"
#include <windows.h>
#include <uxtheme.h>
#include <Vssym32.h>
#include "base/logging.h"
#include "base/win/scoped_gdi_object.h"
#include "base/win/win_util.h"
#include "ui/base/l10n/l10n_util_win.h"
#include "ui/gfx/color_utils.h"
#include "ui/native_theme/native_theme_win.h"
#if defined(USE_AURA)
#include "ui/native_theme/native_theme_aura.h"
#endif
using ui::NativeTheme;
using ui::NativeThemeWin;
namespace views {
void MenuConfig::Init(const NativeTheme* theme) {
#if defined(USE_AURA)
if (theme == ui::NativeThemeAura::instance()) {
InitAura(theme);
return;
}
#endif
text_color = NativeThemeWin::instance()->GetThemeColorWithDefault(
NativeThemeWin::MENU, MENU_POPUPITEM, MPI_NORMAL, TMT_TEXTCOLOR,
COLOR_MENUTEXT);
arrow_color = color_utils::GetSysSkColor(COLOR_MENUTEXT);
NONCLIENTMETRICS metrics;
base::win::GetNonClientMetrics(&metrics);
l10n_util::AdjustUIFont(&(metrics.lfMenuFont));
{
base::win::ScopedHFONT new_font(CreateFontIndirect(&metrics.lfMenuFont));
DLOG_ASSERT(new_font.Get());
font = gfx::Font(new_font);
}
NativeTheme::ExtraParams extra;
extra.menu_check.is_radio = false;
extra.menu_check.is_selected = false;
gfx::Size check_size = NativeThemeWin::instance()->GetPartSize(
NativeTheme::kMenuCheck, NativeTheme::kNormal, extra);
if (!check_size.IsEmpty()) {
check_width = check_size.width();
check_height = check_size.height();
} else {
check_width = GetSystemMetrics(SM_CXMENUCHECK);
check_height = GetSystemMetrics(SM_CYMENUCHECK);
}
extra.menu_check.is_radio = true;
gfx::Size radio_size = NativeThemeWin::instance()->GetPartSize(
NativeTheme::kMenuCheck, NativeTheme::kNormal, extra);
if (!radio_size.IsEmpty()) {
radio_width = radio_size.width();
radio_height = radio_size.height();
} else {
radio_width = GetSystemMetrics(SM_CXMENUCHECK);
radio_height = GetSystemMetrics(SM_CYMENUCHECK);
}
gfx::Size arrow_size = NativeThemeWin::instance()->GetPartSize(
NativeTheme::kMenuPopupArrow, NativeTheme::kNormal, extra);
if (!arrow_size.IsEmpty()) {
arrow_width = arrow_size.width();
arrow_height = arrow_size.height();
} else {
// Sadly I didn't see a specify metrics for this.
arrow_width = GetSystemMetrics(SM_CXMENUCHECK);
arrow_height = GetSystemMetrics(SM_CYMENUCHECK);
}
BOOL show_cues;
show_mnemonics =
(SystemParametersInfo(SPI_GETKEYBOARDCUES, 0, &show_cues, 0) &&
show_cues == TRUE);
SystemParametersInfo(SPI_GETMENUSHOWDELAY, 0, &show_delay, 0);
}
// static
const MenuConfig& MenuConfig::instance(const ui::NativeTheme* theme) {
// NOTE: |theme| may be NULL if used before the menu is running.
if (!theme || theme == NativeThemeWin::instance()) {
static MenuConfig* win_instance = NULL;
if (!win_instance)
win_instance = new MenuConfig(NativeThemeWin::instance());
return *win_instance;
}
static MenuConfig* views_instance = NULL;
if (!views_instance)
views_instance = new MenuConfig(theme);
return *views_instance;
}
} // namespace views
|