939 lines
30 KiB
PHP
939 lines
30 KiB
PHP
<?php
|
|
//
|
|
// ZoneMinder web watch feed view file, $Date$, $Revision$
|
|
// Copyright (C) 2003, 2004, 2005, 2006 Philip Coombes
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License
|
|
// as published by the Free Software Foundation; either version 2
|
|
// of the License, or (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
//
|
|
|
|
if ( !canView( 'Stream' ) )
|
|
{
|
|
$view = "error";
|
|
return;
|
|
}
|
|
|
|
$sql = "select C.*, M.* from Monitors as M left join Controls as C on (M.ControlId = C.Id ) where M.Id = '$mid'";
|
|
$monitor = dbFetchOne( $sql );
|
|
|
|
$showControls = ( ZM_OPT_CONTROL && $monitor['Controllable'] && canView( 'Control' ) );
|
|
|
|
if ( !isset( $scale ) )
|
|
$scale = reScale( SCALE_BASE, $monitor['DefaultScale'], ZM_WEB_DEFAULT_SCALE );
|
|
|
|
$connkey = generateConnKey();
|
|
|
|
noCacheHeaders();
|
|
|
|
?>
|
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<title><?= ZM_WEB_TITLE_PREFIX ?> - <?= $monitor['Name'] ?> - <?= $zmSlangFeed ?></title>
|
|
<link rel="stylesheet" href="<?= basename(__FILE__,".php") ?>.css" type="text/css" media="screen"/>
|
|
<?php require_once( 'zm_html_js.php' ) ?>
|
|
<script type="text/javascript">
|
|
var STATE_IDLE = <?= STATE_IDLE ?>;
|
|
var STATE_PREALARM = <?= STATE_PREALARM ?>;
|
|
var STATE_ALARM = <?= STATE_ALARM ?>;
|
|
var STATE_ALERT = <?= STATE_ALERT ?>;
|
|
var STATE_TAPE = <?= STATE_TAPE ?>;
|
|
|
|
var url = "<?= ZM_BASE_URL.$PHP_SELF ?>";
|
|
|
|
function setButtonState( element, butclass )
|
|
{
|
|
element.className = butclass;
|
|
element.disabled = (butclass != 'inactive');
|
|
}
|
|
|
|
var showMode = "<?= ($showControls && $control)?"control":"events" ?>";
|
|
function showEvents()
|
|
{
|
|
$('ptzControls').addClass( 'hidden' );
|
|
$('events').removeClass( 'hidden' );
|
|
$('controlToggle').setHTML( '<?= $zmSlangControl ?>' );
|
|
$('controlToggle').setProperty( 'onclick', 'showControls()' );
|
|
showMode = "events";
|
|
}
|
|
|
|
function showControls()
|
|
{
|
|
$('events').addClass( 'hidden' );
|
|
$('ptzControls').removeClass( 'hidden' );
|
|
$('controlToggle').setHTML( '<?= $zmSlangEvents ?>' );
|
|
$('controlToggle').setProperty( 'onclick', 'showEvents()' );
|
|
showMode = "control";
|
|
}
|
|
|
|
function changeScale()
|
|
{
|
|
var scale = $('scale').getValue();
|
|
var baseWidth = <?= $monitor['Width'] ?>;
|
|
var baseHeight = <?= $monitor['Height'] ?>;
|
|
//console.log( "Got new scale: "+scale );
|
|
var newWidth = ( baseWidth * scale ) / <?= SCALE_BASE ?>;
|
|
var newHeight = ( baseHeight * scale ) / <?= SCALE_BASE ?>;
|
|
|
|
streamCmdScale( scale );
|
|
|
|
var streamImg = $('imageFeed').getElement('img');
|
|
if ( !streamImg )
|
|
streamImg = $('imageFeed').getElement('object');
|
|
$(streamImg).setStyles( { width: newWidth, height: newHeight } );
|
|
}
|
|
|
|
var streamCmdParms = "view=request&request=stream&connkey=<?= $connkey ?>";
|
|
var streamCmdTimeoutId = 0;
|
|
|
|
var alarmState = STATE_IDLE;
|
|
var lastAlarmState = STATE_IDLE;
|
|
var status;
|
|
|
|
function getStreamCmdResponse( resp_text )
|
|
{
|
|
if ( streamCmdTimeoutId )
|
|
{
|
|
window.clearTimeout( streamCmdTimeoutId );
|
|
streamCmdTimeoutId = 0;
|
|
}
|
|
if ( !resp_text )
|
|
return;
|
|
var response = Json.evaluate( resp_text );
|
|
status = response.status;
|
|
$('fpsValue').setHTML( status.fps );
|
|
alarmState = status.state;
|
|
var stateString = "Unknown";
|
|
var stateClass = "";
|
|
if ( alarmState <= STATE_PREALARM )
|
|
{
|
|
stateString = "<?= $zmSlangIdle ?>";
|
|
}
|
|
else if ( alarmState == STATE_ALARM )
|
|
{
|
|
stateString = "<?= $zmSlangAlarm ?>";
|
|
stateClass = "alarm";
|
|
}
|
|
else if ( alarmState == STATE_ALERT )
|
|
{
|
|
stateString = "<?= $zmSlangAlert ?>";
|
|
stateClass = "alert";
|
|
}
|
|
else if ( alarmState == STATE_TAPE )
|
|
{
|
|
stateString = "<?= $zmSlangRecord ?>";
|
|
}
|
|
$('stateValue').setHTML( stateString );
|
|
if ( stateClass )
|
|
$('stateValue').setProperty( 'class', stateClass );
|
|
else
|
|
$('stateValue').removeProperty( 'class' );
|
|
$('levelValue').setHTML( status.level );
|
|
if ( status.level > 95)
|
|
{
|
|
$('levelValue').className = "alarm";
|
|
}
|
|
else if ( status.level > 80 )
|
|
{
|
|
$('levelValue').className = "alert";
|
|
}
|
|
else
|
|
{
|
|
$('levelValue').className = "ok";
|
|
}
|
|
|
|
var delayString;
|
|
if ( status.delay < 60 )
|
|
delayString = status.delay;
|
|
else if ( status.delay < 60*60 )
|
|
{
|
|
var mins = parseInt(status.delay/60);
|
|
var secs = status.delay%60;
|
|
if ( secs < 10 )
|
|
secs = '0'+secs.toString().substr( 0, 4 );
|
|
else
|
|
secs = secs.toString().substr( 0, 5 );
|
|
delayString = mins+":"+secs;
|
|
}
|
|
else
|
|
{
|
|
var hours = parseInt(status.delay/3600);
|
|
var mins = (status.delay%3600)/60;
|
|
var secs = status.delay%60;
|
|
if ( mins < 10 )
|
|
mins = '0'+mins.toString().substr( 0, 4 );
|
|
else
|
|
mins = mins.toString().substr( 0, 5 );
|
|
if ( secs < 10 )
|
|
secs = '0'+secs.toString().substr( 0, 4 );
|
|
else
|
|
secs = secs.toString().substr( 0, 5 );
|
|
delayString = hours+":"+mins+":"+secs;
|
|
}
|
|
if ( status.paused == true )
|
|
{
|
|
$('modeValue').setHTML( "Paused" );
|
|
$('rate').addClass( 'hidden' );
|
|
$('delayValue').setHTML( delayString );
|
|
$('delay').removeClass( 'hidden' );
|
|
$('level').removeClass( 'hidden' );
|
|
streamCmdPause( false );
|
|
}
|
|
else if ( status.delayed == true )
|
|
{
|
|
$('modeValue').setHTML( "Replay" );
|
|
$('rateValue').setHTML( status.rate );
|
|
$('rate').removeClass( 'hidden' );
|
|
$('delayValue').setHTML( delayString );
|
|
$('delay').removeClass( 'hidden' );
|
|
$('level').removeClass( 'hidden' );
|
|
if ( status.rate == 1 )
|
|
{
|
|
streamCmdPlay( false );
|
|
}
|
|
else if ( status.rate > 0 )
|
|
{
|
|
if ( status.rate < 1 )
|
|
streamCmdSlowFwd( false );
|
|
else
|
|
streamCmdFastFwd( false );
|
|
}
|
|
else
|
|
{
|
|
if ( status.rate > -1 )
|
|
streamCmdSlowRev( false );
|
|
else
|
|
streamCmdFastRev( false );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$('modeValue').setHTML( "Live" );
|
|
$('rate').addClass( 'hidden' );
|
|
$('delay').addClass( 'hidden' );
|
|
$('level').addClass( 'hidden' );
|
|
streamCmdPlay( false );
|
|
}
|
|
$('zoomValue').setHTML( status.zoom );
|
|
if ( status.zoom == "1.0" )
|
|
setButtonState( $('zoomOutBtn'), 'unavail' );
|
|
else
|
|
setButtonState( $('zoomOutBtn'), 'inactive' );
|
|
|
|
<?php
|
|
if ( canEdit( 'Monitors' ) )
|
|
{
|
|
?>
|
|
$('enableLink').removeEvents( 'click' );
|
|
if ( status.enabled )
|
|
{
|
|
$('enableLink').setText( '<?= $zmSlangDisableAlarms ?>' );
|
|
$('enableLink').addEvent( 'click', cmdDisableAlarms );
|
|
$('forceLink').removeEvents( 'click' );
|
|
if ( status.forced )
|
|
{
|
|
$('forceLink').setText( '<?= $zmSlangCancelForcedAlarm ?>' );
|
|
$('forceLink').addEvent( 'click', cmdCancelForcedAlarm );
|
|
}
|
|
else
|
|
{
|
|
$('forceLink').setText( '<?= $zmSlangForceAlarm ?>' );
|
|
$('forceLink').addEvent( 'click', cmdForceAlarm );
|
|
}
|
|
$('forceLink').removeClass( 'hidden' );
|
|
}
|
|
else
|
|
{
|
|
$('enableLink').setText( '<?= $zmSlangEnableAlarms ?>' );
|
|
$('enableLink').addEvent( 'click', cmdEnableAlarms );
|
|
$('forceLink').addClass( 'hidden' );
|
|
}
|
|
$('enableLink').removeClass( 'hidden' );
|
|
<?php
|
|
}
|
|
?>
|
|
|
|
var isAlarmed = ( alarmState == STATE_ALARM || alarmState == STATE_ALERT );
|
|
var wasAlarmed = ( lastAlarmState == STATE_ALARM || lastAlarmState == STATE_ALERT );
|
|
|
|
var newAlarm = ( isAlarmed && !wasAlarmed );
|
|
var oldAlarm = ( !isAlarmed && wasAlarmed );
|
|
|
|
if ( newAlarm )
|
|
{
|
|
<?php
|
|
if ( ZM_WEB_SOUND_ON_ALARM )
|
|
{
|
|
?>
|
|
// Enable the alarm sound
|
|
$('alarmSound').removeClass( 'hidden' );
|
|
<?php
|
|
}
|
|
if ( ZM_WEB_POPUP_ON_ALARM )
|
|
{
|
|
?>
|
|
window.focus();
|
|
<?php
|
|
}
|
|
?>
|
|
}
|
|
<?php
|
|
if ( ZM_WEB_SOUND_ON_ALARM )
|
|
{
|
|
?>
|
|
if ( oldAlarm )
|
|
{
|
|
// Disable alarm sound
|
|
$('alarmSound').addClass( 'hidden' );
|
|
}
|
|
<?php
|
|
}
|
|
?>
|
|
var streamCmdTimeout = <?= 1000*ZM_WEB_REFRESH_STATUS ?>;
|
|
if ( alarmState == STATE_ALARM || alarmState == STATE_ALERT )
|
|
{
|
|
streamCmdTimeout = streamCmdTimeout/5;
|
|
}
|
|
streamCmdTimeoutId = window.setTimeout( 'streamCmdQuery()', streamCmdTimeout );
|
|
lastAlarmState = alarmState;
|
|
}
|
|
|
|
function streamCmdPause( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'active' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('stopBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_PAUSE ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
}
|
|
|
|
function streamCmdPlay( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'active' );
|
|
if ( status.delayed == true )
|
|
{
|
|
setButtonState( $('stopBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
}
|
|
else
|
|
{
|
|
setButtonState( $('stopBtn'), 'unavail' );
|
|
setButtonState( $('fastFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowRevBtn'), 'unavail' );
|
|
setButtonState( $('fastRevBtn'), 'unavail' );
|
|
}
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_PLAY ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
}
|
|
|
|
function streamCmdStop( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'unavail' );
|
|
setButtonState( $('stopBtn'), 'active' );
|
|
setButtonState( $('fastFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowRevBtn'), 'unavail' );
|
|
setButtonState( $('fastRevBtn'), 'unavail' );
|
|
|
|
//window.setTimeout('setButtonState( $('stopBtn'), 'unavail' ); setButtonState( $('playBtn'), 'active' );", 500 );
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_STOP ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
setButtonState( $('stopBtn'), 'unavail' );
|
|
setButtonState( $('playBtn'), 'active' );
|
|
}
|
|
|
|
function streamCmdFastFwd( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('stopBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_FASTFWD ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
}
|
|
|
|
function streamCmdSlowFwd( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('stopBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'active' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_SLOWFWD ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
setButtonState( $('pauseBtn'), 'active' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
}
|
|
|
|
function streamCmdSlowRev( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('stopBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'active' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_SLOWREV ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
setButtonState( $('pauseBtn'), 'active' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
}
|
|
|
|
function streamCmdFastRev( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('stopBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_FASTREV ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
}
|
|
|
|
function streamCmdZoomIn( x, y )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_ZOOMIN ?>&x="+x+"&y="+y, onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
|
|
function streamCmdZoomOut()
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_ZOOMOUT ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
|
|
function streamCmdScale( scale )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_SCALE ?>&scale="+scale, onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
|
|
function streamCmdPan( x, y )
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_PAN ?>&x="+x+"&y="+y, onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
|
|
function streamCmdQuery()
|
|
{
|
|
var streamCmdReq = new Ajax( url, { method: 'post', postBody: streamCmdParms+"&command=<?= CMD_QUERY ?>", onComplete: getStreamCmdResponse } );
|
|
streamCmdReq.request();
|
|
}
|
|
|
|
var alarmCmdParms = "view=request&request=alarm&id=<?= $mid ?>";
|
|
var alarmCmdTimeoutId = 0;
|
|
var alarmCmdFirst = true;
|
|
|
|
function getAlarmCmdResponse( resp_text )
|
|
{
|
|
if ( resp_text == 'Ok' )
|
|
return;
|
|
var response = Json.evaluate( resp_text );
|
|
}
|
|
|
|
function cmdDisableAlarms()
|
|
{
|
|
var alarmCmdReq = new Ajax( url, { method: 'post', postBody: alarmCmdParms+"&command=disableAlarms", onComplete: getAlarmCmdResponse } );
|
|
alarmCmdReq.request();
|
|
}
|
|
|
|
function cmdEnableAlarms()
|
|
{
|
|
var alarmCmdReq = new Ajax( url, { method: 'post', postBody: alarmCmdParms+"&command=enableAlarms", onComplete: getAlarmCmdResponse } );
|
|
alarmCmdReq.request();
|
|
}
|
|
|
|
function cmdForceAlarm()
|
|
{
|
|
var alarmCmdReq = new Ajax( url, { method: 'post', postBody: alarmCmdParms+"&command=forceAlarm", onComplete: getAlarmCmdResponse } );
|
|
alarmCmdReq.request();
|
|
}
|
|
|
|
function cmdCancelForcedAlarm()
|
|
{
|
|
var alarmCmdReq = new Ajax( url, { method: 'post', postBody: alarmCmdParms+"&command=cancelForcedAlarm", onComplete: getAlarmCmdResponse } );
|
|
alarmCmdReq.request();
|
|
}
|
|
|
|
var eventCmdParms = "view=request&request=status&entity=events&id=<?= $mid ?>&count=<?= MAX_EVENTS ?>&sort=Id%20desc";
|
|
var eventCmdTimeoutId = 0;
|
|
var eventCmdFirst = true;
|
|
|
|
function getEventCmdResponse( resp_text )
|
|
{
|
|
if ( eventCmdTimeoutId )
|
|
{
|
|
window.clearTimeout( eventCmdTimeoutId );
|
|
eventCmdTimeoutId = 0;
|
|
}
|
|
if ( resp_text == 'Ok' )
|
|
return;
|
|
var response = Json.evaluate( resp_text );
|
|
|
|
var db_events = response.events.reverse();
|
|
var eventList = $('eventList');
|
|
var eventListBody = $(eventList).getElement( 'tbody' );
|
|
var eventListRows = $(eventListBody).getElements( 'tr' );
|
|
for ( var i = 0; i < db_events.length; i++ )
|
|
{
|
|
var row = $('event'+db_events[i].Id);
|
|
if ( !$(row) )
|
|
{
|
|
row = new Element( 'tr', { 'id': 'event'+db_events[i].Id } );
|
|
if ( !eventCmdFirst )
|
|
$(row).addClass( 'highlight' );
|
|
var cell = new Element( 'td' );
|
|
$(cell).injectInside( $(row) );
|
|
$(cell).clone().injectInside( $(row) );
|
|
$(cell).clone().injectInside( $(row) );
|
|
$(cell).clone().injectInside( $(row) );
|
|
$(cell).clone().injectInside( $(row) );
|
|
$(cell).clone().injectInside( $(row) );
|
|
$(row).injectTop( $(eventListBody) );
|
|
}
|
|
else
|
|
{
|
|
$(row).removeClass( 'highlight' );
|
|
}
|
|
var cells = $(row).getElements( 'td' );
|
|
var id = cells[0];
|
|
var idLink = $(id).getElement( 'a' );
|
|
if ( !$(idLink) )
|
|
{
|
|
idLink = new Element( 'a', { 'href': '#', 'events': { 'click': eventWindow.pass( db_events[i].Id, '&trms=1&attr1=MonitorId&op1=%3d&val1=<?= $mid ?>&page=1' ) } });
|
|
$(idLink).injectInside( $(id) );
|
|
}
|
|
$(idLink).setHTML( db_events[i].Id );
|
|
var name = cells[1];
|
|
var nameLink = $(name).getElement( 'a' );
|
|
if ( !$(nameLink) )
|
|
{
|
|
nameLink = new Element( 'a', { 'href': '#', 'events': { 'click': eventWindow.pass( db_events[i].Id, '&trms=1&attr1=MonitorId&op1=%3d&val1=<?= $mid ?>&page=1' ) } });
|
|
$(nameLink).injectInside( $(name) );
|
|
}
|
|
$(nameLink).setHTML( db_events[i].Name );
|
|
var time = cells[2];
|
|
$(time).setHTML( db_events[i].StartTime );
|
|
var secs = cells[3];
|
|
$(secs).setHTML( db_events[i].Length );
|
|
var frames = cells[4];
|
|
var framesLink = $(frames).getElement( 'a' );
|
|
if ( !$(framesLink) )
|
|
{
|
|
framesLink = new Element( 'a', { 'href': '#', 'events': { 'click': framesWindow.pass( db_events[i].Id ) } });
|
|
$(framesLink).injectInside( $(frames) );
|
|
}
|
|
$(framesLink).setHTML( db_events[i].Frames+'/'+db_events[i].AlarmFrames );
|
|
var score = cells[5];
|
|
var scoreLink = $(score).getElement( 'a' );
|
|
if ( !$(scoreLink) )
|
|
{
|
|
scoreLink = new Element( 'a', { 'href': '#', 'events': { 'click': frameWindow.pass( [ db_events[i].Id, '0' ] ) } });
|
|
$(scoreLink).injectInside( $(score) );
|
|
}
|
|
$(scoreLink).setHTML( db_events[i].AvgScore+'/'+db_events[i].MaxScore );
|
|
}
|
|
var rows = $(eventListBody).getElements( 'tr' );
|
|
while ( $$(rows).length > <?= MAX_EVENTS ?> )
|
|
{
|
|
$$(rows)[$$(rows).length-1].remove();
|
|
rows = $(eventListBody).getElements( 'tr' );
|
|
}
|
|
var eventCmdTimeout = <?= 1000*ZM_WEB_REFRESH_STATUS ?>;
|
|
if ( alarmState == STATE_ALARM || alarmState == STATE_ALERT )
|
|
{
|
|
eventCmdTimeout = eventCmdTimeout/5;
|
|
}
|
|
eventCmdTimeoutId = window.setTimeout( 'eventCmdQuery()', eventCmdTimeout );
|
|
eventCmdFirst = false;
|
|
}
|
|
|
|
function eventCmdQuery()
|
|
{
|
|
var eventCmdReq = new Ajax( url, { method: 'post', postBody: eventCmdParms, onComplete: getEventCmdResponse } );
|
|
eventCmdReq.request();
|
|
}
|
|
|
|
var controlParms = "view=request&request=control&id=<?= $mid ?>";
|
|
|
|
function getControlResponse( resp_text )
|
|
{
|
|
if ( !resp_text )
|
|
return;
|
|
//console.log( resp_text );
|
|
var response = Json.evaluate( resp_text );
|
|
result = response.result;
|
|
if ( result != 'Ok' )
|
|
{
|
|
alert( "Control response was status = "+response.status+"\nmessage = "+response.message );
|
|
}
|
|
}
|
|
|
|
function controlCmd( control, event, xtell, ytell )
|
|
{
|
|
var locParms = "";
|
|
if ( event && (xtell || ytell) )
|
|
{
|
|
var xEvent = new Event( event );
|
|
var target = xEvent.target;
|
|
var coords = $(target).getCoordinates();
|
|
|
|
var l = coords.left;
|
|
var t = coords.top;
|
|
var x = xEvent.page.x - l;
|
|
var y = xEvent.page.y - t;
|
|
|
|
if ( xtell )
|
|
{
|
|
var xge = parseInt( (x*100)/coords.width );
|
|
if ( xtell == -1 )
|
|
xge = 100 - xge;
|
|
else if ( xtell == 2 )
|
|
xge = 2*(50 - xge);
|
|
locParms += "&xge="+xge;
|
|
}
|
|
if ( ytell )
|
|
{
|
|
var yge = parseInt( (y*100)/coords.height );
|
|
if ( ytell == -1 )
|
|
yge = 100 - yge;
|
|
else if ( ytell == 2 )
|
|
yge = 2*(50 - yge);
|
|
locParms += "&yge="+yge;
|
|
}
|
|
}
|
|
var controlReq = new Ajax( url, { method: 'post', postBody: controlParms+"&control="+control+locParms, onComplete: getControlResponse } );
|
|
controlReq.request();
|
|
}
|
|
|
|
function controlCmdImage( x, y )
|
|
{
|
|
var imageControlParms = controlParms;
|
|
imageControlParms += "&scale=<?= $scale ?>";
|
|
<?php
|
|
if ( $monitor['CanMoveMap'] )
|
|
{
|
|
?>
|
|
imageControlParms += "&control=moveMap";
|
|
<?php
|
|
}
|
|
elseif ( $monitor['CanMoveRel'] )
|
|
{
|
|
?>
|
|
imageControlParms += "&control=movePseudoMap";
|
|
<?php
|
|
}
|
|
elseif ( $monitor['CanMoveCon'] )
|
|
{
|
|
?>
|
|
imageControlParms += "&control=moveConMap";
|
|
<?php
|
|
}
|
|
?>
|
|
var controlReq = new Ajax( url, { method: 'post', postBody: imageControlParms+"&x="+x+"&y="+y, onComplete: getControlResponse } );
|
|
controlReq.request();
|
|
}
|
|
function startRequests()
|
|
{
|
|
streamCmdTimeoutId = window.setTimeout( 'streamCmdQuery()', 1000 );
|
|
eventCmdTimeoutId = window.setTimeout( 'eventCmdQuery()', 1500 );
|
|
}
|
|
</script>
|
|
</head>
|
|
<body>
|
|
<div id="container">
|
|
<div id="menuBar">
|
|
<span id="monitorName"><strong><?= $monitor['Name'] ?></strong></span>
|
|
<span id="menuControls">
|
|
<?php
|
|
if ( $showControls )
|
|
{
|
|
if ( !$control )
|
|
{
|
|
if ( canView( 'Control' ) )
|
|
{
|
|
?>
|
|
<span><a id="controlToggle" href="javascript: void(0)" onclick="showControls()"><?= $zmSlangControl ?></a></span>
|
|
<?php
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if ( canView( 'Events' ) )
|
|
{
|
|
?>
|
|
<span><a id="controlToggle" href="javascript: void(0)" onclick="showEvents()"><?= $zmSlangEvents ?></a></span>
|
|
<?php
|
|
}
|
|
}
|
|
}
|
|
?>
|
|
<span><?= $zmSlangScale ?>: <?= buildSelect( "scale", $scales, "changeScale( this );" ); ?></span>
|
|
<?php
|
|
if ( canView( 'Control' ) && $monitor['Type'] == "Local" )
|
|
{
|
|
?>
|
|
<span><a href="javascript: newWindow( '<?= $PHP_SELF ?>?view=settings&mid=<?= $monitor['Id'] ?>', 'zmSettings<?= $monitor['Id'] ?>', <?= $jws['settings']['w'] ?>, <?= $jws['settings']['h'] ?> );"><?= $zmSlangSettings ?></a></span>
|
|
<?php
|
|
}
|
|
?>
|
|
</span>
|
|
<span id="closeWindow"><a href="javascript: closeWindow();"><?= $zmSlangClose ?></a></span>
|
|
</div>
|
|
<div id="imageFeed">
|
|
<?php
|
|
if ( ZM_STREAM_METHOD == 'mpeg' && ZM_MPEG_LIVE_FORMAT )
|
|
{
|
|
$stream_src = getStreamSrc( array( "mode=mpeg", "monitor=".$mid, "scale=".$scale, "bitrate=".ZM_WEB_VIDEO_BITRATE, "maxfps=".ZM_WEB_VIDEO_MAXFPS, "format=".ZM_MPEG_LIVE_FORMAT ) );
|
|
outputVideoStream( $stream_src, reScale( $monitor['Width'], $scale ), reScale( $monitor['Height'], $scale ), $monitor['Name'], ZM_MPEG_LIVE_FORMAT );
|
|
}
|
|
else
|
|
{
|
|
$stream_src = getStreamSrc( array( "mode=jpeg", "monitor=".$mid, "scale=".$scale, "maxfps=".ZM_WEB_VIDEO_MAXFPS ) );
|
|
if ( canStreamNative() )
|
|
{
|
|
//if ( $control && ($monitor['CanMoveMap'] || $monitor['CanMoveRel'] || $monitor['CanMoveCon']) )
|
|
{
|
|
outputImageStream( $stream_src, reScale( $monitor['Width'], $scale ), reScale( $monitor['Height'], $scale ), $monitor['Name'] );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
outputHelperStream( $stream_src, reScale( $monitor['Width'], $scale ), reScale( $monitor['Height'], $scale ) );
|
|
}
|
|
}
|
|
?>
|
|
</div>
|
|
<div id="monitorStatus">
|
|
<?php
|
|
if ( canEdit( 'Monitors' ) )
|
|
{
|
|
?>
|
|
<span id="enableAlarms"><a id="enableLink" href="javascript: void(0)" class="hidden"> </a></span>
|
|
<?php
|
|
}
|
|
?>
|
|
<span id="monitorState"><?= $zmSlangState ?>: <span id="stateValue"></span> - <span id="fpsValue"></span> fps</span>
|
|
<?php
|
|
if ( canEdit( 'Monitors' ) )
|
|
{
|
|
?>
|
|
<span id="forceAlarm"><a id="forceLink" href="javascript: void(0)" class="hidden"> </a></span>
|
|
<?php
|
|
}
|
|
?>
|
|
</div>
|
|
<p id="dvrControls">
|
|
<input type="button" value="<<" id="fastRevBtn" title="<?= $zmSlangRewind ?>" class="unavail" disabled="disabled" onclick="streamCmdFastRev( true )"/>
|
|
<input type="button" value="<" id="slowRevBtn" title="<?= $zmSlangStepBack ?>" class="unavail" disabled="disabled" onclick="streamCmdSlowRev( true )"/>
|
|
<input type="button" value="||" id="pauseBtn" title="<?= $zmSlangPause ?>" class="inactive" onclick="streamCmdPause( true )"/>
|
|
<input type="button" value="[]" id="stopBtn" title="<?= $zmSlangStop ?>" class="unavail" disabled="disabled" onclick="streamCmdStop( true )"/>
|
|
<input type="button" value="|>" id="playBtn" title="<?= $zmSlangPlay ?>" class="active" disabled="disabled" onclick="streamCmdPlay( true )"/>
|
|
<input type="button" value=">" id="slowFwdBtn" title="<?= $zmSlangStepForward ?>" class="unavail" disabled="disabled" onclick="streamCmdSlowFwd( true )"/>
|
|
<input type="button" value=">>" id="fastFwdBtn" title="<?= $zmSlangFastForward ?>" class="unavail" disabled="disabled" onclick="streamCmdFastFwd( true )"/>
|
|
<input type="button" value="–" id="zoomOutBtn" title="<?= $zmSlangZoomOut ?>" class="avail" onclick="streamCmdZoomOut()"/>
|
|
</p>
|
|
<div id="replayStatus"><span id="mode">Mode: <span id="modeValue"> </span></span><span id="rate"> – Rate: <span id="rateValue"></span>x</span><span id="delay"> – Delay: <span id="delayValue"></span>s</span><span id="level"> – Buffer: <span id="levelValue"></span>%</span><span id="zoom"> – Zoom: <span id="zoomValue"></span>x</span>
|
|
</div>
|
|
<?php
|
|
if ( $showControls )
|
|
{
|
|
require_once( 'zm_control_funcsX.php' );
|
|
$streamCmds = getControlCommands( $monitor );
|
|
?>
|
|
<div id="ptzControls"<?= $control?'':' class="hidden"' ?>>
|
|
<div id="controlsPanel">
|
|
<?php
|
|
if ( $monitor['CanFocus'] )
|
|
{
|
|
echo controlFocus( $monitor );
|
|
}
|
|
if ( $monitor['CanZoom'] )
|
|
{
|
|
echo controlZoom( $monitor );
|
|
}
|
|
if ( $monitor['CanMove'] || ( $monitor['CanWake'] || $monitor['CanSleep'] || $monitor['CanReset'] ) )
|
|
{
|
|
?>
|
|
<div id="pantiltPanel">
|
|
<?php
|
|
if ( $monitor['CanMove'] )
|
|
{
|
|
echo controlPanTilt( $monitor );
|
|
}
|
|
if ( $monitor['CanWake'] || $monitor['CanSleep'] || $monitor['CanReset'] )
|
|
{
|
|
echo controlPower( $monitor );
|
|
}
|
|
?>
|
|
</div>
|
|
<?php
|
|
}
|
|
if ( $monitor['CanIris'] )
|
|
{
|
|
echo controlIris( $monitor );
|
|
}
|
|
if ( $monitor['CanWhite'] )
|
|
{
|
|
echo controlWhite( $monitor );
|
|
}
|
|
?>
|
|
</div>
|
|
<?php
|
|
if ( $monitor['HasPresets'] )
|
|
{
|
|
echo controlPresets( $monitor );
|
|
}
|
|
?>
|
|
</div>
|
|
<?php
|
|
}
|
|
if ( canView( 'Events' ) )
|
|
{
|
|
?>
|
|
<div id="events"<?= $control?' class="hidden"':'' ?>>
|
|
<table id="eventList" cellspacing="0">
|
|
<thead>
|
|
<tr>
|
|
<td><?= $zmSlangId ?></td>
|
|
<td><?= $zmSlangName ?></td>
|
|
<td><?= $zmSlangTime ?></td>
|
|
<td><?= $zmSlangSecs ?></td>
|
|
<td><?= $zmSlangFrames ?></td>
|
|
<td><?= $zmSlangScore ?></td>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<?php
|
|
}
|
|
if ( ZM_WEB_SOUND_ON_ALARM )
|
|
{
|
|
$sound_src = ZM_DIR_SOUNDS.'/'.ZM_WEB_ALARM_SOUND;
|
|
?>
|
|
<div id="alarmSound" class="hidden">
|
|
<?php
|
|
if ( ZM_WEB_USE_OBJECT_TAGS && isWindows() )
|
|
{
|
|
?>
|
|
<object id="MediaPlayer" width="0" height="0"
|
|
classid="CLSID:22D6F312-B0F6-11D0-94AB-0080C74C7E95"
|
|
codebase="http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=6,0,02,902">
|
|
<param name="FileName" value="<?= $sound_src ?>"/>
|
|
<param name="autoStart" value="1"/>
|
|
<param name="loop" value="1"/>
|
|
<param name=hidden value="1"/>
|
|
<param name="showControls" value="0"/>
|
|
<embed src="<?= $sound_src ?>"
|
|
autostart="true"
|
|
loop="true"
|
|
hidden="true">
|
|
</embed>
|
|
</object>
|
|
<?php
|
|
}
|
|
else
|
|
{
|
|
?>
|
|
<embed src="<?= $sound_src ?>"
|
|
autostart="true"
|
|
loop="true"
|
|
hidden="true">
|
|
</embed>
|
|
<?php
|
|
}
|
|
?>
|
|
</div>
|
|
<?php
|
|
}
|
|
?>
|
|
</div>
|
|
<script type="text/javascript">
|
|
startRequests();
|
|
<?php
|
|
if ( canStreamNative() )
|
|
{
|
|
?>
|
|
function handleClick( event )
|
|
{
|
|
var target = event.target;
|
|
var x = event.page.x - $(target).getLeft();
|
|
var y = event.page.y - $(target).getTop();
|
|
var canMove = <?= ($monitor['CanMoveMap'] || $monitor['CanMoveRel'] || $monitor['CanMoveCon'])?'true':'false' ?>;
|
|
|
|
if ( showMode == "events" || !canMove )
|
|
{
|
|
if ( event.shift )
|
|
streamCmdPan( x, y );
|
|
else
|
|
streamCmdZoomIn( x, y );
|
|
}
|
|
else
|
|
{
|
|
controlCmdImage( x, y );
|
|
}
|
|
}
|
|
|
|
var streamImg = $('imageFeed').getElement('img');
|
|
if ( !streamImg )
|
|
streamImg = $('imageFeed').getElement('object');
|
|
$(streamImg).addEvent( 'click', handleClick.bindWithEvent( $(streamImg) ) );
|
|
<?php
|
|
}
|
|
?>
|
|
</script>
|
|
</body>
|
|
</html>
|