projekt-7/Script_Speech_recognition/videoplayer.js
2024-11-17 20:19:16 +01:00

127 lines
3.3 KiB
JavaScript

const inputText = document.getElementById('inputText');
const videoPlayer = document.getElementById('translationVideo');
const translateWordsBtn = document.getElementById('translateWordsBtn');
const translateLettersBtn = document.getElementById('translateLettersBtn');
const prevBtn = document.getElementById('prevBtn');
const nextBtn = document.getElementById('nextBtn');
const translateBtn = document.getElementById('translateBtn');
let videoSequence = [];
let currentIndex = 0;
let autoPlayEnabled = true;
let currentTranslationMode = 'words';
async function videoExists(src) {
return new Promise(resolve => {
const video = document.createElement('video');
video.src = src;
video.onloadeddata = () => resolve(true);
video.onerror = () => resolve(false);
});
}
async function loadVideoSequenceByWords() {
const words = inputText.value.trim().split(' ');
videoSequence = [];
for (const word of words) {
const videoSrc = `video/${word.toLowerCase()}.mp4`;
if (await videoExists(videoSrc)) {
videoSequence.push(videoSrc);
}
}
currentIndex = 0;
}
async function loadVideoSequenceByLetters() {
const characters = inputText.value.trim().split('');
videoSequence = [];
for (const char of characters) {
if (/[a-zA-Z]/.test(char)) {
const videoSrc = `video/pismena/${char.toLowerCase()}.mp4`;
if (await videoExists(videoSrc)) {
videoSequence.push(videoSrc);
}
}
}
currentIndex = 0;
}
function playVideoAtIndex(index) {
if (index < 0 || index >= videoSequence.length) return;
videoPlayer.src = videoSequence[index];
videoPlayer.play();
currentIndex = index;
const currentChar = videoSequence[index].split('/').pop().split('.')[0];
document.getElementById('currentLetter').innerText = currentChar.toUpperCase();
if (autoPlayEnabled) {
videoPlayer.onended = () => {
currentIndex++;
if (currentIndex < videoSequence.length) {
playVideoAtIndex(currentIndex);
} else {
autoPlayEnabled = false;
}
};
} else {
videoPlayer.onended = null;
}
}
translateBtn.addEventListener('click', async () => {
autoPlayEnabled = true;
if (currentTranslationMode === 'words') {
await loadVideoSequenceByWords();
} else if (currentTranslationMode === 'letters') {
await loadVideoSequenceByLetters();
}
if (videoSequence.length > 0) {
playVideoAtIndex(currentIndex);
}
});
translateWordsBtn.addEventListener('click', () => {
currentTranslationMode = 'words';
translateWordsBtn.classList.add('active');
translateLettersBtn.classList.remove('active');
});
translateLettersBtn.addEventListener('click', () => {
currentTranslationMode = 'letters';
translateLettersBtn.classList.add('active');
translateWordsBtn.classList.remove('active');
});
prevBtn.addEventListener('click', () => {
if (currentIndex > 0) {
autoPlayEnabled = false;
currentIndex--;
playVideoAtIndex(currentIndex);
}
});
nextBtn.addEventListener('click', () => {
if (currentIndex < videoSequence.length - 1) {
autoPlayEnabled = false;
currentIndex++;
playVideoAtIndex(currentIndex);
}
});