blob: 501ca4de9cc14273f9e421d56ae97fa59f95297e [file] [log] [blame]
// Copyright 2017 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 <memory>
#include "ash/ash_export.h"
#include "ash/session/session_observer.h"
class PrefChangeRegistrar;
class PrefRegistrySimple;
class PrefService;
namespace ash {
// Different sources for requested touchscreen enabled/disabled state.
enum class TouchscreenEnabledSource {
// User-requested state set via a debug accelerator and stored in a pref.
// Transient global state used to disable touchscreen via power button.
// Controls the enabled state of touchpad and touchscreen. Also controls the
// touch HUD, which draws a circle for each touch tap. The HUD is used for
// demos/presentations because there is no visible cursor to show where taps
// occur. Must be initialized after Shell and SessionController.
class ASH_EXPORT TouchDevicesController : public SessionObserver {
~TouchDevicesController() override;
static void RegisterProfilePrefs(PrefRegistrySimple* registry);
// Toggles the status of touchpad between enabled and disabled.
void ToggleTouchpad();
// Returns the current touchscreen enabled status as specified by |source|.
// Note that the actual state of the touchscreen device is automatically
// determined based on the requests of multiple sources.
bool GetTouchscreenEnabled(TouchscreenEnabledSource source) const;
// Sets |source|'s requested touchscreen enabled status to |enabled|. Note
// that the actual state of the touchscreen device is automatically determined
// based on the requests of multiple sources.
void SetTouchscreenEnabled(bool enabled, TouchscreenEnabledSource source);
bool IsTouchHudProjectionEnabled() const;
void SetTouchHudProjectionEnabled(bool enabled);
// Overridden from SessionObserver:
void OnSigninScreenPrefServiceInitialized(PrefService* prefs) override;
void OnActiveUserPrefServiceChanged(PrefService* prefs) override;
// Observes either the signin screen prefs or active user prefs and loads
// initial state.
void ObservePrefs(PrefService* prefs);
// Updates the actual enabled/disabled status of the touchpad.
void UpdateTouchpadEnabled();
// Updates the actual enabled/disabled status of the touchscreen. Touchscreen
// is enabled if all the touchscreen enabled sources are enabled.
void UpdateTouchscreenEnabled();
// The touchscreen state which is associated with the global touchscreen
// enabled source.
bool global_touchscreen_enabled_ = true;
// Observes user profile prefs for touch devices.
std::unique_ptr<PrefChangeRegistrar> pref_change_registrar_;
} // namespace ash