601 lines
20 KiB
PHP
601 lines
20 KiB
PHP
<?php
|
|
//
|
|
// ZoneMinder web event 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( 'Events' ) )
|
|
{
|
|
$view = "error";
|
|
return;
|
|
}
|
|
|
|
if ( $user['MonitorIds'] )
|
|
{
|
|
$mid_sql = " and MonitorId in (".join( ",", preg_split( '/["\'\s]*,["\'\s]*/', $user['MonitorIds'] ) ).")";
|
|
}
|
|
else
|
|
{
|
|
$mid_sql = '';
|
|
}
|
|
|
|
$sql = "select E.*,M.Name as MonitorName,M.Width,M.Height,M.DefaultRate,M.DefaultScale from Events as E inner join Monitors as M on E.MonitorId = M.Id where E.Id = '$eid'$mid_sql";
|
|
$event = dbFetchOne( $sql );
|
|
|
|
if ( !isset( $rate ) )
|
|
$rate = reScale( RATE_BASE, $event['DefaultRate'], ZM_WEB_DEFAULT_RATE );
|
|
if ( !isset( $scale ) )
|
|
$scale = reScale( SCALE_BASE, $event['DefaultScale'], ZM_WEB_DEFAULT_SCALE );
|
|
|
|
$panel_sections = 40;
|
|
$panel_section_width = (int)ceil(reScale($event['Width'],$scale)/$panel_sections);
|
|
$panel_width = ($panel_sections*$panel_section_width-1);
|
|
|
|
$connkey = generateConnKey();
|
|
|
|
?>
|
|
<!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 ?> - <?= $zmSlangEvent ?></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 url = "<?= ZM_BASE_URL.$PHP_SELF ?>";
|
|
|
|
function setButtonState( element, butclass )
|
|
{
|
|
element.className = butclass;
|
|
element.disabled = (butclass != 'inactive');
|
|
}
|
|
|
|
function secsToTime( secs )
|
|
{
|
|
var timeString;
|
|
if ( secs < 60 )
|
|
timeString = secs;
|
|
else if ( secs < 60*60 )
|
|
{
|
|
var mins = parseInt(secs/60);
|
|
var secs = secs%60;
|
|
if ( secs < 10 )
|
|
secs = '0'+secs.toString().substr( 0, 4 );
|
|
else
|
|
secs = secs.toString().substr( 0, 5 );
|
|
timeString = mins+":"+secs;
|
|
}
|
|
else
|
|
{
|
|
var hours = parseInt(secs/3600);
|
|
var mins = (secs%3600)/60;
|
|
var secs = secs%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 );
|
|
timeString = hours+":"+mins+":"+secs;
|
|
}
|
|
return( timeString );
|
|
}
|
|
|
|
function changeScale()
|
|
{
|
|
var scale = $('scale').getValue();
|
|
var baseWidth = event.Width;
|
|
var baseHeight = event.Height;
|
|
//console.log( "Got new scale: "+scale );
|
|
var newWidth = ( baseWidth * scale ) / <?= SCALE_BASE ?>;
|
|
var newHeight = ( baseHeight * scale ) / <?= SCALE_BASE ?>;
|
|
|
|
streamScale( scale );
|
|
|
|
var streamImg = $('imageFeed').getElement('img');
|
|
$(streamImg).setStyles( { width: newWidth, height: newHeight } );
|
|
}
|
|
|
|
var streamParms = "view=request&request=stream&connkey=<?= $connkey ?>";
|
|
var streamTimeoutId = 0;
|
|
|
|
var status;
|
|
var event;
|
|
var eventId;
|
|
var lastEventId = 0;
|
|
|
|
function getCmdResponse( resp_text, resp_xml )
|
|
{
|
|
if ( streamTimeoutId )
|
|
{
|
|
window.clearTimeout( streamTimeoutId );
|
|
streamTimeoutId = 0;
|
|
}
|
|
if ( !resp_text )
|
|
return;
|
|
var resp_func = new Function( "return "+resp_text );
|
|
var resp_obj = resp_func();
|
|
status = resp_obj.status;
|
|
|
|
eventId = status.event;
|
|
if ( eventId != lastEventId )
|
|
{
|
|
evtQuery();
|
|
lastEventId = eventId;
|
|
}
|
|
if ( status.paused == true )
|
|
{
|
|
$('modeValue').setHTML( "Paused" );
|
|
$('rate').addClass( 'hidden' );
|
|
streamPause( false );
|
|
}
|
|
else
|
|
{
|
|
$('modeValue').setHTML( "Replay" );
|
|
$('rateValue').setHTML( status.rate );
|
|
$('rate').removeClass( 'hidden' );
|
|
streamPlay( false );
|
|
}
|
|
$('progressValue').setHTML( secsToTime( parseInt(status.progress) ) );
|
|
$('zoomValue').setHTML( status.zoom );
|
|
if ( status.zoom == "1.0" )
|
|
setButtonState( $('zoomOutBtn'), 'unavail' );
|
|
else
|
|
setButtonState( $('zoomOutBtn'), 'inactive' );
|
|
|
|
updateProgressBar();
|
|
|
|
var streamTimeout = <?= ZM_WEB_REFRESH_STATUS ?>;
|
|
streamTimeoutId = window.setTimeout( 'streamQuery()', 1000 * streamTimeout );
|
|
}
|
|
|
|
function streamPause( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'active' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'unavail' );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_PAUSE ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
}
|
|
|
|
function streamPlay( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), status.rate==1?'active':'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowRevBtn'), 'unavail' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_PLAY ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
}
|
|
|
|
function streamFastFwd( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowRevBtn'), 'unavail' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_FASTFWD ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
}
|
|
|
|
function streamSlowFwd( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowFwdBtn'), 'active' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
setButtonState( $('fastRevBtn'), 'unavail' );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_SLOWFWD ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
setButtonState( $('pauseBtn'), 'active' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
}
|
|
|
|
function streamSlowRev( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowRevBtn'), 'active' );
|
|
setButtonState( $('fastRevBtn'), 'unavail' );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_SLOWREV ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
setButtonState( $('pauseBtn'), 'active' );
|
|
setButtonState( $('slowRevBtn'), 'inactive' );
|
|
}
|
|
|
|
function streamFastRev( action )
|
|
{
|
|
setButtonState( $('pauseBtn'), 'inactive' );
|
|
setButtonState( $('playBtn'), 'inactive' );
|
|
setButtonState( $('fastFwdBtn'), 'inactive' );
|
|
setButtonState( $('slowFwdBtn'), 'unavail' );
|
|
setButtonState( $('slowRevBtn'), 'unavail' );
|
|
setButtonState( $('fastRevBtn'), 'inactive' );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_FASTREV ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
}
|
|
|
|
function streamPrev( action )
|
|
{
|
|
streamPlay( false );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_PREV ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
}
|
|
|
|
function streamNext( action )
|
|
{
|
|
streamPlay( false );
|
|
if ( action )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_NEXT ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
}
|
|
|
|
function streamZoomIn( x, y )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_ZOOMIN ?>&x="+x+"&y="+y, onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
|
|
function streamZoomOut()
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_ZOOMOUT ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
|
|
function streamScale( scale )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_SCALE ?>&scale="+scale, onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
|
|
function streamPan( x, y )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_PAN ?>&x="+x+"&y="+y, onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
|
|
function streamSeek( offset )
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_SEEK ?>&offset="+offset, onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
|
|
function streamQuery()
|
|
{
|
|
var streamReq = new Ajax( url, { method: 'post', postBody: streamParms+"&command=<?= CMD_QUERY ?>", onComplete: getCmdResponse } );
|
|
streamReq.request();
|
|
}
|
|
|
|
function getEvtResponse( resp_text, resp_xml )
|
|
{
|
|
if ( resp_text == 'Ok' )
|
|
return;
|
|
var resp_func = new Function( "return "+resp_text );
|
|
var resp_obj = resp_func();
|
|
//console.log( resp_obj );
|
|
|
|
event = resp_obj.event;
|
|
|
|
$('dataId').setHTML( event.Id );
|
|
if ( event.Notes )
|
|
{
|
|
$('dataCause').setProperty( 'title', event.Notes );
|
|
}
|
|
else
|
|
{
|
|
$('dataCause').setProperty( 'title', '<?= $zmSlangAttrCause ?>' );
|
|
}
|
|
$('dataCause').setHTML( event.Cause );
|
|
$('dataTime').setHTML( event.StartTime );
|
|
$('dataDuration').setHTML( event.Length );
|
|
$('dataFrames').setHTML( event.Frames+"/"+event.AlarmFrames );
|
|
$('dataScore').setHTML( event.TotScore+"/"+event.AvgScore+"/"+event.MaxScore );
|
|
$('eventName').setProperty( 'value', event.Name );
|
|
|
|
var link = $('archiveEvent').getElement( 'a' );
|
|
if ( parseInt(event.Archived) )
|
|
{
|
|
$(link).setHTML( '<?= $zmSlangUnarchive ?>' );
|
|
$(link).setProperty( 'href', 'javascript: unarchiveEvent()' );
|
|
}
|
|
else
|
|
{
|
|
$(link).setHTML( '<?= $zmSlangArchive ?>' );
|
|
$(link).setProperty( 'href', 'javascript: archiveEvent()' );
|
|
}
|
|
drawProgressBar();
|
|
}
|
|
|
|
function evtQuery()
|
|
{
|
|
var evtParms = "view=request&request=status&entity=event&id="+eventId;
|
|
var evtReq = new Ajax( url, { method: 'post', postBody: evtParms, onComplete: getEvtResponse } );
|
|
evtReq.request();
|
|
}
|
|
|
|
function getActResponse( resp_text, resp_xml )
|
|
{
|
|
if ( resp_text == 'Ok' )
|
|
return;
|
|
var resp_func = new Function( "return "+resp_text );
|
|
var resp_obj = resp_func();
|
|
//console.log( resp_obj );
|
|
|
|
if ( resp_obj.refreshParent )
|
|
{
|
|
window.opener.location.reload();
|
|
}
|
|
evtQuery();
|
|
}
|
|
|
|
function actQuery( action, parms )
|
|
{
|
|
var actParms = "view=request&request=event&id="+event.Id+"&action="+action;
|
|
//console.log( parms );
|
|
if ( parms != null )
|
|
{
|
|
actParms += "&"+Object.toQueryString( parms );
|
|
}
|
|
//console.log( actParms );
|
|
var actReq = new Ajax( url, { method: 'post', postBody: actParms, onComplete: getActResponse } );
|
|
actReq.request();
|
|
}
|
|
|
|
function startRequests()
|
|
{
|
|
streamTimeoutId = window.setTimeout( 'streamQuery()', 1000 );
|
|
}
|
|
|
|
function deleteEvent()
|
|
{
|
|
actQuery( 'delete' );
|
|
streamNext();
|
|
opener.location.reload(true);
|
|
}
|
|
|
|
function renameEvent()
|
|
{
|
|
var newName = $('eventName').getValue();
|
|
actQuery( 'rename', { eventName: newName } );
|
|
}
|
|
|
|
function editEvent()
|
|
{
|
|
newWindow( '<?= $PHP_SELF ?>?view=eventdetail&eid='+event.Id, 'zmEventDetail', <?= $jws['eventdetail']['w'] ?>, <?= $jws['eventdetail']['h'] ?> );
|
|
}
|
|
|
|
function exportEvent()
|
|
{
|
|
newWindow( '<?= $PHP_SELF ?>?view=export&eid='+event.Id, 'zmExport', <?= $jws['export']['w'] ?>, <?= $jws['export']['h'] ?> );
|
|
}
|
|
|
|
function archiveEvent()
|
|
{
|
|
actQuery( 'archive' );
|
|
}
|
|
|
|
function unarchiveEvent()
|
|
{
|
|
actQuery( 'unarchive' );
|
|
}
|
|
|
|
function drawProgressBar()
|
|
{
|
|
var barWidth = 0;
|
|
$('progressBar').addClass( 'invisible' );
|
|
var cells = $('progressBar').getElements( 'div' );
|
|
var cellWidth = parseInt( event.Width/$$(cells).length );
|
|
$$(cells).forEach(
|
|
function( cell, index )
|
|
{
|
|
$(cell).setStyle( 'left', barWidth );
|
|
$(cell).setStyle( 'width', cellWidth );
|
|
//console.log( "Cell at "+barWidth );
|
|
if ( index == 0 )
|
|
$(cell).setStyle( 'border-left', 0 );
|
|
var offset = parseInt((index*event.Length)/$$(cells).length);
|
|
$(cell).setProperty( 'title', '+'+secsToTime(offset)+'s' );
|
|
$(cell).removeEvent( 'click' );
|
|
$(cell).addEvent( 'click', function(){ streamSeek( offset ); } );
|
|
$(cell).setProperty( 'title', '+'+secsToTime(offset)+'s' );
|
|
barWidth += $(cell).getCoordinates().width;
|
|
}
|
|
);
|
|
//console.log( "Bar width "+barWidth );
|
|
$('progressBar').setStyle( 'width', barWidth );
|
|
$('progressBar').removeClass( 'invisible' );
|
|
}
|
|
|
|
function updateProgressBar()
|
|
{
|
|
if ( event && status )
|
|
{
|
|
var cells = $('progressBar').getElements( 'div' );
|
|
var completeIndex = parseInt((($$(cells).length+1)*status.progress)/event.Length);
|
|
$$(cells).forEach(
|
|
function( cell, index )
|
|
{
|
|
if ( index < completeIndex )
|
|
{
|
|
if ( !$(cell).hasClass( 'complete' ) )
|
|
{
|
|
$(cell).addClass( 'complete' );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if ( $(cell).hasClass( 'complete' ) )
|
|
{
|
|
$(cell).removeClass( 'complete' );
|
|
}
|
|
}
|
|
}
|
|
);
|
|
}
|
|
}
|
|
</script>
|
|
</head>
|
|
<body>
|
|
<div id="container">
|
|
<div id="dataBar">
|
|
<table id="dataTable" cellspacing="0">
|
|
<tr>
|
|
<td><span id="dataId" title="<?= $zmSlangId ?>"><?= $event['Id'] ?></span></td>
|
|
<td><span id="dataCause" title="<?= $event['Notes']?htmlentities($event['Notes']):$zmSlangAttrCause ?>"><?= htmlentities($event['Cause']) ?></span></td>
|
|
<td><span id="dataTime" title="<?= $zmSlangTime ?>"><?= strftime( STRF_FMT_DATETIME_SHORT, strtotime($event['StartTime'] ) ) ?></span></td>
|
|
<td><span id="dataDuration" title="<?= $zmSlangDuration ?>"><?= $event['Length'] ?></span>s</td>
|
|
<td><span id="dataFrames" title="<?= $zmSlangAttrFrames."/".$zmSlangAttrAlarmFrames ?>"><?= $event['Frames'] ?>/<?= $event['AlarmFrames'] ?></span></td>
|
|
<td><span id="dataScore" title="<?= $zmSlangAttrTotalScore."/".$zmSlangAttrAvgScore."/".$zmSlangAttrMaxScore ?>"><?= $event['TotScore'] ?>/<?= $event['AvgScore'] ?>/<?= $event['MaxScore'] ?></span></td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
<div id="menuBar1">
|
|
<span><input size="16" id="eventName" name="eventName" value="<?= $event['Name'] ?>"/> <input type="button" value="<?= $zmSlangRename ?>" onclick="renameEvent()"<?php if ( !canEdit( 'Events' ) ) { ?> disabled<?php } ?>/></span>
|
|
<span id="menuControls">
|
|
<span><?= $zmSlangScale ?>: <?= buildSelect( "scale", $scales, "changeScale();" ); ?></span>
|
|
</span>
|
|
</div>
|
|
<div id="menuBar2">
|
|
<?php
|
|
if ( canEdit( 'Events' ) )
|
|
{
|
|
?>
|
|
<span id="deleteEvent"><a href="javascript: deleteEvent()"><?= $zmSlangDelete ?></a></span>
|
|
<span id="editEvent"><a href="javascript: editEvent()"><?= $zmSlangEdit ?></a></span>
|
|
<span id="exportEvent"><a href="javascript: exportEvent()"><?= $zmSlangExport ?></a></span>
|
|
<span id="archiveEvent"><a href="javascript: void(0)"> </a></span>
|
|
<?php
|
|
}
|
|
if ( ZM_OPT_MPEG != "no" )
|
|
{
|
|
?>
|
|
<span><a href="javascript: videoEvent()"><?= $zmSlangVideo ?></a></span>
|
|
<?php
|
|
}
|
|
?>
|
|
<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( "source=event", "mode=mpeg", "event=".$eid, "frame=".(!empty($fid)?$fid:1), "scale=".$scale, "rate=".$rate, "bitrate=".ZM_WEB_VIDEO_BITRATE, "maxfps=".ZM_WEB_VIDEO_MAXFPS, "format=".ZM_MPEG_REPLAY_FORMAT ) );
|
|
outputVideoStream( $stream_src, reScale( $event['Width'], $scale ), reScale( $event['Height'], $scale ), $event['Name'], ZM_MPEG_LIVE_FORMAT );
|
|
}
|
|
else
|
|
{
|
|
$stream_src = getStreamSrc( array( "source=event", "mode=jpeg", "event=".$eid, "frame=".(!empty($fid)?$fid:1), "scale=".$scale, "rate=".$rate, "maxfps=".ZM_WEB_VIDEO_MAXFPS ) );
|
|
if ( canStreamNative() )
|
|
{
|
|
outputImageStream( $stream_src, reScale( $event['Width'], $scale ), reScale( $event['Height'], $scale ), $event['Name'] );
|
|
}
|
|
else
|
|
{
|
|
outputHelperStream( $stream_src, reScale( $event['Width'], $scale ), reScale( $event['Height'], $scale ) );
|
|
}
|
|
}
|
|
?>
|
|
</div>
|
|
<p id="dvrControls">
|
|
<input type="button" value="<+" id="prevBtn" title="<?= $zmSlangPrev ?>" class="inactive" onclick="streamPrev( true )"/>
|
|
<input type="button" value="<<" id="fastRevBtn" title="<?= $zmSlangRewind ?>" class="inactive" disabled="disabled" onclick="streamFastRev( true )"/>
|
|
<input type="button" value="<" id="slowRevBtn" title="<?= $zmSlangStepBack ?>" class="unavail" disabled="disabled" onclick="streamSlowRev( true )"/>
|
|
<input type="button" value="||" id="pauseBtn" title="<?= $zmSlangPause ?>" class="inactive" onclick="streamPause( true )"/>
|
|
<input type="button" value="|>" id="playBtn" title="<?= $zmSlangPlay ?>" class="active" disabled="disabled" onclick="streamPlay( true )"/>
|
|
<input type="button" value=">" id="slowFwdBtn" title="<?= $zmSlangStepForward ?>" class="unavail" disabled="disabled" onclick="streamSlowFwd( true )"/>
|
|
<input type="button" value=">>" id="fastFwdBtn" title="<?= $zmSlangFastForward ?>" class="inactive" disabled="disabled" onclick="streamFastFwd( true )"/>
|
|
<input type="button" value="–" id="zoomOutBtn" title="<?= $zmSlangZoomOut ?>" class="avail" onclick="streamZoomOut()"/>
|
|
<input type="button" value="+>" id="nextBtn" title="<?= $zmSlangNext ?>" class="inactive" onclick="streamNext( true )"/>
|
|
</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="progress"> – Progress: <span id="progressValue"></span>s</span><span id="zoom"> – Zoom: <span id="zoomValue"></span>x</span>
|
|
</div>
|
|
<div id="progressBar" class="invisible">
|
|
<?php
|
|
for ( $i = 0; $i < $panel_sections; $i++ )
|
|
{
|
|
?>
|
|
<div class="progressBox" id="progressBox<?= $i ?>" title=""></div>
|
|
<?php
|
|
}
|
|
?>
|
|
</div>
|
|
</div>
|
|
<script type="text/javascript">
|
|
startRequests();
|
|
<?php
|
|
if ( canStreamNative() )
|
|
{
|
|
?>
|
|
function handleClick( event )
|
|
{
|
|
var target = event.target;
|
|
//console.log( "Target = "+event.target );
|
|
//console.log( "Left = "+$(target).getLeft() );
|
|
var x = event.page.x - $(target).getLeft();
|
|
var y = event.page.y - $(target).getTop();
|
|
|
|
if ( event.shift )
|
|
streamPan( x, y );
|
|
else
|
|
streamZoomIn( x, y );
|
|
//console.log(x+","+y)
|
|
}
|
|
|
|
var streamImg = $('imageFeed').getElement('img');
|
|
$(streamImg).addEvent( 'click', handleClick.bindWithEvent( $(streamImg) ) );
|
|
<?php
|
|
}
|
|
?>
|
|
</script>
|
|
</body>
|
|
</html>
|