1.阻抗显示 2.解码器启动配置文件更改
This commit is contained in:
@@ -26,135 +26,166 @@
|
||||
|
||||
#include <QHostAddress>
|
||||
|
||||
namespace QMLTcpSockets{
|
||||
|
||||
TcpSocket::TcpSocket(QQuickItem* parent):
|
||||
QQuickItem(parent),
|
||||
socket(this)
|
||||
namespace QMLTcpSockets
|
||||
{
|
||||
connect(&socket, SIGNAL(connected()), this, SIGNAL(connected()));
|
||||
connect(&socket, SIGNAL(disconnected()), this, SIGNAL(disconnected()));
|
||||
connect(&socket, SIGNAL(error(QAbstractSocket::SocketError)), this, SLOT(emitErrorAsInt(QAbstractSocket::SocketError)));
|
||||
connect(&socket, SIGNAL(readyRead()), this, SLOT(publish()));
|
||||
peer = "";
|
||||
port = 0;
|
||||
}
|
||||
|
||||
TcpSocket::TcpSocket(QIntPtr* socketDescriptor, QQuickItem* parent):
|
||||
TcpSocket(parent)
|
||||
{
|
||||
socket.setSocketDescriptor(socketDescriptor->ptr);
|
||||
socketDescriptor->deleteLater();
|
||||
peer = socket.peerAddress().toString();
|
||||
port = socket.peerPort();
|
||||
}
|
||||
|
||||
TcpSocket::~TcpSocket(){
|
||||
socket.flush();
|
||||
}
|
||||
|
||||
void TcpSocket::setSocketDescriptor(QIntPtr* socketDescriptor){
|
||||
socket.flush();
|
||||
socket.disconnectFromHost();
|
||||
|
||||
socket.setSocketDescriptor(socketDescriptor->ptr);
|
||||
socketDescriptor->deleteLater();
|
||||
|
||||
QString peer = socket.peerAddress().toString();
|
||||
if(this->peer != peer){
|
||||
this->peer = peer;
|
||||
emit peerChanged();
|
||||
TcpSocket::TcpSocket(QQuickItem *parent):
|
||||
QQuickItem(parent),
|
||||
socket(this)
|
||||
{
|
||||
connect(&socket, SIGNAL(connected()), this, SIGNAL(connected()));
|
||||
connect(&socket, SIGNAL(disconnected()), this, SIGNAL(disconnected()));
|
||||
connect(&socket, SIGNAL(error(QAbstractSocket::SocketError)), this, SLOT(emitErrorAsInt(QAbstractSocket::SocketError)));
|
||||
connect(&socket, SIGNAL(readyRead()), this, SLOT(publish()));
|
||||
peer = "";
|
||||
port = 0;
|
||||
}
|
||||
|
||||
quint16 port = socket.peerPort();
|
||||
if(this->port != port){
|
||||
this->port = port;
|
||||
emit portChanged();
|
||||
TcpSocket::TcpSocket(QIntPtr *socketDescriptor, QQuickItem *parent):
|
||||
TcpSocket(parent)
|
||||
{
|
||||
socket.setSocketDescriptor(socketDescriptor->ptr);
|
||||
socketDescriptor->deleteLater();
|
||||
peer = socket.peerAddress().toString();
|
||||
port = socket.peerPort();
|
||||
}
|
||||
|
||||
emit connected();
|
||||
}
|
||||
TcpSocket::~TcpSocket()
|
||||
{
|
||||
socket.flush();
|
||||
}
|
||||
|
||||
void TcpSocket::setSocketOption(int option, QVariant value){
|
||||
socket.setSocketOption((QAbstractSocket::SocketOption)option, value);
|
||||
}
|
||||
void TcpSocket::setSocketDescriptor(QIntPtr *socketDescriptor)
|
||||
{
|
||||
socket.flush();
|
||||
socket.disconnectFromHost();
|
||||
|
||||
void TcpSocket::setPeer(QString peer){
|
||||
if(peer != this->peer){
|
||||
if(socket.state() != TcpSocketEnums::UnconnectedState)
|
||||
qWarning() << "TcpSocket::setPeer(): Can only set peer while disconnected.";
|
||||
else{
|
||||
socket.setSocketDescriptor(socketDescriptor->ptr);
|
||||
socketDescriptor->deleteLater();
|
||||
|
||||
QString peer = socket.peerAddress().toString();
|
||||
if(this->peer != peer)
|
||||
{
|
||||
this->peer = peer;
|
||||
emit peerChanged();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void TcpSocket::setPort(int port){
|
||||
if(port < 0){
|
||||
qWarning() << "TcpSocket::setPort(): port given was negative, setting to 0.";
|
||||
port = 0;
|
||||
}
|
||||
else if(port > 0xFFFF){
|
||||
qWarning() << "TcpSocket::setPort(): port given was larger than 65535, setting to 65535.";
|
||||
port = 0xFFFF;
|
||||
}
|
||||
|
||||
if(port != this->port){
|
||||
if(socket.state() != TcpSocketEnums::UnconnectedState)
|
||||
qWarning() << "TcpSocket::setPort(): Can only set port while disconnected.";
|
||||
else{
|
||||
quint16 port = socket.peerPort();
|
||||
if(this->port != port)
|
||||
{
|
||||
this->port = port;
|
||||
emit portChanged();
|
||||
}
|
||||
|
||||
emit connected();
|
||||
}
|
||||
}
|
||||
|
||||
void TcpSocket::connectToHost(){
|
||||
socket.connectToHost(peer, port);
|
||||
}
|
||||
void TcpSocket::setSocketOption(int option, QVariant value)
|
||||
{
|
||||
socket.setSocketOption((QAbstractSocket::SocketOption)option, value);
|
||||
}
|
||||
|
||||
void TcpSocket::disconnectFromHost(){
|
||||
socket.disconnectFromHost();
|
||||
}
|
||||
|
||||
void TcpSocket::emitErrorAsInt(QAbstractSocket::SocketError socketError){
|
||||
emit error(socketError);
|
||||
}
|
||||
|
||||
void TcpSocket::publish(){
|
||||
QList<int> list;
|
||||
QByteArray receivedBytes = socket.readAll();
|
||||
for(char c : receivedBytes)
|
||||
list << (int)(*((unsigned char*)(&c)));
|
||||
emit bytesReceived(list);
|
||||
}
|
||||
|
||||
bool TcpSocket::writeBytes(QList<int> bytes){
|
||||
QByteArray container;
|
||||
for(int b : bytes){
|
||||
if(b < 0 || b > 0xFF){
|
||||
qWarning() << "TcpSocket::writeBytes(): bytes contain integer not in [0x00,0xFF], not writing";
|
||||
return false;
|
||||
void TcpSocket::setPeer(QString peer)
|
||||
{
|
||||
if(peer != this->peer)
|
||||
{
|
||||
if(socket.state() != TcpSocketEnums::UnconnectedState)
|
||||
{
|
||||
qWarning() << "TcpSocket::setPeer(): Can only set peer while disconnected.";
|
||||
}
|
||||
else
|
||||
{
|
||||
this->peer = peer;
|
||||
emit peerChanged();
|
||||
}
|
||||
}
|
||||
else
|
||||
container.append((char)b);
|
||||
}
|
||||
|
||||
int numBytesToWrite = container.size();
|
||||
const char* bytesRaw = container.constData();
|
||||
while(numBytesToWrite > 0){
|
||||
int bytesWritten = socket.write(bytesRaw, numBytesToWrite);
|
||||
if(bytesWritten < 0){
|
||||
qWarning() << "TcpSocket::writeBytes(): Bytes were not written: " << socket.errorString();
|
||||
return false;
|
||||
void TcpSocket::setPort(int port)
|
||||
{
|
||||
if(port < 0)
|
||||
{
|
||||
qWarning() << "TcpSocket::setPort(): port given was negative, setting to 0.";
|
||||
port = 0;
|
||||
}
|
||||
else if(port > 0xFFFF)
|
||||
{
|
||||
qWarning() << "TcpSocket::setPort(): port given was larger than 65535, setting to 65535.";
|
||||
port = 0xFFFF;
|
||||
}
|
||||
|
||||
if(port != this->port)
|
||||
{
|
||||
if(socket.state() != TcpSocketEnums::UnconnectedState)
|
||||
{
|
||||
qWarning() << "TcpSocket::setPort(): Can only set port while disconnected.";
|
||||
}
|
||||
else
|
||||
{
|
||||
this->port = port;
|
||||
emit portChanged();
|
||||
}
|
||||
}
|
||||
numBytesToWrite -= bytesWritten;
|
||||
bytesRaw += bytesWritten;
|
||||
}
|
||||
socket.flush();
|
||||
|
||||
return true;
|
||||
}
|
||||
void TcpSocket::connectToHost()
|
||||
{
|
||||
socket.connectToHost(peer, port);
|
||||
}
|
||||
|
||||
void TcpSocket::disconnectFromHost()
|
||||
{
|
||||
socket.disconnectFromHost();
|
||||
}
|
||||
|
||||
void TcpSocket::emitErrorAsInt(QAbstractSocket::SocketError socketError)
|
||||
{
|
||||
emit error(socketError);
|
||||
}
|
||||
|
||||
void TcpSocket::publish()
|
||||
{
|
||||
QList<int> list;
|
||||
QByteArray receivedBytes = socket.readAll();
|
||||
for(char c : receivedBytes)
|
||||
{
|
||||
list << (int)(*((unsigned char *)(&c)));
|
||||
}
|
||||
emit bytesReceived(list);
|
||||
}
|
||||
|
||||
bool TcpSocket::writeBytes(QList<int> bytes)
|
||||
{
|
||||
QByteArray container;
|
||||
for(int b : bytes)
|
||||
{
|
||||
if(b < 0 || b > 0xFF)
|
||||
{
|
||||
qWarning() << "TcpSocket::writeBytes(): bytes contain integer not in [0x00,0xFF], not writing";
|
||||
return false;
|
||||
}
|
||||
else
|
||||
{
|
||||
container.append((char)b);
|
||||
}
|
||||
}
|
||||
|
||||
int numBytesToWrite = container.size();
|
||||
const char *bytesRaw = container.constData();
|
||||
while(numBytesToWrite > 0)
|
||||
{
|
||||
int bytesWritten = socket.write(bytesRaw, numBytesToWrite);
|
||||
if(bytesWritten < 0)
|
||||
{
|
||||
qWarning() << "TcpSocket::writeBytes(): Bytes were not written: " << socket.errorString();
|
||||
return false;
|
||||
}
|
||||
numBytesToWrite -= bytesWritten;
|
||||
bytesRaw += bytesWritten;
|
||||
}
|
||||
socket.flush();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user