The client will connect to the CCD driver and attempts to change the CCD temperature.
#if 0
Simple Client Tutorial
Demonstration of libindi v0.7 capabilities.
Copyright (C) 2010 Jasem Mutlaq (mutlaqja@ikarustech.com)
This library is free software;
you can redistribute it and / or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation;
either
version 2.1 of the License, or (at your option) any later version.
This library 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
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library;
if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110 - 1301 USA
#endif
#include <cstring>
#include <fstream>
#include <iostream>
#include <memory>
{
std::cout << "Press Enter key to terminate the client.\n";
std::cin.ignore();
}
{
{
{
IDLog(
"Connecting to INDI Driver...\n");
{
{
IDLog(
"CCD is connected.\n");
}
property.onUpdate([property, this]()
{
IDLog(
"Receving new CCD Temperature: %g C\n", property[0].getValue());
if (property[0].getValue() == -20)
{
IDLog(
"CCD temperature reached desired value!\n");
}
});
{
std::ofstream myfile;
myfile.open("ccd_simulator.fits", std::ios::out | std::ios::binary);
myfile.write(static_cast<char *>(property[0].getBlob()), property[0].getBlobLen());
myfile.close();
IDLog(
"Received image, saved as ccd_simulator.fits\n");
});
}
{
{
IDLog(
"Error: unable to find Simple CCD, CCD_TEMPERATURE property...\n");
return;
}
IDLog(
"Setting temperature to %g C.\n", value);
ccdTemperature[0].setValue(value);
}
{
{
IDLog(
"Error: unable to find CCD Simulator CCD_EXPOSURE property...\n");
return;
}
IDLog(
"Taking a %g second exposure.\n", seconds);
ccdExposure[0].setValue(seconds);
}
{
return;
IDLog(
"Recveing message from Server:\n"
" %s\n\n",
}
void setServer(const char *hostname, unsigned int port)
Set the server host name and port.
void setBLOBMode(BLOBHandling blobH, const char *dev, const char *prop=nullptr)
Set Binary Large Object policy mode.
void sendNewProperty(INDI::Property pp)
Send new Property command to server.
void connectDevice(const char *deviceName)
Disconnect INDI driver.
void watchDevice(const char *deviceName)
Add a device to the watch list.
void enableDirectBlobAccess(const char *dev=nullptr, const char *prop=nullptr)
activate zero-copy delivering of the blob content. When enabled, all blob copy will be avoided when p...
bool connectServer() override
Connect to INDI server.
Class to provide basic INDI device functionality.
const std::string & messageQueue(size_t index) const
Property getProperty(const char *name, INDI_PROPERTY_TYPE type=INDI_UNKNOWN) const
Return a property and its type given its name.
bool isDeviceNameMatch(const char *otherName) const
Check that the device name matches the argument.
Provides generic container for INDI properties.
void setTemperature(double value)
void newMessage(INDI::BaseDevice baseDevice, int messageID) override
Emmited when a new message arrives from INDI server.
void takeExposure(double seconds)
void IDLog(const char *fmt,...)
Construct a basic INDI client that demonstrates INDI::Client capabilities. This client must be used w...