import streamlit as st
import cv2
import numpy as np
import datetime
import os
import time
import base64
import re
import glob
from camera_input_live import camera_input_live
# Set wide layout
st.set_page_config(layout="wide")
# Decorator for caching images
def get_image_count():
return {'count': 0}
# Function Definitions for Camera Feature
def save_image(image, image_count):
timestamp = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")
filename = f"captured_image_{timestamp}_{image_count['count']}.png"
image_count['count'] += 1
bytes_data = image.getvalue()
cv2_img = cv2.imdecode(np.frombuffer(bytes_data, np.uint8), cv2.IMREAD_COLOR)
cv2.imwrite(filename, cv2_img)
return filename
def get_image_base64(image_path):
with open(image_path, "rb") as image_file:
return base64.b64encode(image_file.read()).decode()
# Function Definitions for Chord Sheet Feature
def process_line(line):
if re.search(r'\b[A-G][#b]?m?\b', line):
line = re.sub(r'\b([A-G][#b]?m?)\b', r"", line)
return line
def process_sheet(sheet):
processed_lines = []
for line in sheet.split('\n'):
processed_line = process_line(line)
processed_lines.append(processed_line)
return '
'.join(processed_lines)
# Main Function
def main():
# Layout Configuration
col1, col2 = st.columns([2, 3])
# Camera Section
with col1:
#st.markdown("📹 Real-Time Camera Stream 🚀")
#st.markdown("## 👁️🗨️ Eye on the World: Real-Time Camera Stream 🌐")
#st.markdown("🔴 Live Feed: Real-Time Camera Stream 🎥")
#st.markdown("🌟 Instant Vision: Real-Time Camera Stream 📸")
#st.markdown("🕵️♂️ Spy Mode: Real-Time Camera Stream 🕶️")
#st.markdown("🚀 Explore Now: Real-Time Camera Stream 🌍")
#st.markdown("💡 Illuminate: Real-Time Camera Stream 🔦")
#st.markdown("🌉 Views Unfold: Real-Time Camera Stream 🏞️")
st.markdown("✨ Magic Lens: Real-Time Camera Stream 🌈")
snapshot_interval = st.slider("Snapshot Interval (seconds)", 1, 10, 5)
image_placeholder = st.empty()
if 'captured_images' not in st.session_state:
st.session_state['captured_images'] = []
if 'last_captured' not in st.session_state:
st.session_state['last_captured'] = time.time()
image = camera_input_live()
if image is not None:
image_placeholder.image(image)
if time.time() - st.session_state['last_captured'] > snapshot_interval:
image_count = get_image_count()
filename = save_image(image, image_count)
st.session_state['captured_images'].append(filename)
st.session_state['last_captured'] = time.time()
sidebar_html = "