Updates in attempt to get window to start on launch in macOS. Not happening but it's a quick hack to start it with a message. Add a send.js file for node.
This commit is contained in:
parent
ba3ddf82de
commit
3addc7464f
32
main.cpp
32
main.cpp
|
@ -21,7 +21,7 @@ using namespace std;
|
||||||
using namespace std::chrono;
|
using namespace std::chrono;
|
||||||
using namespace nlohmann;
|
using namespace nlohmann;
|
||||||
|
|
||||||
const int DISPLAY_DURATION = 2000;
|
volatile int DISPLAY_DURATION = 2000;
|
||||||
const int PORT = 8081;
|
const int PORT = 8081;
|
||||||
|
|
||||||
steady_clock::time_point startTime;
|
steady_clock::time_point startTime;
|
||||||
|
@ -31,6 +31,11 @@ condition_variable quadCondVar;
|
||||||
|
|
||||||
void displayQuad() {
|
void displayQuad() {
|
||||||
glClear(GL_COLOR_BUFFER_BIT);
|
glClear(GL_COLOR_BUFFER_BIT);
|
||||||
|
glEnable(GL_TEXTURE_2D);
|
||||||
|
glViewport(0, 0, 500, 500);
|
||||||
|
glMatrixMode(GL_PROJECTION);
|
||||||
|
glLoadIdentity();
|
||||||
|
glOrtho(-1.0, 1.0, -1.0, 1.0, -1.0, 1.0);
|
||||||
|
|
||||||
auto currentTime = steady_clock::now();
|
auto currentTime = steady_clock::now();
|
||||||
auto elapsedTime = duration_cast<milliseconds>(currentTime - startTime).count();
|
auto elapsedTime = duration_cast<milliseconds>(currentTime - startTime).count();
|
||||||
|
@ -41,21 +46,19 @@ void displayQuad() {
|
||||||
quadCondVar.wait(lock, [&] { return shouldDisplayQuad; });
|
quadCondVar.wait(lock, [&] { return shouldDisplayQuad; });
|
||||||
localShouldDisplayQuad = shouldDisplayQuad;
|
localShouldDisplayQuad = shouldDisplayQuad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (localShouldDisplayQuad && elapsedTime < DISPLAY_DURATION) {
|
if (localShouldDisplayQuad && elapsedTime < DISPLAY_DURATION) {
|
||||||
glColor3f(1.0f, 0.0f, 0.0f);
|
glColor3f(1.0f, 0.0f, 0.0f);
|
||||||
|
|
||||||
glBegin(GL_QUADS);
|
|
||||||
glVertex2f(-0.5f, -0.5f);
|
|
||||||
glVertex2f(-0.5f, 0.5f);
|
|
||||||
glVertex2f(0.5f, 0.5f);
|
|
||||||
glVertex2f(0.5f, -0.5f);
|
|
||||||
glEnd();
|
|
||||||
} else {
|
} else {
|
||||||
glClearColor(0.0f, 0.0f, 0.0f, 1.0f);
|
glColor3f(0.0f, 0.0f, 0.0f);
|
||||||
glClear(GL_COLOR_BUFFER_BIT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
glBegin(GL_QUADS);
|
||||||
|
glVertex2f(-0.5f, -0.5f);
|
||||||
|
glVertex2f(-0.5f, 0.5f);
|
||||||
|
glVertex2f(0.5f, 0.5f);
|
||||||
|
glVertex2f(0.5f, -0.5f);
|
||||||
|
glEnd();
|
||||||
|
|
||||||
glutSwapBuffers();
|
glutSwapBuffers();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -87,6 +90,11 @@ void handleTCPConnection(int serverSocket) {
|
||||||
json jsonData = json::parse(jsonString);
|
json jsonData = json::parse(jsonString);
|
||||||
cout << "Received JSON: " << jsonData << endl;
|
cout << "Received JSON: " << jsonData << endl;
|
||||||
|
|
||||||
|
if (jsonData.contains("rgb")) {
|
||||||
|
DISPLAY_DURATION = jsonData["rgb"];
|
||||||
|
cout << "Set exposure time to " << DISPLAY_DURATION << "ms" << endl;
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
lock_guard<mutex> lock(quadMutex);
|
lock_guard<mutex> lock(quadMutex);
|
||||||
shouldDisplayQuad = true;
|
shouldDisplayQuad = true;
|
||||||
|
@ -114,6 +122,8 @@ int main(int argc, char** argv) {
|
||||||
|
|
||||||
glutDisplayFunc(displayQuad);
|
glutDisplayFunc(displayQuad);
|
||||||
glutTimerFunc(0, timer, 0);
|
glutTimerFunc(0, timer, 0);
|
||||||
|
|
||||||
|
startTime = steady_clock::now();
|
||||||
|
|
||||||
int serverSocket = socket(AF_INET, SOCK_STREAM, 0);
|
int serverSocket = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
if (serverSocket < 0) {
|
if (serverSocket < 0) {
|
||||||
|
|
|
@ -0,0 +1,27 @@
|
||||||
|
const net = require('net');
|
||||||
|
|
||||||
|
const serverAddress = 'localhost';
|
||||||
|
const serverPort = 8081;
|
||||||
|
|
||||||
|
const client = new net.Socket();
|
||||||
|
|
||||||
|
console.log(`Connecting to ${serverAddress}:${serverPort}...`);
|
||||||
|
|
||||||
|
client.connect(serverPort, serverAddress, () => {
|
||||||
|
const data = {
|
||||||
|
file: 'filename.tif',
|
||||||
|
rgb: 1000
|
||||||
|
};
|
||||||
|
const jsonData = JSON.stringify(data);
|
||||||
|
|
||||||
|
console.log(`Sending: ${jsonData}`);
|
||||||
|
client.write(jsonData);
|
||||||
|
});
|
||||||
|
|
||||||
|
client.on('close', () => {
|
||||||
|
console.log('Closing connection');
|
||||||
|
});
|
||||||
|
|
||||||
|
client.on('error', (err) => {
|
||||||
|
console.error('Error:', err);
|
||||||
|
});
|
Loading…
Reference in New Issue