7 Commits

Author SHA1 Message Date
1431d2c164 updated set up docs 2025-01-27 08:41:19 +01:00
0a8b96a45a increase image compression level and re-enabled thread 2025-01-22 13:46:47 +01:00
69eba455f9 added image compression to thread 2025-01-22 13:32:43 +01:00
e262325565 disabled image logick 2025-01-22 12:28:36 +01:00
ishak jmilou.ishak
f493665275 riep de functie nergens aan 2025-01-21 16:13:26 +01:00
ishak jmilou.ishak
899aa94b40 seperate yolo results because it updates now only when going to /yolo_results 2025-01-21 16:01:59 +01:00
ishak jmilou.ishak
d5524d7890 shouldn't have done POST 2025-01-21 15:09:23 +01:00
3 changed files with 25 additions and 13 deletions

View File

@@ -30,7 +30,7 @@ This project is a kobuki that drives around in dangerous areas and detects objec
3. **Install the required packages**
- Install the following packages on the server: "docker docker-buildx mosquitto nginx"
- Install the following packages on the Raspberry Pi: "g++ make cmake", https://github.com/eclipse-paho/paho.mqtt.c, https://github.com/eclipse-paho/paho.mqtt.cpp
- Install the following packages on the Raspberry Pi: "g++ make cmake libopencv-dev libssl-dev", https://github.com/eclipse-paho/paho.mqtt.c, https://github.com/eclipse-paho/paho.mqtt.cpp

View File

@@ -407,6 +407,7 @@ std::string serializeKobukiData(const TKobukiData &data)
json += "]}";
return json;
}
// create extra function to send the message every 100ms
// needed it so it can be threaded
void sendKobukiData(TKobukiData &data)
@@ -420,7 +421,8 @@ void sendKobukiData(TKobukiData &data)
}
void CapnSend() {
VideoCapture cap(0);
int COMPRESSION_LEVEL = 90;
VideoCapture cap(0); // Open the camera
if (!cap.isOpened()) {
cerr << "Error: Could not open camera" << endl;
return;
@@ -444,14 +446,21 @@ void CapnSend() {
}
}
// Convert the image to a byte array
vector<uchar> buf;
imencode(".jpg", frame, buf);
auto *enc_msg = reinterpret_cast<unsigned char *>(buf.data());
// Publish the image data
client.publishMessage("kobuki/cam", string(enc_msg, enc_msg + buf.size()));
cout << "Sent image" << endl;
vector<uchar> imgbuf;
vector<int> compression_params;
compression_params.push_back(IMWRITE_JPEG_QUALITY); // Set JPEG quality
compression_params.push_back(COMPRESSION_LEVEL); // Adjust the quality level (0-100, lower = more compression)
// Encode the image into the byte buffer with the specified compression parameters
imencode(".jpg", frame, imgbuf, compression_params);
// Convert the vector<uchar> buffer to a string (no casting)
string enc_msg(imgbuf.begin(), imgbuf.end());
// Publish the compressed image data (MQTT, in this case)
client.publishMessage("kobuki/cam", enc_msg);
cout << "Sent compressed image" << endl;
std::this_thread::sleep_for(std::chrono::milliseconds(200)); // Send image every 200ms
}

View File

@@ -85,6 +85,7 @@ def index():
@app.route('/control', methods=["GET", "POST"])
def control():
if request.authorization and request.authorization.username == 'ishak' and request.authorization.password == 'kobuki':
yolo_results_db()
return render_template('control.html')
else:
return ('Unauthorized', 401, {'WWW-Authenticate': 'Basic realm="Login Required"'})
@@ -158,9 +159,13 @@ def image():
return "No image available", 404
@app.route('/yolo_results', methods=['GET', 'POST'])
@app.route('/yolo_results', methods=['GET'])
def yolo_results_endpoint():
global yolo_results
global yolo_results
return jsonify(yolo_results)
def yolo_results_db():
global yolo_results
with lock:
try:
db = get_db()
@@ -175,8 +180,6 @@ def yolo_results_endpoint():
print(f"Database error: {err}")
except Exception as e:
print(f"Unexpected error: {e}")
return jsonify(yolo_results)
if __name__ == '__main__':
app.run(debug=True, port=5000)