kwin/colorcorrection/manager.h

204 lines
5.7 KiB
C++

/********************************************************************
KWin - the KDE window manager
This file is part of the KDE project.
Copyright 2017 Roman Gilg <subdiff@gmail.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*********************************************************************/
#ifndef KWIN_COLORCORRECT_MANAGER_H
#define KWIN_COLORCORRECT_MANAGER_H
#include "constants.h"
#include <kwin_export.h>
#include <QObject>
#include <QPair>
#include <QDateTime>
class QTimer;
namespace KWin
{
class Workspace;
namespace ColorCorrect
{
typedef QPair<QDateTime,QDateTime> DateTimes;
typedef QPair<QTime,QTime> Times;
class ColorCorrectDBusInterface;
/**
* This enum type is used to specify operation mode of the night color manager.
*/
enum NightColorMode {
/**
* Color temperature is computed based on the current position of the Sun.
*
* Location of the user is provided by Plasma.
*/
Automatic,
/**
* Color temperature is computed based on the current position of the Sun.
*
* Location of the user is provided by themselves.
*/
Location,
/**
* Color temperature is computed based on the current time.
*
* Sunrise and sunset times have to be specified by the user.
*/
Timings,
/**
* Color temperature is constant thoughout the day.
*/
Constant,
};
/**
* The night color manager is a blue light filter similar to Redshift.
*
* There are four modes this manager can operate in: Automatic, Location, Timings,
* and Constant. Both Automatic and Location modes derive screen color temperature
* from the current position of the Sun, the only difference between two is how
* coordinates of the user are specified. If the user is located near the North or
* South pole, we can't compute correct position of the Sun, that's why we need
* Timings and Constant mode.
*
* With the Timings mode, screen color temperature is computed based on the clock
* time. The user needs to specify timings of the sunset and sunrise as well the
* transition time.
*
* With the Constant mode, screen color temperature is always constant.
*/
class KWIN_EXPORT Manager : public QObject
{
Q_OBJECT
public:
Manager(QObject *parent);
void init();
/**
* Get current configuration
* @see changeConfiguration
* @since 5.12
*/
QHash<QString, QVariant> info() const;
/**
* Change configuration
* @see info
* @since 5.12
*/
bool changeConfiguration(QHash<QString, QVariant> data);
void autoLocationUpdate(double latitude, double longitude);
/**
* Toggles the active state of the filter.
*
* A quick transition will be started if the difference between current screen
* color temperature and target screen color temperature is too large. Target
* temperature is defined in context of the new active state.
*
* If the filter becomes inactive after calling this method, the target color
* temperature is 6500 K.
*
* If the filter becomes active after calling this method, the target screen
* color temperature is defined by the current operation mode.
*
* Note that this method is a no-op if the underlying platform doesn't support
* adjusting gamma ramps.
*/
void toggle();
// for auto tests
void reparseConfigAndReset();
public Q_SLOTS:
void resetSlowUpdateStartTimer();
void quickAdjust();
Q_SIGNALS:
void configChange(QHash<QString, QVariant> data);
private:
void initShortcuts();
void readConfig();
void hardReset();
void slowUpdate(int targetTemp);
void resetAllTimers();
int currentTargetTemp() const;
void cancelAllTimers();
/**
* Quick shift on manual change to current target Temperature
*/
void resetQuickAdjustTimer();
/**
* Slow shift to daytime target Temperature
*/
void resetSlowUpdateTimer();
void updateSunTimings(bool force);
DateTimes getSunTimings(const QDateTime &dateTime, double latitude, double longitude, bool morning) const;
bool checkAutomaticSunTimings() const;
bool daylight() const;
void commitGammaRamps(int temperature);
ColorCorrectDBusInterface *m_iface;
bool m_active;
bool m_running = false;
NightColorMode m_mode = NightColorMode::Automatic;
// the previous and next sunrise/sunset intervals - in UTC time
DateTimes m_prev = DateTimes();
DateTimes m_next = DateTimes();
// manual times from config
QTime m_morning = QTime(6,0);
QTime m_evening = QTime(18,0);
int m_trTime = 30; // saved in minutes > 1
// auto location provided by work space
double m_latAuto;
double m_lngAuto;
// manual location from config
double m_latFixed;
double m_lngFixed;
QTimer *m_slowUpdateStartTimer = nullptr;
QTimer *m_slowUpdateTimer = nullptr;
QTimer *m_quickAdjustTimer = nullptr;
int m_currentTemp = NEUTRAL_TEMPERATURE;
int m_dayTargetTemp = NEUTRAL_TEMPERATURE;
int m_nightTargetTemp = DEFAULT_NIGHT_TEMPERATURE;
int m_failedCommitAttempts = 0;
// The Workspace class needs to call initShortcuts during initialization.
friend class KWin::Workspace;
};
}
}
#endif // KWIN_COLORCORRECT_MANAGER_H