Home | History | Annotate | Download | only in dbus
      1 // Copyright (c) 2013 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 #ifndef CHROMEOS_DBUS_CRAS_AUDIO_CLIENT_H_
      6 #define CHROMEOS_DBUS_CRAS_AUDIO_CLIENT_H_
      7 
      8 #include "base/callback.h"
      9 #include "base/observer_list.h"
     10 #include "chromeos/chromeos_export.h"
     11 #include "chromeos/dbus/audio_node.h"
     12 #include "chromeos/dbus/dbus_client.h"
     13 #include "chromeos/dbus/volume_state.h"
     14 
     15 namespace chromeos {
     16 
     17 // CrasAudioClient is used to communicate with the cras audio dbus interface.
     18 class CHROMEOS_EXPORT CrasAudioClient : public DBusClient {
     19  public:
     20   // Interface for observing changes from the cras audio changes.
     21   class Observer {
     22    public:
     23     // Called when cras audio client starts or re-starts, which happens when
     24     // cros device powers up or restarted.
     25     virtual void AudioClientRestarted();
     26 
     27     // Called when audio output mute state changed to new state of |mute_on|.
     28     virtual void OutputMuteChanged(bool mute_on);
     29 
     30     // Called when audio input mute state changed to new state of |mute_on|.
     31     virtual void InputMuteChanged(bool mute_on);
     32 
     33     // Called when audio nodes change.
     34     virtual void NodesChanged();
     35 
     36     // Called when active audio output node changed to new node with |node_id|.
     37     virtual void ActiveOutputNodeChanged(uint64 node_id);
     38 
     39     // Called when active audio input node changed to new node with |node_id|.
     40     virtual void ActiveInputNodeChanged(uint64 node_id);
     41 
     42    protected:
     43     virtual ~Observer();
     44   };
     45 
     46   virtual ~CrasAudioClient();
     47 
     48   // Adds and removes the observer.
     49   virtual void AddObserver(Observer* observer) = 0;
     50   virtual void RemoveObserver(Observer* observer) = 0;
     51   // Returns true if this object has the given observer.
     52   virtual bool HasObserver(Observer* observer) = 0;
     53 
     54   // GetVolumeStateCallback is used for GetVolumeState method. It receives
     55   // 2 arguments, |volume_state| which containing both input and  output volume
     56   // state data, and |success| which indicates whether or not the request
     57   // succeeded.
     58   typedef base::Callback<void(const VolumeState&, bool)> GetVolumeStateCallback;
     59 
     60   // GetNodesCallback is used for GetNodes method. It receives 2 arguments,
     61   // |audio_nodes| which containing a list of audio nodes data and
     62   // |success| which indicates whether or not the request succeeded.
     63   typedef base::Callback<void(const AudioNodeList&, bool)> GetNodesCallback;
     64 
     65   // ErrorCallback is used for cras dbus method error response. It receives 2
     66   // arguments, |error_name| indicates the dbus error name, and |error_message|
     67   // contains the detailed dbus error message.
     68   typedef base::Callback<void(const std::string&,
     69                               const std::string&)> ErrorCallback;
     70 
     71   // Gets the volume state, asynchronously.
     72   virtual void GetVolumeState(const GetVolumeStateCallback& callback) = 0;
     73 
     74   // Gets an array of audio input and output nodes.
     75   virtual void GetNodes(const GetNodesCallback& callback,
     76                         const ErrorCallback& error_callback) = 0;
     77 
     78   // Sets output volume of the given |node_id| to |volume|, in the rage of
     79   // [0, 100].
     80   virtual void SetOutputNodeVolume(uint64 node_id, int32 volume) = 0;
     81 
     82   // Sets output mute from user action.
     83   virtual void SetOutputUserMute(bool mute_on) = 0;
     84 
     85   // Sets input gain of the given |node_id| to |gain|, in the range of
     86   // [0, 100].
     87   virtual void SetInputNodeGain(uint64 node_id, int32 gain) = 0;
     88 
     89   // Sets input mute state to |mute_on| value.
     90   virtual void SetInputMute(bool mute_on) = 0;
     91 
     92   // Sets the active output node to |node_id|.
     93   virtual void SetActiveOutputNode(uint64 node_id) = 0;
     94 
     95   // Sets the primary active input node to |node_id|.
     96   virtual void SetActiveInputNode(uint64 node_id) = 0;
     97 
     98   // Adds input node |node_id| to the active input list. This is used to add
     99   // an additional active input node besides the one set by SetActiveInputNode.
    100   // Note that this action will not trigger an ActiveInputNodeChanged event and
    101   // nothing will happen if the |node_id| has already been set as active.
    102   virtual void AddActiveInputNode(uint64 node_id) = 0;
    103 
    104   // Removes input node |node_id| from the active input list. This is used for
    105   // removing an active input node added by AddActiveInputNode.
    106   virtual void RemoveActiveInputNode(uint64 node_id) = 0;
    107 
    108   // Adds input node |node_id| to the active outputs list. This is used to add
    109   // an additional active output node besides the one set by SetActiveInputNode.
    110   // Note that this action will not trigger an ActiveOutputNodeChanged event
    111   // and nothing will happen if the |node_id| has already been set as active.
    112   virtual void AddActiveOutputNode(uint64 node_id) = 0;
    113 
    114   // Removes output node |node_id| from the active output list. This is used for
    115   // removing an active output node added by AddActiveOutputNode.
    116   virtual void RemoveActiveOutputNode(uint64 node_id) = 0;
    117 
    118   // Creates the instance.
    119   static CrasAudioClient* Create();
    120 
    121  protected:
    122   // Create() should be used instead.
    123   CrasAudioClient();
    124 
    125  private:
    126   DISALLOW_COPY_AND_ASSIGN(CrasAudioClient);
    127 };
    128 
    129 }  // namespace chromeos
    130 
    131 #endif  // CHROMEOS_DBUS_CRAS_AUDIO_CLIENT_H_
    132