var periodical_id; var pauseBtn = $j('#pauseBtn'); var playBtn = $j('#playBtn'); function nextCycleView() { window.location.replace('?view=cycle&mid='+nextMid+'&mode='+mode, cycleRefreshTimeout); } function cyclePause() { $clear(periodical_id); pauseBtn.prop('disabled', true); playBtn.prop('disabled', false); } function cycleStart() { periodical_id = nextCycleView.periodical(cycleRefreshTimeout); pauseBtn.prop('disabled', false); playBtn.prop('disabled', true); } function cycleNext() { monIdx ++; if ( monIdx >= monitorData.length ) { monIdx = 0; } if ( !monitorData[monIdx] ) { console.log('No monitorData for ' + monIdx); } window.location.replace('?view=cycle&mid='+monitorData[monIdx].id+'&mode='+mode, cycleRefreshTimeout); } function cyclePrev() { if ( monIdx ) { monIdx -= 1; } else { monIdx = monitorData.length - 1; } window.location.replace('?view=cycle&mid='+monitorData[monIdx].id+'&mode='+mode, cycleRefreshTimeout); } function initCycle() { periodical_id = nextCycleView.periodical(cycleRefreshTimeout); var scale = $j('#scale').val(); if ( scale == '0' || scale == 'auto' ) changeScale(); } function changeSize() { var width = $j('#width').val(); var height = $j('#height').val(); // Scale the frame monitor_frame = $j('#imageFeed'); if ( !monitor_frame ) { console.log('Error finding frame'); return; } if ( width ) { monitor_frame.css('width', width); } if ( height ) { monitor_frame.css('height', height); } /* Stream could be an applet so can't use moo tools */ var streamImg = document.getElementById('liveStream'+monitorData[monIdx].id); if ( streamImg ) { if ( streamImg.nodeName == 'IMG' ) { var src = streamImg.src; streamImg.src = ''; console.log(parseInt(width)); src = src.replace(/width=[\.\d]+/i, 'width='+parseInt(width)); src = src.replace(/height=[\.\d]+/i, 'height='+parseInt(height)); src = src.replace(/rand=\d+/i, 'rand='+Math.floor((Math.random() * 1000000) )); streamImg.src = src; } streamImg.style.width = width ? width : null; streamImg.style.height = height ? height : null; } else { console.log('Did not find liveStream'+monitorData[monIdx].id); } $j('#scale').val(''); Cookie.write('zmCycleScale', '', {duration: 10*365, samesite: 'strict'}); Cookie.write('zmCycleWidth', width, {duration: 10*365, samesite: 'strict'}); Cookie.write('zmCycleHeight', height, {duration: 10*365, samesite: 'strict'}); } // end function changeSize() function changeScale() { var scale = $j('#scale').val(); $j('#width').val('auto'); $j('#height').val('auto'); Cookie.write('zmCycleScale', scale, {duration: 10*365, samesite: 'strict'}); Cookie.write('zmCycleWidth', 'auto', {duration: 10*365, samesite: 'strict'}); Cookie.write('zmCycleHeight', 'auto', {duration: 10*365, samesite: 'strict'}); var newWidth = ( monitorData[monIdx].width * scale ) / SCALE_BASE; var newHeight = ( monitorData[monIdx].height * scale ) / SCALE_BASE; // Scale the frame monitor_frame = $j('#imageFeed'); if ( !monitor_frame ) { console.log('Error finding frame'); return; } if ( scale != '0' && scale != '' && scale != 'auto' ) { var newWidth = ( monitorData[monIdx].width * scale ) / SCALE_BASE; var newHeight = ( monitorData[monIdx].height * scale ) / SCALE_BASE; if ( newWidth ) { monitor_frame.css('width', newWidth+'px'); } if ( newHeight ) { monitor_frame.css('height', newHeight+'px'); } } else { //var bottomEl = streamMode == 'stills' ? $j('#eventImageNav') : $j('#replayStatus'); var newSize = scaleToFit(monitorData[monIdx].width, monitorData[monIdx].height, monitor_frame, $j('#buttons')); newWidth = newSize.width; newHeight = newSize.height; autoScale = newSize.autoScale; monitor_frame.width(newWidth); monitor_frame.height(newHeight); } /*Stream could be an applet so can't use moo tools*/ var streamImg = $j('#liveStream'+monitorData[monIdx].id)[0]; if ( !streamImg ) { console.log("Did not find liveStream"+monitorData[monIdx].id); return; } if ( streamImg.nodeName == 'IMG' ) { var src = streamImg.src; streamImg.src = ''; //src = src.replace(/rand=\d+/i,'rand='+Math.floor((Math.random() * 1000000) )); src = src.replace(/scale=[\.\d]+/i, 'scale='+scale); // zms doesn't actually use width&height if ( scale != '0' && scale != '' && scale != 'auto' ) { src = src.replace(/width=[\.\d]+/i, 'width='+newWidth); src = src.replace(/height=[\.\d]+/i, 'height='+newHeight); } else { src = src.replace(/width=[\.\d]+/i, 'width='+monitorData[monIdx].width); src = src.replace(/height=[\.\d]+/i, 'height='+monitorData[monIdx].height); } streamImg.src = src; } if ( scale != '0' && scale != '' && scale != 'auto' ) { streamImg.style.width = newWidth+'px'; streamImg.style.height = newHeight+'px'; } else { streamImg.style.width = '100%'; streamImg.style.height = 'auto'; } } // end function changeScale() $j(document).ready(initCycle);