commit
					ec994e6a67
				
				 10 changed files with 222 additions and 0 deletions
			
			
		@ -0,0 +1,3 @@
					 | 
				
			||||
# Default ignored files | 
				
			||||
/shelf/ | 
				
			||||
/workspace.xml | 
				
			||||
@ -0,0 +1,10 @@
					 | 
				
			||||
<?xml version="1.0" encoding="UTF-8"?> | 
				
			||||
<module type="PYTHON_MODULE" version="4"> | 
				
			||||
  <component name="NewModuleRootManager"> | 
				
			||||
    <content url="file://$MODULE_DIR$"> | 
				
			||||
      <excludeFolder url="file://$MODULE_DIR$/.venv" /> | 
				
			||||
    </content> | 
				
			||||
    <orderEntry type="inheritedJdk" /> | 
				
			||||
    <orderEntry type="sourceFolder" forTests="false" /> | 
				
			||||
  </component> | 
				
			||||
</module> | 
				
			||||
@ -0,0 +1,6 @@
					 | 
				
			||||
<component name="InspectionProjectProfileManager"> | 
				
			||||
  <settings> | 
				
			||||
    <option name="USE_PROJECT_PROFILE" value="false" /> | 
				
			||||
    <version value="1.0" /> | 
				
			||||
  </settings> | 
				
			||||
</component> | 
				
			||||
@ -0,0 +1,7 @@
					 | 
				
			||||
<?xml version="1.0" encoding="UTF-8"?> | 
				
			||||
<project version="4"> | 
				
			||||
  <component name="Black"> | 
				
			||||
    <option name="sdkName" value="Python 3.12 (YOLOv8)" /> | 
				
			||||
  </component> | 
				
			||||
  <component name="ProjectRootManager" version="2" project-jdk-name="Python 3.12 (YOLOv8)" project-jdk-type="Python SDK" /> | 
				
			||||
</project> | 
				
			||||
@ -0,0 +1,8 @@
					 | 
				
			||||
<?xml version="1.0" encoding="UTF-8"?> | 
				
			||||
<project version="4"> | 
				
			||||
  <component name="ProjectModuleManager"> | 
				
			||||
    <modules> | 
				
			||||
      <module fileurl="file://$PROJECT_DIR$/.idea/YOLOv8.iml" filepath="$PROJECT_DIR$/.idea/YOLOv8.iml" /> | 
				
			||||
    </modules> | 
				
			||||
  </component> | 
				
			||||
</project> | 
				
			||||
@ -0,0 +1,37 @@
					 | 
				
			||||
import cv2 | 
				
			||||
from ultralytics import YOLO | 
				
			||||
 | 
				
			||||
# Загрузим YOLOv8 модель (если ты скачал .pt файл вручную, укажи путь) | 
				
			||||
model = YOLO('yolov8n.pt')  # автоматически скачается, если файла нет | 
				
			||||
 | 
				
			||||
# Открываем веб-камеру | 
				
			||||
cap = cv2.VideoCapture(0) | 
				
			||||
 | 
				
			||||
while True: | 
				
			||||
    ret, frame = cap.read() | 
				
			||||
    if not ret: | 
				
			||||
        break | 
				
			||||
 | 
				
			||||
    # Детекция объектов | 
				
			||||
    results = model(frame)[0] | 
				
			||||
 | 
				
			||||
    for result in results.boxes: | 
				
			||||
        cls_id = int(result.cls[0]) | 
				
			||||
        conf = float(result.conf[0]) | 
				
			||||
        if model.names[cls_id] == 'person': | 
				
			||||
            x1, y1, x2, y2 = map(int, result.xyxy[0]) | 
				
			||||
            # Зелёная рамка | 
				
			||||
            cv2.rectangle(frame, (x1, y1), (x2, y2), (0, 255, 0), 2) | 
				
			||||
            # Текст | 
				
			||||
            label = f'{model.names[cls_id]} {conf:.2f}' | 
				
			||||
            cv2.putText(frame, label, (x1, y1 - 5), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0,255,0), 1) | 
				
			||||
 | 
				
			||||
    # Показываем результат | 
				
			||||
    cv2.imshow("Detection", frame) | 
				
			||||
 | 
				
			||||
    # Выход — по клавише ESC | 
				
			||||
    if cv2.waitKey(1) & 0xFF == 27: | 
				
			||||
        break | 
				
			||||
 | 
				
			||||
cap.release() | 
				
			||||
cv2.destroyAllWindows() | 
				
			||||
@ -0,0 +1,99 @@
					 | 
				
			||||
import cv2 | 
				
			||||
import time | 
				
			||||
import os | 
				
			||||
from ultralytics import YOLO | 
				
			||||
import logging | 
				
			||||
 | 
				
			||||
# Отключаем вывод ненужных логов из ultralytics | 
				
			||||
logging.getLogger('ultralytics').setLevel(logging.WARNING) | 
				
			||||
 | 
				
			||||
# Загружаем модель YOLOv8 | 
				
			||||
model = YOLO('yolov8n.pt') | 
				
			||||
 | 
				
			||||
# Захват видео с камеры | 
				
			||||
cap = cv2.VideoCapture(0) | 
				
			||||
 | 
				
			||||
# Устанавливаем разрешение для захвата кадров | 
				
			||||
cap.set(cv2.CAP_PROP_FRAME_WIDTH, 1920) | 
				
			||||
cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 1080) | 
				
			||||
 | 
				
			||||
# Получаем FPS из камеры | 
				
			||||
fps = cap.get(cv2.CAP_PROP_FPS) | 
				
			||||
print(f"FPS камеры: {fps}") | 
				
			||||
 | 
				
			||||
# Установим FPS записи видео равным FPS камеры | 
				
			||||
record_fps = fps  # Записываем с FPS, который камера реально поддерживает | 
				
			||||
 | 
				
			||||
# Время между кадрами (в секундах) | 
				
			||||
frame_interval = 1 / record_fps | 
				
			||||
 | 
				
			||||
recording = False | 
				
			||||
record_start_time = 0 | 
				
			||||
out = None | 
				
			||||
last_frame_time = 0 | 
				
			||||
 | 
				
			||||
# Путь для сохранения видео | 
				
			||||
save_dir = r'C:\Users\ilyac\PycharmProjects\YOLOv8\.venv\video' | 
				
			||||
os.makedirs(save_dir, exist_ok=True)  # Создаст папку, если не существует | 
				
			||||
 | 
				
			||||
# Используем кодек MJPG для записи видео с хорошим качеством | 
				
			||||
fourcc = cv2.VideoWriter_fourcc(*'MJPG') | 
				
			||||
 | 
				
			||||
while True: | 
				
			||||
    ret, frame = cap.read() | 
				
			||||
    if not ret: | 
				
			||||
        break | 
				
			||||
 | 
				
			||||
    # Применяем модель YOLOv8 для обнаружения объектов | 
				
			||||
    results = model(frame)[0] | 
				
			||||
    person_detected = False | 
				
			||||
 | 
				
			||||
    # Проходим по результатам и рисуем рамки вокруг людей | 
				
			||||
    for result in results.boxes: | 
				
			||||
        cls_id = int(result.cls[0]) | 
				
			||||
        if model.names[cls_id] == 'person': | 
				
			||||
            person_detected = True | 
				
			||||
            x1, y1, x2, y2 = map(int, result.xyxy[0]) | 
				
			||||
            # Уменьшаем ширину рамки на 20% | 
				
			||||
            width_shrink = int((x2 - x1) * 0.2) | 
				
			||||
            x1 += width_shrink | 
				
			||||
            x2 -= width_shrink | 
				
			||||
            cv2.rectangle(frame, (x1, y1), (x2, y2), (0, 255, 0), 2) | 
				
			||||
 | 
				
			||||
    # Начинаем запись, если человек был обнаружен | 
				
			||||
    if person_detected and not recording: | 
				
			||||
        print("🟢 Обнаружен человек — начинаю запись на 10 секунд") | 
				
			||||
        record_start_time = time.time() | 
				
			||||
        timestamp = time.strftime('%Y-%m-%d_%H-%M-%S') | 
				
			||||
        video_path = os.path.join(save_dir, f'person_{timestamp}.avi') | 
				
			||||
        out = cv2.VideoWriter(video_path, fourcc, record_fps, (frame.shape[1], frame.shape[0])) | 
				
			||||
        recording = True | 
				
			||||
 | 
				
			||||
    # Запись видео с интервалом времени | 
				
			||||
    if recording: | 
				
			||||
        current_time = time.time() | 
				
			||||
 | 
				
			||||
        # Пишем кадр в видео, если прошло достаточно времени | 
				
			||||
        if current_time - last_frame_time >= frame_interval: | 
				
			||||
            out.write(frame) | 
				
			||||
            last_frame_time = current_time | 
				
			||||
 | 
				
			||||
        # Проверяем, прошло ли 10 секунд | 
				
			||||
        if current_time - record_start_time >= 10: | 
				
			||||
            print("🔴 10 секунд прошло — запись завершена") | 
				
			||||
            recording = False | 
				
			||||
            out.release() | 
				
			||||
            out = None | 
				
			||||
 | 
				
			||||
    # Отображаем видео в окне | 
				
			||||
    cv2.imshow("Live", frame) | 
				
			||||
 | 
				
			||||
    # Выход по клавише ESC | 
				
			||||
    if cv2.waitKey(1) & 0xFF == 27: | 
				
			||||
        break | 
				
			||||
 | 
				
			||||
# Завершаем работу с камерой и записывающим устройством | 
				
			||||
cap.release() | 
				
			||||
if out: | 
				
			||||
    out.release() | 
				
			||||
cv2.destroyAllWindows() | 
				
			||||
@ -0,0 +1,33 @@
					 | 
				
			||||
import cv2 | 
				
			||||
import time | 
				
			||||
 | 
				
			||||
# Открытие видеофайла | 
				
			||||
cap = cv2.VideoCapture(r'C:\Users\ilyac\PycharmProjects\YOLOv8\.venv\video\person_2025-04-07_23-36-45.avi')  # Укажите путь к вашему видеофайлу | 
				
			||||
 | 
				
			||||
if not cap.isOpened(): | 
				
			||||
    print("Ошибка при открытии видео!") | 
				
			||||
    exit() | 
				
			||||
 | 
				
			||||
# Получаем FPS видео (кадров в секунду) | 
				
			||||
fps = cap.get(cv2.CAP_PROP_FPS) | 
				
			||||
print(f"FPS видео: {fps}") | 
				
			||||
 | 
				
			||||
while cap.isOpened(): | 
				
			||||
    ret, frame = cap.read() | 
				
			||||
    if not ret: | 
				
			||||
        break  # Если не удалось прочитать кадр, завершаем | 
				
			||||
 | 
				
			||||
    # Отображаем кадр | 
				
			||||
    cv2.imshow('Video', frame) | 
				
			||||
 | 
				
			||||
    # Добавляем задержку между кадрами для замедления видео | 
				
			||||
    # Если FPS = 30, а мы хотим воспроизводить в 2 раза медленным темпом, ставим задержку 2x | 
				
			||||
    time.sleep(1 / fps * 4)  # Умножаем на 2 для замедления воспроизведения | 
				
			||||
 | 
				
			||||
    # Выход из программы при нажатии клавиши 'ESC' | 
				
			||||
    if cv2.waitKey(1) & 0xFF == 27: | 
				
			||||
        break | 
				
			||||
 | 
				
			||||
# Закрываем все окна и освобождаем ресурсы | 
				
			||||
cap.release() | 
				
			||||
cv2.destroyAllWindows() | 
				
			||||
									
										Binary file not shown.
									
								
							
						
					Loading…
					
					
				
		Reference in new issue