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

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: Rebase off Master 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() &&
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
65 void AshTouchExplorationManager::PlayExitScreenEarcon() {
66 Shell::GetInstance()->accessibility_delegate()->PlayEarcon(
67 chromeos::SOUND_EXIT_SCREEN);
68 }
69
70 void AshTouchExplorationManager::PlayEnterScreenEarcon() {
71 Shell::GetInstance()->accessibility_delegate()->PlayEarcon(
72 chromeos::SOUND_ENTER_SCREEN);
73 }
74
60 void AshTouchExplorationManager::UpdateTouchExplorationState() { 75 void AshTouchExplorationManager::UpdateTouchExplorationState() {
61 AccessibilityDelegate* delegate = 76 AccessibilityDelegate* delegate =
62 Shell::GetInstance()->accessibility_delegate(); 77 Shell::GetInstance()->accessibility_delegate();
63 bool enabled = delegate->IsSpokenFeedbackEnabled(); 78 bool enabled = delegate->IsSpokenFeedbackEnabled();
64 79
65 if (enabled && !touch_exploration_controller_.get()) { 80 if (enabled && !touch_exploration_controller_.get()) {
66 touch_exploration_controller_.reset(new ui::TouchExplorationController( 81 touch_exploration_controller_.reset(new ui::TouchExplorationController(
67 root_window_controller_->GetRootWindow(), this)); 82 root_window_controller_->GetRootWindow(), this));
68 } else if (!enabled) { 83 } else if (!enabled) {
69 touch_exploration_controller_.reset(); 84 touch_exploration_controller_.reset();
70 } 85 }
71 } 86 }
72 87
73 bool AshTouchExplorationManager::VolumeAdjustSoundEnabled() { 88 bool AshTouchExplorationManager::VolumeAdjustSoundEnabled() {
74 return !CommandLine::ForCurrentProcess()->HasSwitch( 89 return !CommandLine::ForCurrentProcess()->HasSwitch(
75 chromeos::switches::kDisableVolumeAdjustSound); 90 chromeos::switches::kDisableVolumeAdjustSound);
76 } 91 }
77 92
78 } // namespace ash 93 } // namespace ash
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698