[英]Sending floating point numbers to QuartzComposer via UDP with C++
在另一个问题中 ,用户提供了一种通过UDP将数据发送到QuartzComposer的方法。 似乎QuartzComposer对于发送给它的字节数据的填充非常特别。 特别是,它要求发送的每个字符都以“ \\ 0 \\ 0 \\ 0”开头。
我能够模拟一个快速的Python程序来解决此问题:
from socket import *
PORT = 50000
N = 3.14159265358
# connect to Quartz Composer on localhost port 50000
s = socket(AF_INET, SOCK_DGRAM)
s.bind(('', 0))
s.setsockopt(SOL_SOCKET, SO_BROADCAST, 1)
for c in str(N):
out = out + '\0\0\0' + c
s.sendto(out, ('225.0.0.0', PORT))
我需要在C ++中实现的关键部分是填充浮点数的位。 这是关键部分的快速Python模拟:
def padfloat(n):
out = ''
for c in str(n):
out = out + '\0\0\0' + c
return out
if __name__ == '__main__':
print(padfloat(3.14159265358))
诚然,我的C ++斩波不是那么紧密,但是我能够使用boost来启动和运行UDP并发送一条硬编码的消息“ 0.7”:
//
// Working C++ to Quartz Network Test
//
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <boost/asio.hpp>
using boost::asio::ip::udp;
enum { max_length = 1024 };
int main(int argc, char* argv[])
{
try
{
boost::asio::io_service io_service;
udp::socket s(io_service, udp::endpoint(udp::v4(), 0));
udp::resolver resolver(io_service);
udp::resolver::query query(udp::v4(), "225.0.0.0", "50000");
udp::resolver::iterator iterator = resolver.resolve(query);
using namespace std; // For strlen.
// TODO: alter code to take in any number
for (;;) {
std::cout << "Press Any Key to send 0.7: ";
char request[max_length];
std::cin.getline(request, max_length);
// size_t request_length = strlen(request);
char test [] = {0,0,0,'0',0,0,0,'.',0,0,0,'7','\0'};
s.send_to(boost::asio::buffer(test, 12), *iterator);
std::cout << "Sent\n";
}
}
catch (std::exception& e)
{
std::cerr << "Exception: " << e.what() << "\n";
}
return 0;
}
我需要帮助的一个相当琐碎的问题是如何采用浮点数并将其正确格式化为char数组,以便在正确填充所有“ \\ 0 \\ 0 \\ 0”填充的情况下发出。 我将要做一些丑陋的事情,但是如果有人可以指出我的解决方法,我很乐于学习。
我没有一个方便的编译器,但这足够了。
我不确定asio是否希望null终止符成为其大小的一部分,因此我遵循了您的示例。
float float_value = 4.2f;
std::string str = boost::lexical_cast<std::string>(float_value);
std::vector<char> char_buff((str.size() * 4) + 1, 0);
for (size_t i = 0; i < str.size(); i++)
char_buff[(i * 4) + 3] = str[i];
s.send_to(boost::asio::buffer(&char_buff[0], char_buff.size()), *iterator);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.