2011-03-20 18:05:19 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: wx/power.h
|
|
|
|
// Purpose: functions and classes for system power management
|
|
|
|
// Author: Vadim Zeitlin
|
|
|
|
// Modified by:
|
|
|
|
// Created: 2006-05-27
|
|
|
|
// Copyright: (c) 2006 Vadim Zeitlin <vadim@wxwindows.org>
|
|
|
|
// Licence: wxWindows licence
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
#ifndef _WX_POWER_H_
|
|
|
|
#define _WX_POWER_H_
|
|
|
|
|
|
|
|
#include "wx/event.h"
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// power management constants
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
enum wxPowerType
|
|
|
|
{
|
|
|
|
wxPOWER_SOCKET,
|
|
|
|
wxPOWER_BATTERY,
|
|
|
|
wxPOWER_UNKNOWN
|
|
|
|
};
|
|
|
|
|
|
|
|
enum wxBatteryState
|
|
|
|
{
|
|
|
|
wxBATTERY_NORMAL_STATE, // system is fully usable
|
|
|
|
wxBATTERY_LOW_STATE, // start to worry
|
|
|
|
wxBATTERY_CRITICAL_STATE, // save quickly
|
|
|
|
wxBATTERY_SHUTDOWN_STATE, // too late
|
|
|
|
wxBATTERY_UNKNOWN_STATE
|
|
|
|
};
|
|
|
|
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxPowerEvent is generated when the system online status changes
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// currently the power events are only available under Windows, to avoid
|
|
|
|
// compiling in the code for handling them which is never going to be invoked
|
|
|
|
// under the other platforms, we define wxHAS_POWER_EVENTS symbol if this event
|
|
|
|
// is available, it should be used to guard all code using wxPowerEvent
|
2012-03-17 18:12:27 -07:00
|
|
|
#ifdef __WINDOWS__
|
2011-03-20 18:05:19 +00:00
|
|
|
|
|
|
|
#define wxHAS_POWER_EVENTS
|
|
|
|
|
|
|
|
class WXDLLIMPEXP_BASE wxPowerEvent : public wxEvent
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
wxPowerEvent() // just for use by wxRTTI
|
|
|
|
: m_veto(false) { }
|
|
|
|
|
|
|
|
wxPowerEvent(wxEventType evtType) : wxEvent(wxID_NONE, evtType)
|
|
|
|
{
|
|
|
|
m_veto = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Veto the operation (only makes sense with EVT_POWER_SUSPENDING)
|
|
|
|
void Veto() { m_veto = true; }
|
|
|
|
|
|
|
|
bool IsVetoed() const { return m_veto; }
|
|
|
|
|
|
|
|
|
|
|
|
// default copy ctor, assignment operator and dtor are ok
|
|
|
|
|
|
|
|
virtual wxEvent *Clone() const { return new wxPowerEvent(*this); }
|
|
|
|
|
|
|
|
private:
|
|
|
|
bool m_veto;
|
|
|
|
|
2016-06-26 05:25:29 +00:00
|
|
|
wxDECLARE_DYNAMIC_CLASS_NO_ASSIGN(wxPowerEvent);
|
2011-03-20 18:05:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_BASE, wxEVT_POWER_SUSPENDING, wxPowerEvent );
|
|
|
|
wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_BASE, wxEVT_POWER_SUSPENDED, wxPowerEvent );
|
|
|
|
wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_BASE, wxEVT_POWER_SUSPEND_CANCEL, wxPowerEvent );
|
|
|
|
wxDECLARE_EXPORTED_EVENT( WXDLLIMPEXP_BASE, wxEVT_POWER_RESUME, wxPowerEvent );
|
|
|
|
|
|
|
|
typedef void (wxEvtHandler::*wxPowerEventFunction)(wxPowerEvent&);
|
|
|
|
|
|
|
|
#define wxPowerEventHandler(func) \
|
|
|
|
wxEVENT_HANDLER_CAST(wxPowerEventFunction, func)
|
|
|
|
|
|
|
|
#define EVT_POWER_SUSPENDING(func) \
|
|
|
|
wx__DECLARE_EVT0(wxEVT_POWER_SUSPENDING, wxPowerEventHandler(func))
|
|
|
|
#define EVT_POWER_SUSPENDED(func) \
|
|
|
|
wx__DECLARE_EVT0(wxEVT_POWER_SUSPENDED, wxPowerEventHandler(func))
|
|
|
|
#define EVT_POWER_SUSPEND_CANCEL(func) \
|
|
|
|
wx__DECLARE_EVT0(wxEVT_POWER_SUSPEND_CANCEL, wxPowerEventHandler(func))
|
|
|
|
#define EVT_POWER_RESUME(func) \
|
|
|
|
wx__DECLARE_EVT0(wxEVT_POWER_RESUME, wxPowerEventHandler(func))
|
|
|
|
|
|
|
|
#else // no support for power events
|
|
|
|
#undef wxHAS_POWER_EVENTS
|
|
|
|
#endif // support for power events/no support
|
|
|
|
|
2016-06-26 05:25:29 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// wxPowerResourceBlocker
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
enum wxPowerResourceKind
|
|
|
|
{
|
|
|
|
wxPOWER_RESOURCE_SCREEN,
|
|
|
|
wxPOWER_RESOURCE_SYSTEM
|
|
|
|
};
|
|
|
|
|
|
|
|
class WXDLLIMPEXP_BASE wxPowerResource
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
static bool Acquire(wxPowerResourceKind kind,
|
|
|
|
const wxString& reason = wxString());
|
|
|
|
static void Release(wxPowerResourceKind kind);
|
|
|
|
};
|
|
|
|
|
|
|
|
class wxPowerResourceBlocker
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit wxPowerResourceBlocker(wxPowerResourceKind kind,
|
|
|
|
const wxString& reason = wxString())
|
|
|
|
: m_kind(kind),
|
|
|
|
m_acquired(wxPowerResource::Acquire(kind, reason))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
bool IsInEffect() const { return m_acquired; }
|
|
|
|
|
|
|
|
~wxPowerResourceBlocker()
|
|
|
|
{
|
|
|
|
if ( m_acquired )
|
|
|
|
wxPowerResource::Release(m_kind);
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
const wxPowerResourceKind m_kind;
|
|
|
|
const bool m_acquired;
|
|
|
|
|
|
|
|
wxDECLARE_NO_COPY_CLASS(wxPowerResourceBlocker);
|
|
|
|
};
|
|
|
|
|
2011-03-20 18:05:19 +00:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
// power management functions
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
// return the current system power state: online or offline
|
|
|
|
WXDLLIMPEXP_BASE wxPowerType wxGetPowerType();
|
|
|
|
|
|
|
|
// return approximate battery state
|
|
|
|
WXDLLIMPEXP_BASE wxBatteryState wxGetBatteryState();
|
|
|
|
|
|
|
|
#endif // _WX_POWER_H_
|