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

Side by Side Diff: ash/ash_touch_exploration_manager_chromeos.cc

Issue 410783002: Corner Passthrough for Accessibility (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@side-gestures
Patch Set: Fixed some rebase quirks Created 6 years, 4 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
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 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/ash_touch_exploration_manager_chromeos.h" 5 #include "ash/ash_touch_exploration_manager_chromeos.h"
6 6
7 #include "ash/accessibility_delegate.h" 7 #include "ash/accessibility_delegate.h"
8 #include "ash/audio/sounds.h" 8 #include "ash/audio/sounds.h"
9 #include "ash/root_window_controller.h" 9 #include "ash/root_window_controller.h"
10 #include "ash/shell.h" 10 #include "ash/shell.h"
(...skipping 19 matching lines...) Expand all
30 Shell::GetInstance()->system_tray_notifier(); 30 Shell::GetInstance()->system_tray_notifier();
31 if (system_tray_notifier) 31 if (system_tray_notifier)
32 system_tray_notifier->RemoveAccessibilityObserver(this); 32 system_tray_notifier->RemoveAccessibilityObserver(this);
33 } 33 }
34 34
35 void AshTouchExplorationManager::OnAccessibilityModeChanged( 35 void AshTouchExplorationManager::OnAccessibilityModeChanged(
36 AccessibilityNotificationVisibility notify) { 36 AccessibilityNotificationVisibility notify) {
37 UpdateTouchExplorationState(); 37 UpdateTouchExplorationState();
38 } 38 }
39 39
40 void AshTouchExplorationManager::PlayVolumeAdjustSound() {
41 if (!VolumeAdjustSoundEnabled())
42 return;
43 if ((!audio_handler_->IsOutputMuted()) ||
44 !(audio_handler_->GetOutputVolumePercent() == 100))
45 PlaySystemSoundIfSpokenFeedback(chromeos::SOUND_VOLUME_ADJUST);
46 }
47
48 void AshTouchExplorationManager::SetOutputLevel(int volume) { 40 void AshTouchExplorationManager::SetOutputLevel(int volume) {
49 if (volume > 0) { 41 if (volume > 0) {
50 if (audio_handler_->IsOutputMuted()) { 42 if (audio_handler_->IsOutputMuted()) {
51 audio_handler_->SetOutputMute(false); 43 audio_handler_->SetOutputMute(false);
52 } 44 }
53 } 45 }
54 audio_handler_->SetOutputVolumePercent(volume); 46 audio_handler_->SetOutputVolumePercent(volume);
55 // Avoid negative volume. 47 // Avoid negative volume.
56 if (audio_handler_->IsOutputVolumeBelowDefaultMuteLevel()) 48 if (audio_handler_->IsOutputVolumeBelowDefaultMuteLevel())
57 audio_handler_->SetOutputMute(true); 49 audio_handler_->SetOutputMute(true);
58 } 50 }
59 51
52 void AshTouchExplorationManager::PlayVolumeAdjustEarcon() {
53 if (!VolumeAdjustSoundEnabled())
54 return;
55 if ((!audio_handler_->IsOutputMuted()) ||
James Cook 2014/07/28 19:10:42 Too many parens here: if (!audio_handler_->IsOutp
lisayin 2014/07/28 20:31:27 Done.
56 !(audio_handler_->GetOutputVolumePercent() == 100))
57 PlaySystemSoundIfSpokenFeedback(chromeos::SOUND_VOLUME_ADJUST);
58 }
59
60 void AshTouchExplorationManager::PlayPassthroughEarcon() {
61 Shell::GetInstance()->accessibility_delegate()->PlayEarcon(
62 chromeos::SOUND_PASSTHROUGH);
63 }
64 void AshTouchExplorationManager::PlayExitScreenEarcon() {
James Cook 2014/07/28 19:10:42 nit: blank line above
lisayin 2014/07/28 20:31:28 Done.
65 Shell::GetInstance()->accessibility_delegate()->PlayEarcon(
66 chromeos::SOUND_EXIT_SCREEN);
67 }
68
69 void AshTouchExplorationManager::PlayEnterScreenEarcon() {
70 Shell::GetInstance()->accessibility_delegate()->PlayEarcon(
71 chromeos::SOUND_ENTER_SCREEN);
72 }
73
60 void AshTouchExplorationManager::UpdateTouchExplorationState() { 74 void AshTouchExplorationManager::UpdateTouchExplorationState() {
61 AccessibilityDelegate* delegate = 75 AccessibilityDelegate* delegate =
62 Shell::GetInstance()->accessibility_delegate(); 76 Shell::GetInstance()->accessibility_delegate();
63 bool enabled = delegate->IsSpokenFeedbackEnabled(); 77 bool enabled = delegate->IsSpokenFeedbackEnabled();
64 78
65 if (enabled && !touch_exploration_controller_.get()) { 79 if (enabled && !touch_exploration_controller_.get()) {
66 touch_exploration_controller_.reset(new ui::TouchExplorationController( 80 touch_exploration_controller_.reset(new ui::TouchExplorationController(
67 root_window_controller_->GetRootWindow(), this)); 81 root_window_controller_->GetRootWindow(), this));
68 } else if (!enabled) { 82 } else if (!enabled) {
69 touch_exploration_controller_.reset(); 83 touch_exploration_controller_.reset();
70 } 84 }
71 } 85 }
72 86
73 bool AshTouchExplorationManager::VolumeAdjustSoundEnabled() { 87 bool AshTouchExplorationManager::VolumeAdjustSoundEnabled() {
74 return !CommandLine::ForCurrentProcess()->HasSwitch( 88 return !CommandLine::ForCurrentProcess()->HasSwitch(
75 chromeos::switches::kDisableVolumeAdjustSound); 89 chromeos::switches::kDisableVolumeAdjustSound);
76 } 90 }
77 91
78 } // namespace ash 92 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698