Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #11 (permalink)  
Старый 05.11.2017, 10:46
Аспирант
Отправить личное сообщение для Grasss Посмотреть профиль Найти все сообщения от Grasss
 
Регистрация: 03.11.2017
Сообщений: 44

Воспроизведение будет осуществляться этой функцией через 2 сек после загрузки страницы
<script class="source" type="text/javascript">
$('.countdown').downCount({date:'11/04/2017 23:30:00',offset: +3},function (){
function foo(){$("#start").click();}setTimeout(foo, 2000);
});</script>

работает во всех браузерах на пк, а вот на iphone в браузерах safari, chrome и яндекс функция
function foo(){$("#start").click();}setTimeout(foo, 2000);
отказывается работать, она работает только в opera.
Ответить с цитированием
  #12 (permalink)  
Старый 05.11.2017, 15:05
Профессор
Отправить личное сообщение для Rasy Посмотреть профиль Найти все сообщения от Rasy
 
Регистрация: 17.06.2016
Сообщений: 509

Сообщение от Grasss
работает во всех браузерах на пк, а вот на iphone в браузерах safari, chrome и яндекс функция
Думаю там другая ошибка. Чтобы узнать, нужно протестировать на одном из мобильных браузеров, заглянув в консоль браузера.
Ответить с цитированием
  #13 (permalink)  
Старый 05.11.2017, 20:09
Аспирант
Отправить личное сообщение для Grasss Посмотреть профиль Найти все сообщения от Grasss
 
Регистрация: 03.11.2017
Сообщений: 44

Если нажимать кнопки start / stopp, то всё работает, а вот автоклик после setTimeout капризный. Будет время у вас, посмотрите в чем может быть дело. А что если попробовать заменить setTimeout на var start_time = '21:52'; для старта вещания, а потом функция var end_time = '23:52'; останавливает видео)

Примерно так:
function (){$("#start").click();}var start_time = '21:52';

function (){$("#stopp").click();}var end_time = '23:52';

Последний раз редактировалось Grasss, 05.11.2017 в 20:15.
Ответить с цитированием
  #14 (permalink)  
Старый 05.11.2017, 20:46
Профессор
Отправить личное сообщение для Rasy Посмотреть профиль Найти все сообщения от Rasy
 
Регистрация: 17.06.2016
Сообщений: 509

Так должно сработать
function onPlayerReady(event) {
		start.onclick = function() {
			event.target.playVideo();
		};
		setTimeout(function() {
			start.click();
		}, 2000);
}
Ответить с цитированием
  #15 (permalink)  
Старый 05.11.2017, 21:58
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,121



попробуйте заменить id start на что-то другое, можно даже startt
Ответить с цитированием
  #16 (permalink)  
Старый 05.11.2017, 22:15
Профессор
Отправить личное сообщение для Rasy Посмотреть профиль Найти все сообщения от Rasy
 
Регистрация: 17.06.2016
Сообщений: 509

рони,
Со start работает я проверял. Вот со stop была такая ситуация. Возможно с play бы не сработало. Но да, аспект важный
Ответить с цитированием
  #17 (permalink)  
Старый 06.11.2017, 03:27
Новичок на форуме
Отправить личное сообщение для fass Посмотреть профиль Найти все сообщения от fass
 
Регистрация: 06.11.2017
Сообщений: 1

Сообщение от Grasss Посмотреть сообщение
Огромное спасибо за помощь
Сообщение от Rasy Посмотреть сообщение
Это не нужно. Если пользователь зайдет в Сиднее в 17:40, а начало запланировано на 17:30, то перемотается 10 минут ролика. Тем времен в Москве будет утро.

В модальное окно нужно добавить див <div id="player"></div>, и удалить текущий ифрейм. Скрипт сам добавит его.

Да. В функциях onPlayerReady, stopVideo дописать логику.

<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Воспроизведение видео на сайте по расписанию</title>
</head>
<body>
	<div id="player"></div>
	<div>
		<button type="button" id="start">start</button>
		<button type="button" id="stopp">stop</button>
	</div>
	<script type="text/javascript"></script>
	<script>
			var start_time = '21:52';
			var end_time = '23:52';
			start_time = start_time.split(':');
			end_time = end_time.split(':');

			var tag = document.createElement('script');
			tag.src = "https://www.youtube.com/iframe_api";
			var firstScriptTag = document.getElementsByTagName('script')[0];
			firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);

			var player;
			function onYouTubeIframeAPIReady() {
				player = new YT.Player('player', {
					height: '315',
					width: '560',
					videoId: 'dwiGTtbo6WM',
					events: {
						'onReady': onPlayerReady,
						'onStateChange': onPlayerStateChange
					}
				});
			}
			
			function onPlayerReady(event) {
					start.onclick = function() {
						event.target.playVideo();
					};
			}

			var jump = false;
			function onPlayerStateChange(event) {
				if (event.data == YT.PlayerState.PLAYING && !jump) {
					player.seekTo(getSeconds());
					jump = true;
				}
			}
			function stopVideo() {
				player.stopVideo();
			}
			stopp.onclick = function() {
				stopVideo();
			};

			var d = new Date();
			var h = d.getHours();
			var m = d.getMinutes();
			function getSeconds() {
				if (h > end_time[0] || h == end_time[0] && m > end_time[1]) return 0;
				if (h >= start_time[0]) {
					var time_now = d;
					var time_start = new Date(d.getFullYear(), d.getMonth(), d.getDate(), start_time[0], start_time[1]);
					var time_end = new Date(d.getFullYear(), d.getMonth(), d.getDate(), end_time[0], end_time[1]);
					return ((time_end - time_start) - (time_end - time_now)) / 1000;
				}
				return 0;
			}

	</script>
</body>
</html>

Возможна ли реализация данного решения, но уже к видео лежащему в папке сайта на хостинге? <video src="video/test.mp4"></video>
Ответить с цитированием
  #18 (permalink)  
Старый 06.11.2017, 11:35
Профессор
Отправить личное сообщение для Rasy Посмотреть профиль Найти все сообщения от Rasy
 
Регистрация: 17.06.2016
Сообщений: 509

Сообщение от fass
Возможна ли реализация данного решения, но уже к видео лежащему в папке сайта на хостинге?
Решения для видео из ютуба.
Ответить с цитированием
  #19 (permalink)  
Старый 06.11.2017, 11:47
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,121


<video></video> и video.currentTime
Ответить с цитированием
  #20 (permalink)  
Старый 06.11.2017, 20:54
Аспирант
Отправить личное сообщение для Grasss Посмотреть профиль Найти все сообщения от Grasss
 
Регистрация: 03.11.2017
Сообщений: 44

Если видео достаточно увесистое, то подгружаясь с хостинга оно съест кучу трафика и не факт что твой проигрыватель будет корректно отображаться всеми устройствами, поэтому для этих целей вполне хватит и YouTube, он оптимизирован под все устройства и быстро загружает контент, не съедая тонны трафика. Другое дело, если ты загружаешь видео нарушающее авторские права и тп, которое YouTube не пропустит, тут уже потребуются другие видеохостинги.

Последний раз редактировалось Grasss, 06.11.2017 в 21:00.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Помогите сделать автозапуск видео на сайте Petrovna80 Ваши сайты и скрипты 4 02.09.2016 23:24
автовоспроизведение видео на сайте jonrut Events/DOM/Window 0 20.04.2016 12:23
Автозапуск видео на сайте. Видео подгружается через js pirlo_29 Общие вопросы Javascript 0 24.12.2013 20:57
Управление скроллом "а-ля тач" HonesT Элементы интерфейса 2 27.08.2013 14:25
видео на сайте karencho7777 Элементы интерфейса 0 05.11.2012 15:05