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

Side by Side Diff: ash/common/system/chromeos/media_security/multi_profile_media_tray_item.cc

Issue 2732813002: chromeos: Move files in //ash/common to //ash, part 1 (Closed)
Patch Set: rebase Created 3 years, 9 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 2014 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 "ash/common/system/chromeos/media_security/multi_profile_media_tray_ite m.h"
6
7 #include "ash/common/ash_view_ids.h"
8 #include "ash/common/media_controller.h"
9 #include "ash/common/session/session_state_delegate.h"
10 #include "ash/common/system/tray/system_tray_notifier.h"
11 #include "ash/common/system/tray/tray_constants.h"
12 #include "ash/common/system/tray/tray_item_view.h"
13 #include "ash/common/wm_shell.h"
14 #include "ash/resources/grit/ash_resources.h"
15 #include "ash/resources/vector_icons/vector_icons.h"
16 #include "ui/base/resource/resource_bundle.h"
17 #include "ui/gfx/paint_vector_icon.h"
18 #include "ui/views/controls/image_view.h"
19
20 namespace ash {
21 namespace tray {
22
23 class MultiProfileMediaTrayView : public TrayItemView,
24 public MediaCaptureObserver {
25 public:
26 explicit MultiProfileMediaTrayView(SystemTrayItem* system_tray_item)
27 : TrayItemView(system_tray_item) {
28 CreateImageView();
29 ui::ResourceBundle& bundle = ui::ResourceBundle::GetSharedInstance();
30 image_view()->SetImage(
31 UseMd()
32 ? gfx::CreateVectorIcon(kSystemTrayRecordingIcon, kTrayIconColor)
33 : *bundle.GetImageSkiaNamed(IDR_AURA_UBER_TRAY_RECORDING));
34 WmShell::Get()->media_controller()->AddObserver(this);
35 SetVisible(false);
36 WmShell::Get()->media_controller()->RequestCaptureState();
37 set_id(VIEW_ID_MEDIA_TRAY_VIEW);
38 }
39
40 ~MultiProfileMediaTrayView() override {
41 WmShell::Get()->media_controller()->RemoveObserver(this);
42 }
43
44 // MediaCaptureObserver:
45 void OnMediaCaptureChanged(
46 const std::vector<mojom::MediaCaptureState>& capture_states) override {
47 SessionStateDelegate* session_state_delegate =
48 WmShell::Get()->GetSessionStateDelegate();
49 // The user at 0 is the current desktop user.
50 for (UserIndex index = 1;
51 index < session_state_delegate->NumberOfLoggedInUsers(); ++index) {
52 if (capture_states[index] != mojom::MediaCaptureState::NONE) {
53 SetVisible(true);
54 return;
55 }
56 }
57 SetVisible(false);
58 }
59
60 private:
61 DISALLOW_COPY_AND_ASSIGN(MultiProfileMediaTrayView);
62 };
63
64 } // namespace tray
65
66 MultiProfileMediaTrayItem::MultiProfileMediaTrayItem(SystemTray* system_tray)
67 : SystemTrayItem(system_tray, UMA_MULTI_PROFILE_MEDIA) {}
68
69 MultiProfileMediaTrayItem::~MultiProfileMediaTrayItem() {}
70
71 views::View* MultiProfileMediaTrayItem::CreateTrayView(LoginStatus status) {
72 return new tray::MultiProfileMediaTrayView(this);
73 }
74
75 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698