AI_Photographer/Web/direct_camera.html
2026-04-12 18:52:37 +04:00

57 lines
2.3 KiB
HTML

<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Direct Camera Service</title>
<link rel="stylesheet" href="/static/direct_camera.css">
</head>
<body>
<div class="wrap">
<div class="top">
<section class="panel">
<h1>Direct Camera Service</h1>
<div class="meta">Main camera service. No teleimager. Direct RealSense/OpenCV camera access only.</div>
<img id="preview_img" class="preview" src="/preview.mjpg" alt="preview">
<div class="actions">
<button id="capture_btn">Capture</button>
<button id="refresh_btn" class="secondary">Refresh</button>
<a class="btn secondary" href="/api/download_all.zip">Download All</a>
</div>
<div id="status" class="status">Loading...</div>
</section>
<section class="panel">
<h2>Camera</h2>
<div class="meta">Sample captures are saved in <code>photos/samples/</code>.</div>
<div class="actions">
<select id="resolution_select">
<option value="">Preset</option>
<option value="640x480@30">640x480 @ 30</option>
<option value="640x480@15">640x480 @ 15</option>
<option value="848x480@30">848x480 @ 30</option>
<option value="848x480@15">848x480 @ 15</option>
<option value="960x540@15">960x540 @ 15</option>
<option value="1280x720@30">1280x720 @ 30</option>
<option value="1280x720@15">1280x720 @ 15</option>
</select>
<input id="width_input" type="number" min="1" step="1" placeholder="width">
<input id="height_input" type="number" min="1" step="1" placeholder="height">
<input id="fps_input" type="number" min="1" step="1" placeholder="fps">
<button id="apply_resolution_btn" class="secondary">Apply Resolution</button>
</div>
<div class="meta">Choose a preset or enter width, height, and fps manually. The stream will reopen with the new settings.</div>
<div id="camera_status" class="status">Checking camera...</div>
</section>
</div>
<section class="panel panel-space">
<h2>Samples</h2>
<div id="gallery" class="grid"></div>
</section>
</div>
<script src="/static/direct_camera.js"></script>
</body>
</html>