代码拉取完成,页面将自动刷新
同步操作将从 ianaxe/vrpn 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
#ifndef VRPN_OMEGATEMPERATURE_H
#define VRPN_OMEGATEMPERATURE_H
// XXX Need to have a VRPN boolean output device. Then we can set the
// temperature control to be on or off based on its value. For now, we're
// doing a horrible thing and packing it into an analog output channel.
#include "vrpn_Analog.h" // for vrpn_Serial_Analog
#include "vrpn_Analog_Output.h" // for vrpn_Analog_Output
#include "vrpn_Button.h" // for vrpn_Button_Filter
#include "vrpn_Configure.h" // for VRPN_CALLBACK, VRPN_API
#include "vrpn_Connection.h" // for vrpn_CONNECTION_RELIABLE, etc
#include "vrpn_Shared.h" // for timeval
#include "vrpn_Types.h" // for vrpn_uint32, vrpn_float64
/* XXX The code has not been changed from the Biosciences code yet,
only the names have been changed. */
/*
# Analog channels: (read by client)
# 0 Reading from stage 1 in degrees Celcius
# 1 Reading from bath 1 in degrees Celcius
# 2 External 1 in degrees Celcius (or setpoint if ext not used)
# 3 Reading from stage 2 in degrees Celcius
# 4 Reading from bath 2 in degrees Celcius
# 5 External 1 in degrees Celcius (or setpoint if ext not used)
# Button channels: (read by client)
# 0 Temperature control is on or off
# Analog_Output channels: (set by client)
# 0 Reference temperature for channel 1
# 1 Reference temperature for channel 2
# 2 Turn temperature control on/off (0 = off, otherwise on)
*/
#if defined(VRPN_USE_MODBUS) && defined(VRPN_USE_WINSOCK2)
#include <modbus.h>
class VRPN_API vrpn_OmegaTemperature: public vrpn_Serial_Analog,
public vrpn_Analog_Output, public vrpn_Button_Filter
{
public:
// Tell it the temperature to use to set channels 1 and 2 to
// in Celcius and also whether to turn the temperature control on.
vrpn_OmegaTemperature (const char * name, vrpn_Connection * c,
const char * port, float temp1, float temp2,
bool control_on);
~vrpn_OmegaTemperature () {};
/// Called once through each main loop iteration to handle updates.
virtual void mainloop ();
protected:
modbus_t *d_modbus; //< Modbus object to use to communicate.
char d_buffer[128]; //< Buffer of characters in report
unsigned d_bufcount; //< How many characters we have so far
struct timeval timestamp; //< Time of the last report from the device
virtual int reset(void); //< Set device back to starting config
virtual int get_report(void); //< Try to read a report from the device
// Channels are zero-referenced. Use 0 for channel 1.
bool set_reference_temperature(unsigned channel, float value);
bool set_control_status(bool on);
bool request_temperature(unsigned channel);
// Sets a specified channel based on a new value from the Analog_Output.
// Channels 0 and 1 are temperature settings, and channel 2 is our
// hack to turn on and off temperatur control.
bool set_specified_channel(unsigned channel, vrpn_float64 value);
// This lets us know which channel we're waiting for a reading on.
// It cycles; each time we hear from one, we ask for the next.
unsigned d_next_channel_to_read;
float convert_bytes_to_reading(const char *buf);
/// send report iff changed
virtual void report_changes
(vrpn_uint32 class_of_service = vrpn_CONNECTION_RELIABLE);
/// send report whether or not changed
virtual void report
(vrpn_uint32 class_of_service = vrpn_CONNECTION_RELIABLE);
/// Responds to a request to change one of the values by
/// setting the channel to that value.
static int VRPN_CALLBACK handle_request_message(void *userdata, vrpn_HANDLERPARAM p);
/// Responds to a request to change multiple channels at once.
static int VRPN_CALLBACK handle_request_channels_message(void *userdata, vrpn_HANDLERPARAM p);
/// Responds to a connection request with a report of the values
static int VRPN_CALLBACK handle_connect_message(void *userdata, vrpn_HANDLERPARAM p);
};
#endif
#endif
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。