Add CycleDPI action
This commit is contained in:
parent
21b7455919
commit
949a1ee283
|
@ -25,6 +25,7 @@ add_executable(logid
|
||||||
actions/KeypressAction.cpp
|
actions/KeypressAction.cpp
|
||||||
actions/ToggleHiresScroll.cpp
|
actions/ToggleHiresScroll.cpp
|
||||||
actions/ToggleSmartShift.cpp
|
actions/ToggleSmartShift.cpp
|
||||||
|
actions/CycleDPI.cpp
|
||||||
actions/GestureAction.cpp
|
actions/GestureAction.cpp
|
||||||
actions/gesture/Gesture.cpp
|
actions/gesture/Gesture.cpp
|
||||||
actions/gesture/ReleaseGesture.cpp
|
actions/gesture/ReleaseGesture.cpp
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include "ToggleHiresScroll.h"
|
#include "ToggleHiresScroll.h"
|
||||||
#include "GestureAction.h"
|
#include "GestureAction.h"
|
||||||
#include "NullAction.h"
|
#include "NullAction.h"
|
||||||
|
#include "CycleDPI.h"
|
||||||
|
|
||||||
using namespace logid;
|
using namespace logid;
|
||||||
using namespace logid::actions;
|
using namespace logid::actions;
|
||||||
|
@ -57,6 +58,8 @@ std::shared_ptr<Action> Action::makeAction(Device *device, libconfig::Setting
|
||||||
return std::make_shared<ToggleHiresScroll>(device);
|
return std::make_shared<ToggleHiresScroll>(device);
|
||||||
else if(type == "gestures")
|
else if(type == "gestures")
|
||||||
return std::make_shared<GestureAction>(device, setting);
|
return std::make_shared<GestureAction>(device, setting);
|
||||||
|
else if(type == "cycledpi")
|
||||||
|
return std::make_shared<CycleDPI>(device, setting);
|
||||||
else if(type == "none")
|
else if(type == "none")
|
||||||
return std::make_shared<NullAction>(device);
|
return std::make_shared<NullAction>(device);
|
||||||
else
|
else
|
||||||
|
|
133
src/logid/actions/CycleDPI.cpp
Normal file
133
src/logid/actions/CycleDPI.cpp
Normal file
|
@ -0,0 +1,133 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2019-2020 PixlOne
|
||||||
|
*
|
||||||
|
* 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 3 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/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include "CycleDPI.h"
|
||||||
|
#include "../Device.h"
|
||||||
|
#include "../util/task.h"
|
||||||
|
#include "../util/log.h"
|
||||||
|
#include "../backend/hidpp20/Error.h"
|
||||||
|
#include "../backend/hidpp20/features/ReprogControls.h"
|
||||||
|
|
||||||
|
using namespace logid::actions;
|
||||||
|
using namespace libconfig;
|
||||||
|
|
||||||
|
CycleDPI::CycleDPI(Device* device, libconfig::Setting& setting) :
|
||||||
|
Action (device), _config (device, setting)
|
||||||
|
{
|
||||||
|
_dpi = _device->getFeature<features::DPI>("dpi");
|
||||||
|
if(!_dpi)
|
||||||
|
logPrintf(WARN, "%s:%d: DPI feature not found, cannot use "
|
||||||
|
"CycleDPI action.",
|
||||||
|
_device->hidpp20().devicePath().c_str(),
|
||||||
|
_device->hidpp20().deviceIndex());
|
||||||
|
}
|
||||||
|
|
||||||
|
void CycleDPI::press()
|
||||||
|
{
|
||||||
|
_pressed = true;
|
||||||
|
if(_dpi && !_config.empty()) {
|
||||||
|
task::spawn([this](){
|
||||||
|
uint16_t dpi = _config.nextDPI();
|
||||||
|
try {
|
||||||
|
_dpi->setDPI(dpi, _config.sensor());
|
||||||
|
} catch (backend::hidpp20::Error& e) {
|
||||||
|
if(e.code() == backend::hidpp20::Error::InvalidArgument)
|
||||||
|
logPrintf(WARN, "%s:%d: Could not set DPI to %d for "
|
||||||
|
"sensor %d", _device->hidpp20().devicePath().c_str(),
|
||||||
|
_device->hidpp20().deviceIndex(), dpi,
|
||||||
|
_config.sensor());
|
||||||
|
else
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void CycleDPI::release()
|
||||||
|
{
|
||||||
|
_pressed = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t CycleDPI::reprogFlags() const
|
||||||
|
{
|
||||||
|
return backend::hidpp20::ReprogControls::TemporaryDiverted;
|
||||||
|
}
|
||||||
|
|
||||||
|
CycleDPI::Config::Config(Device *device, libconfig::Setting &config) :
|
||||||
|
Action::Config(device), _current_index (0), _sensor (0)
|
||||||
|
{
|
||||||
|
if(!config.isGroup()) {
|
||||||
|
logPrintf(WARN, "Line %d: action must be an object, skipping.",
|
||||||
|
config.getSourceLine());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
auto& sensor = config.lookup("sensor");
|
||||||
|
if(sensor.getType() != Setting::TypeInt)
|
||||||
|
logPrintf(WARN, "Line %d: sensor must be an integer",
|
||||||
|
sensor.getSourceLine());
|
||||||
|
_sensor = (int)sensor;
|
||||||
|
} catch(libconfig::SettingNotFoundException& e) {
|
||||||
|
// Ignore
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
auto& dpis = config.lookup("dpis");
|
||||||
|
if(!dpis.isList() && !dpis.isArray()) {
|
||||||
|
logPrintf(WARN, "Line %d: dpis must be a list or array, skipping.",
|
||||||
|
dpis.getSourceLine());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int dpi_count = dpis.getLength();
|
||||||
|
for(int i = 0; i < dpi_count; i++) {
|
||||||
|
if(dpis[i].getType() != Setting::TypeInt) {
|
||||||
|
logPrintf(WARN, "Line %d: dpis must be integers, skipping.",
|
||||||
|
dpis[i].getSourceLine());
|
||||||
|
if(dpis.isList())
|
||||||
|
continue;
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
_dpis.push_back((int)(dpis[i]));
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (libconfig::SettingNotFoundException& e) {
|
||||||
|
logPrintf(WARN, "Line %d: dpis is a required field, skipping.",
|
||||||
|
config.getSourceLine());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t CycleDPI::Config::nextDPI()
|
||||||
|
{
|
||||||
|
uint16_t dpi = _dpis[_current_index++];
|
||||||
|
if(_current_index >= _dpis.size())
|
||||||
|
_current_index = 0;
|
||||||
|
return dpi;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CycleDPI::Config::empty() const
|
||||||
|
{
|
||||||
|
return _dpis.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t CycleDPI::Config::sensor() const
|
||||||
|
{
|
||||||
|
return _sensor;
|
||||||
|
}
|
56
src/logid/actions/CycleDPI.h
Normal file
56
src/logid/actions/CycleDPI.h
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2019-2020 PixlOne
|
||||||
|
*
|
||||||
|
* 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 3 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 LOGID_ACTION_CYCLEDPI_H
|
||||||
|
#define LOGID_ACTION_CYCLEDPI_H
|
||||||
|
|
||||||
|
#include <libconfig.h++>
|
||||||
|
#include "Action.h"
|
||||||
|
#include "../features/DPI.h"
|
||||||
|
|
||||||
|
namespace logid {
|
||||||
|
namespace actions {
|
||||||
|
class CycleDPI : public Action
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit CycleDPI(Device* device, libconfig::Setting& setting);
|
||||||
|
|
||||||
|
virtual void press();
|
||||||
|
virtual void release();
|
||||||
|
|
||||||
|
virtual uint8_t reprogFlags() const;
|
||||||
|
|
||||||
|
class Config : public Action::Config
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Config(Device* device, libconfig::Setting& setting);
|
||||||
|
uint16_t nextDPI();
|
||||||
|
bool empty() const;
|
||||||
|
uint8_t sensor() const;
|
||||||
|
private:
|
||||||
|
std::size_t _current_index;
|
||||||
|
std::vector<uint16_t> _dpis;
|
||||||
|
uint8_t _sensor;
|
||||||
|
};
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Config _config;
|
||||||
|
std::shared_ptr<features::DPI> _dpi;
|
||||||
|
};
|
||||||
|
}}
|
||||||
|
|
||||||
|
#endif //LOGID_ACTION_CYCLEDPI_H
|
|
@ -30,14 +30,13 @@ ToggleSmartShift::ToggleSmartShift(Device *dev) : Action (dev)
|
||||||
logPrintf(WARN, "%s:%d: SmartShift feature not found, cannot use "
|
logPrintf(WARN, "%s:%d: SmartShift feature not found, cannot use "
|
||||||
"ToggleSmartShift action.",
|
"ToggleSmartShift action.",
|
||||||
_device->hidpp20().devicePath().c_str(),
|
_device->hidpp20().devicePath().c_str(),
|
||||||
_device->hidpp20().devicePath().c_str());
|
_device->hidpp20().deviceIndex());
|
||||||
}
|
}
|
||||||
|
|
||||||
void ToggleSmartShift::press()
|
void ToggleSmartShift::press()
|
||||||
{
|
{
|
||||||
_pressed = true;
|
_pressed = true;
|
||||||
if(_smartshift)
|
if(_smartshift) {
|
||||||
{
|
|
||||||
task::spawn([ss=this->_smartshift](){
|
task::spawn([ss=this->_smartshift](){
|
||||||
auto status = ss->getStatus();
|
auto status = ss->getStatus();
|
||||||
status.setActive = true;
|
status.setActive = true;
|
||||||
|
|
|
@ -80,6 +80,16 @@ void DPI::listen()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint16_t DPI::getDPI(uint8_t sensor)
|
||||||
|
{
|
||||||
|
return _adjustable_dpi.getSensorDPI(sensor);
|
||||||
|
}
|
||||||
|
|
||||||
|
void DPI::setDPI(uint16_t dpi, uint8_t sensor)
|
||||||
|
{
|
||||||
|
_adjustable_dpi.setSensorDPI(sensor, dpi);
|
||||||
|
}
|
||||||
|
|
||||||
/* Some devices have multiple sensors, but an older config format
|
/* Some devices have multiple sensors, but an older config format
|
||||||
* only supports a single DPI. The dpi setting can be an array or
|
* only supports a single DPI. The dpi setting can be an array or
|
||||||
* an integer.
|
* an integer.
|
||||||
|
|
|
@ -31,6 +31,9 @@ namespace features
|
||||||
virtual void configure();
|
virtual void configure();
|
||||||
virtual void listen();
|
virtual void listen();
|
||||||
|
|
||||||
|
uint16_t getDPI(uint8_t sensor=0);
|
||||||
|
void setDPI(uint16_t dpi, uint8_t sensor=0);
|
||||||
|
|
||||||
class Config : public DeviceFeature::Config
|
class Config : public DeviceFeature::Config
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user