from flask import Flask, request, jsonify, send_file from flask_cors import CORS from PIL import Image, ImageDraw import io import json import os import uuid import google.generativeai as genai generation_config = { "temperature": 1, "max_output_tokens": 8192, } safety_settings = [ { "category": "HARM_CATEGORY_HARASSMENT", "threshold": "BLOCK_NONE" }, { "category": "HARM_CATEGORY_HATE_SPEECH", "threshold": "BLOCK_NONE" }, { "category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "threshold": "BLOCK_NONE" }, { "category": "HARM_CATEGORY_DANGEROUS_CONTENT", "threshold": "BLOCK_NONE" }, ] GOOGLE_API_KEY = os.environ.get("TOKEN") # Configuration de l'API Gemini genai.configure(api_key=GOOGLE_API_KEY) # Remplacez par votre clé API app = Flask(__name__) CORS(app) @app.route('/', methods=['GET']) def svt(): """Renders the SVT page.""" return render_template("svt.html") # Prompt pour la détection d'objets DETECTION_PROMPT = "Detect items, with no more than 20 items. Output a json list where each entry contains the 2D bounding box in \"box_2d\" and a text label in \"label\"." # Prompt pour la description d'image satellite militaire DESCRIPTION_PROMPT = """ Décrivez en détail cette image satellite militaire. Soyez précis et exhaustif dans votre analyse. Identifiez les éléments clés tels que : - **Infrastructures** : Bâtiments, routes, ponts, aéroports, ports, etc. - **Véhicules** : Chars, avions, navires, véhicules de transport de troupes, etc. - **Unités militaires** : Formations de troupes, positions d'artillerie, camps, etc. - **Défenses** : Bunkers, tranchées, barbelés, etc. - **Éléments géographiques** : Relief, végétation, cours d'eau, etc. - **Activités** : Mouvements de troupes, entraînements, constructions, etc. - **Anomalies** : Tout ce qui semble inhabituel ou suspect. Fournissez une évaluation globale de la situation et des implications stratégiques possibles. """ # Dossier pour enregistrer temporairement les images UPLOAD_FOLDER = 'uploads' app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER os.makedirs(UPLOAD_FOLDER, exist_ok=True) @app.route('/analyze', methods=['POST']) def analyze_image(): try: if 'file' not in request.files: return jsonify({'error': 'No file part'}), 400 file = request.files['file'] if file.filename == '': return jsonify({'error': 'No selected file'}), 400 if file: # Générer un nom de fichier unique pour éviter les conflits unique_filename = str(uuid.uuid4()) + os.path.splitext(file.filename)[1] filename = os.path.join(app.config['UPLOAD_FOLDER'], unique_filename) file.save(filename) # 1. Détection d'objets avec Gemini model = genai.GenerativeModel("gemini-1.5-flash-exp",safety_settings=safety_settings,generation_config=generation_config) image_part = { "mime_type": "image/jpeg", # Assurez-vous que cela corresponde au type de votre image "data": open(filename, "rb").read() # Le fichier est lu ici } response = model.generate_content([DETECTION_PROMPT, image_part]) try: detection_results = json.loads(response.text) except json.JSONDecodeError: print(f"Erreur de décodage JSON : {response.text}") return jsonify({'error': 'Erreur lors de la détection des objets (JSON invalide)'}), 500 # 2. Dessiner les boîtes englobantes image = Image.open(filename) draw = ImageDraw.Draw(image) for item in detection_results: box = item['box_2d'] label = item['label'] draw.rectangle(box, outline=(255, 0, 0), width=2) text_position = (box[0], box[1] - 10) draw.text(text_position, label, fill=(255, 255, 255)) # Enregistrer l'image avec les boîtes output_filename = os.path.join(app.config['UPLOAD_FOLDER'], 'output_' + unique_filename) image.save(output_filename) # 3. Générer la description response = model.generate_content([DESCRIPTION_PROMPT, image_part]) description = response.text # 4. Renvoyer les résultats return jsonify({ 'image_path': '/uploads/' + 'output_' + unique_filename, # Chemin relatif vers l'image 'description': description, 'detected_objects': detection_results }) except Exception as e: print(f"Une erreur s'est produite : {e}") return jsonify({'error': f'Erreur lors du traitement de l\'image : {e}'}), 500 # Servir les fichiers statiques depuis le dossier 'uploads' @app.route('/uploads/') def uploaded_file(filename): return send_file(os.path.join(app.config['UPLOAD_FOLDER'], filename)) if __name__ == '__main__': app.run(debug=True)