Add ability to override host ip from yeelight settings
This commit is contained in:
parent
eaf42dfa0a
commit
8900cb00e4
7 changed files with 98 additions and 17 deletions
|
|
@ -9,13 +9,14 @@
|
|||
|
||||
using json = nlohmann::json;
|
||||
|
||||
YeelightController::YeelightController(std::string ip, bool music_mode_val)
|
||||
YeelightController::YeelightController(std::string ip, std::string host_ip, bool music_mode_val)
|
||||
{
|
||||
/*-----------------------------------------------------------------*\
|
||||
| Fill in location string with device's IP address |
|
||||
\*-----------------------------------------------------------------*/
|
||||
location = "IP: " + ip;
|
||||
music_mode = music_mode_val;
|
||||
this->host_ip = host_ip;
|
||||
|
||||
/*-----------------------------------------------------------------*\
|
||||
| Open a TCP client sending to the device's IP, port 38899 |
|
||||
|
|
@ -120,11 +121,19 @@ void YeelightController::SetMusicMode()
|
|||
|
||||
/*-----------------------------------------------------------------*\
|
||||
| The Yeelight bulb requires this PC's local IP address for music |
|
||||
| mode. Get the first IP address of this computer's hostname |
|
||||
| mode. Get the first IP address of this computer's hostname, or |
|
||||
| use the one defined |
|
||||
\*-----------------------------------------------------------------*/
|
||||
gethostname(hostname, 256);
|
||||
host_entry = gethostbyname(hostname);
|
||||
ip_addr = inet_ntoa(*((struct in_addr*) host_entry->h_addr_list[0]));
|
||||
if(host_ip.empty())
|
||||
{
|
||||
gethostname(hostname, 256);
|
||||
host_entry = gethostbyname(hostname);
|
||||
ip_addr = inet_ntoa(*((struct in_addr*) host_entry->h_addr_list[0]));
|
||||
}
|
||||
else
|
||||
{
|
||||
ip_addr = &host_ip[0];
|
||||
}
|
||||
|
||||
/*-----------------------------------------------------------------*\
|
||||
| Fill in the set_rgb command with RGB information. |
|
||||
|
|
|
|||
|
|
@ -16,7 +16,7 @@
|
|||
class YeelightController
|
||||
{
|
||||
public:
|
||||
YeelightController(std::string ip, bool music_mode_val);
|
||||
YeelightController(std::string ip, std::string host_ip, bool music_mode_val);
|
||||
~YeelightController();
|
||||
|
||||
std::string GetLocation();
|
||||
|
|
@ -33,6 +33,7 @@ public:
|
|||
|
||||
private:
|
||||
std::string location;
|
||||
std::string host_ip;
|
||||
net_port port;
|
||||
bool music_mode;
|
||||
unsigned int music_mode_port;
|
||||
|
|
|
|||
|
|
@ -34,6 +34,13 @@ void DetectYeelightControllers(std::vector<RGBController*> &rgb_controllers)
|
|||
{
|
||||
for(unsigned int device_idx = 0; device_idx < yeelight_settings["devices"].size(); device_idx++)
|
||||
{
|
||||
std::string yeelight_host_ip;
|
||||
|
||||
if(yeelight_settings["devices"][device_idx].contains("host_ip"))
|
||||
{
|
||||
yeelight_host_ip = yeelight_settings["devices"][device_idx]["host_ip"];
|
||||
}
|
||||
|
||||
if(yeelight_settings["devices"][device_idx].contains("ip"))
|
||||
{
|
||||
std::string yeelight_ip = yeelight_settings["devices"][device_idx]["ip"];
|
||||
|
|
@ -44,7 +51,7 @@ void DetectYeelightControllers(std::vector<RGBController*> &rgb_controllers)
|
|||
music_mode = yeelight_settings["devices"][device_idx]["music_mode"];
|
||||
}
|
||||
|
||||
new_controller = new YeelightController(yeelight_ip, music_mode);
|
||||
new_controller = new YeelightController(yeelight_ip, yeelight_host_ip, music_mode);
|
||||
new_rgbcontroller = new RGBController_Yeelight(new_controller);
|
||||
|
||||
rgb_controllers.push_back(new_rgbcontroller);
|
||||
|
|
|
|||
|
|
@ -1,5 +1,7 @@
|
|||
#include "OpenRGBYeelightSettingsEntry.h"
|
||||
#include "ui_OpenRGBYeelightSettingsEntry.h"
|
||||
#include "net_port.h"
|
||||
#include <QInputDialog>
|
||||
|
||||
using namespace Ui;
|
||||
|
||||
|
|
@ -14,3 +16,34 @@ OpenRGBYeelightSettingsEntry::~OpenRGBYeelightSettingsEntry()
|
|||
{
|
||||
delete ui;
|
||||
}
|
||||
|
||||
void OpenRGBYeelightSettingsEntry::on_HostIPChooserButton_clicked()
|
||||
{
|
||||
char hostname[256];
|
||||
gethostname(hostname, 256);
|
||||
|
||||
char **in_addrs = gethostbyname(hostname)->h_addr_list;
|
||||
|
||||
QStringList in_addr_list;
|
||||
|
||||
while (*in_addrs != NULL)
|
||||
{
|
||||
in_addr_list << inet_ntoa(*((struct in_addr*) *in_addrs));
|
||||
in_addrs++;
|
||||
}
|
||||
|
||||
QInputDialog inp;
|
||||
|
||||
inp.setOptions(QInputDialog::UseListViewForComboBoxItems);
|
||||
inp.setComboBoxItems(in_addr_list);
|
||||
inp.setWindowTitle("Choose an IP...");
|
||||
inp.setLabelText("Choose the correct IP for the host");
|
||||
|
||||
if(!inp.exec())
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
ui->HostIPEdit->setText(inp.textValue());
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -16,6 +16,10 @@ public:
|
|||
explicit OpenRGBYeelightSettingsEntry(QWidget *parent = nullptr);
|
||||
~OpenRGBYeelightSettingsEntry();
|
||||
Ui::OpenRGBYeelightSettingsEntryUi *ui;
|
||||
|
||||
private slots:
|
||||
void on_HostIPChooserButton_clicked();
|
||||
|
||||
};
|
||||
|
||||
#endif // OPENRGBYeelightSETTINGSENTRY_H
|
||||
|
|
|
|||
|
|
@ -6,8 +6,8 @@
|
|||
<rect>
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>225</width>
|
||||
<height>85</height>
|
||||
<width>972</width>
|
||||
<height>385</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="sizePolicy">
|
||||
|
|
@ -26,8 +26,12 @@
|
|||
<string/>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_2">
|
||||
<item row="1" column="3">
|
||||
<widget class="QLineEdit" name="IPEdit"/>
|
||||
<item row="2" column="1">
|
||||
<widget class="QCheckBox" name="MusicModeCheckBox">
|
||||
<property name="text">
|
||||
<string/>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<widget class="QLabel" name="IPLabel">
|
||||
|
|
@ -36,10 +40,13 @@
|
|||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="3">
|
||||
<widget class="QCheckBox" name="MusicModeCheckBox">
|
||||
<item row="5" column="1">
|
||||
<widget class="QLineEdit" name="HostIPEdit"/>
|
||||
</item>
|
||||
<item row="5" column="2">
|
||||
<widget class="QToolButton" name="HostIPChooserButton">
|
||||
<property name="text">
|
||||
<string/>
|
||||
<string>?</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
|
|
@ -50,14 +57,28 @@
|
|||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="5" column="0">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Override host IP:</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1" colspan="2">
|
||||
<widget class="QLineEdit" name="IPEdit"/>
|
||||
</item>
|
||||
<item row="6" column="1">
|
||||
<widget class="QLabel" name="label_2">
|
||||
<property name="text">
|
||||
<string>Left blank for auto discovering host ip</string>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
<tabstops>
|
||||
<tabstop>IPEdit</tabstop>
|
||||
</tabstops>
|
||||
<resources/>
|
||||
<connections/>
|
||||
</ui>
|
||||
|
|
|
|||
|
|
@ -31,6 +31,11 @@ OpenRGBYeelightSettingsPage::OpenRGBYeelightSettingsPage(QWidget *parent) :
|
|||
entry->ui->IPEdit->setText(QString::fromStdString(yeelight_settings["devices"][device_idx]["ip"]));
|
||||
}
|
||||
|
||||
if(yeelight_settings["devices"][device_idx].contains("host_ip"))
|
||||
{
|
||||
entry->ui->HostIPEdit->setText(QString::fromStdString(yeelight_settings["devices"][device_idx]["host_ip"]));
|
||||
}
|
||||
|
||||
if(yeelight_settings["devices"][device_idx].contains("music_mode"))
|
||||
{
|
||||
entry->ui->MusicModeCheckBox->setChecked(yeelight_settings["devices"][device_idx]["music_mode"]);
|
||||
|
|
@ -103,6 +108,7 @@ void Ui::OpenRGBYeelightSettingsPage::on_SaveYeelightConfigurationButton_clicked
|
|||
| Required parameters |
|
||||
\*-------------------------------------------------*/
|
||||
yeelight_settings["devices"][device_idx]["ip"] = entries[device_idx]->ui->IPEdit->text().toStdString();
|
||||
yeelight_settings["devices"][device_idx]["host_ip"] = entries[device_idx]->ui->HostIPEdit->text().toStdString();
|
||||
yeelight_settings["devices"][device_idx]["music_mode"] = entries[device_idx]->ui->MusicModeCheckBox->isChecked();
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue