// // ZoneMinder Control Utility, $Date$, $Revision$ // Copyright (C) 2003 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. // #include #include "zm.h" #include "zm_db.h" #include "zm_monitor.h" #include "zm_local_camera.h" void Usage( int status=-1 ) { fprintf( stderr, "zmu <-d device_no> [-v] [function]\n" ); fprintf( stderr, "zmu <-m monitor_id> [-v] [function]\n" ); fprintf( stderr, "General options:\n" ); fprintf( stderr, " -h, --help : This screen\n" ); fprintf( stderr, " -v, --verbose : Produce more verbose output\n" ); fprintf( stderr, "Options for use with devices:\n" ); fprintf( stderr, " -d, --device : Get the current video device settings for /dev/video\n" ); fprintf( stderr, " -q, --query : Query the current settings for the device\n" ); fprintf( stderr, " -p, --probe : Query possible settings for the device\n" ); fprintf( stderr, "Options for use with monitors:\n" ); fprintf( stderr, " -m, --monitor : Specify which monitor to address, default 1 if absent\n" ); fprintf( stderr, " -q, --query : Query the current settings for the monitor\n" ); fprintf( stderr, " -s, --state : Output the current monitor state, 0 = idle, 1 = alarm, 2 = alert\n" ); fprintf( stderr, " -B, --brightness [value] : Output the current brightness, set to value if given \n" ); fprintf( stderr, " -C, --contrast [value] : Output the current contrast, set to value if given \n" ); fprintf( stderr, " -H, --hue [value] : Output the current hue, set to value if given \n" ); fprintf( stderr, " -O, --colour [value] : Output the current colour, set to value if given \n" ); fprintf( stderr, " -i, --image [image_index] : Write captured image to disk as .jpg, last image captured\n" ); fprintf( stderr, " or specified ring buffer index if given.\n" ); fprintf( stderr, " -t, --timestamp [image_index] : Output captured image timestamp, last image captured or specified\n" ); fprintf( stderr, " ring buffer index if given\n" ); fprintf( stderr, " -r, --read_index : Output ring buffer read index\n" ); fprintf( stderr, " -w, --write_index : Output ring buffer write index\n" ); fprintf( stderr, " -e, --event : Output last event index\n" ); fprintf( stderr, " -f, --fps : Output last Frames Per Second captured reading\n" ); fprintf( stderr, " -z, --zones : Write last captured image overlaid with zones to -Zones.jpg\n" ); fprintf( stderr, " -a, --alarm : Force alarm in monitor, this will trigger recording until cancelled with -c\n" ); fprintf( stderr, " -n, --noalarm : Force no alarms in monitor, this will prevent alarms until cancelled with -c\n" ); fprintf( stderr, " -c, --cancel : Cancel a forced alarm/noalarm in monitor, required after being enabled with -a or -n\n" ); exit( status ); } int main( int argc, char *argv[] ) { static struct option long_options[] = { {"device", 1, 0, 'd'}, {"monitor", 1, 0, 'm'}, {"verbose", 0, 0, 'v'}, {"image", 2, 0, 'i'}, {"timestamp", 2, 0, 't'}, {"state", 0, 0, 's'}, {"brightness", 2, 0, 'B'}, {"contrast", 2, 0, 'C'}, {"hue", 2, 0, 'H'}, {"contrast", 2, 0, 'O'}, {"read_index", 0, 0, 'r'}, {"write_index", 0, 0, 'w'}, {"event", 0, 0, 'e'}, {"fps", 0, 0, 'f'}, {"zones", 0, 0, 'z'}, {"alarm", 0, 0, 'a'}, {"noalarm", 0, 0, 'n'}, {"cancel", 0, 0, 'c'}, {"query", 0, 0, 'q'}, {"brightness", 0, 0, 'b'}, {"help", 0, 0, 'h'}, {0, 0, 0, 0} }; int dev_id = -1; int mon_id = 1; bool verbose = false; typedef enum { BOGUS=0x0000, STATE=0x0001, IMAGE=0x0002, TIME=0x0004, READ_IDX=0x0008, WRITE_IDX=0x0010, EVENT=0x0020, FPS=0x0040, ZONES=0x0080, ALARM=0x0100, NOALARM=0x0200, CANCEL=0x0400, QUERY=0x0800, BRIGHTNESS=0x1000, CONTRAST=0x2000, HUE=0x4000, COLOUR=0x8000 } Function; Function function = BOGUS; int image_idx = -1; int brightness = -1; int contrast = -1; int hue = -1; int colour = -1; while (1) { int option_index = 0; int c = getopt_long (argc, argv, "d:m:vsrwie::t::fzancqphB::C::H::O::", long_options, &option_index); if (c == -1) { break; } switch (c) { case 'd': dev_id = atoi(optarg); break; case 'm': mon_id = atoi(optarg); break; case 'v': verbose = true; break; case 's': function = Function(function | STATE); break; case 'i': function = Function(function | IMAGE); if ( optarg ) { image_idx = atoi( optarg ); } break; case 't': function = Function(function | TIME); if ( optarg ) { image_idx = atoi( optarg ); } break; case 'r': function = Function(function | READ_IDX); break; case 'w': function = Function(function | WRITE_IDX); break; case 'e': function = Function(function | EVENT); break; case 'f': function = Function(function | FPS); break; case 'z': function = Function(function | ZONES); break; case 'a': function = Function(function | ALARM); break; case 'n': function = Function(function | NOALARM); break; case 'c': function = Function(function | CANCEL); break; case 'q': function = Function(function | QUERY); break; case 'B': function = Function(function | BRIGHTNESS); if ( optarg ) { brightness = atoi( optarg ); } break; case 'C': function = Function(function | CONTRAST); if ( optarg ) { contrast = atoi( optarg ); } break; case 'H': function = Function(function | HUE); if ( optarg ) { hue = atoi( optarg ); } break; case 'O': function = Function(function | COLOUR); if ( optarg ) { colour = atoi( optarg ); } break; case 'h': Usage( 0 ); break; case '?': Usage(); break; default: //fprintf( stderr, "?? getopt returned character code 0%o ??\n", c ); break; } } if (optind < argc) { fprintf( stderr, "Extraneous options, " ); while (optind < argc) fprintf( stderr, "%s ", argv[optind++]); fprintf( stderr, "\n"); Usage(); } if ( dev_id >= 0 && !(function&(QUERY|QUERY)) ) { fprintf( stderr, "Error, -d option cannot be used with this option\n" ); Usage(); } //printf( "Monitor %d, Function %d\n", mon_id, function ); zm_dbg_name = "zmu"; zm_dbg_level = -1; zmDbgInit(); zmDbConnect( ZM_DB_USERB, ZM_DB_PASSB ); if ( dev_id >= 0 ) { if ( function & QUERY ) { char vid_string[4096] = ""; bool ok = LocalCamera::GetCurrentSettings( dev_id, vid_string, verbose ); printf( "%s", vid_string ); exit( ok?0:-1 ); } } else { Monitor *monitor = Monitor::Load( mon_id, function&(QUERY|ZONES) ); if ( monitor ) { if ( verbose ) { printf( "Monitor %d(%s)\n", monitor->Id(), monitor->Name() ); } char separator = ' '; bool have_output = false; if ( function & STATE ) { Monitor::State state = monitor->GetState(); if ( verbose ) printf( "Current state: %s\n", state==Monitor::ALARM?"Alarm":(state==Monitor::ALERT?"Alert":"Idle") ); else { if ( have_output ) printf( "%c", separator ); printf( "%d", state ); have_output = true; } } if ( function & TIME ) { struct timeval timestamp = monitor->GetTimestamp( image_idx ); if ( verbose ) { char timestamp_str[64] = "None"; if ( timestamp.tv_sec ) strftime( timestamp_str, sizeof(timestamp_str), "%Y-%m-%d %H:%M:%S", localtime( ×tamp.tv_sec ) ); if ( image_idx == -1 ) printf( "Time of last image capture: %s.%02ld\n", timestamp_str, timestamp.tv_usec/10000 ); else printf( "Time of image %d capture: %s.%02ld\n", image_idx, timestamp_str, timestamp.tv_usec/10000 ); } else { if ( have_output ) printf( "%c", separator ); printf( "%ld.%02ld", timestamp.tv_sec, timestamp.tv_usec/10000 ); have_output = true; } } if ( function & READ_IDX ) { if ( verbose ) printf( "Last read index: %d\n", monitor->GetLastReadIndex() ); else { if ( have_output ) printf( "%c", separator ); printf( "%d", monitor->GetLastReadIndex() ); have_output = true; } } if ( function & WRITE_IDX ) { if ( verbose ) printf( "Last write index: %d\n", monitor->GetLastWriteIndex() ); else { if ( have_output ) printf( "%c", separator ); printf( "%d", monitor->GetLastWriteIndex() ); have_output = true; } } if ( function & EVENT ) { if ( verbose ) printf( "Last event id: %d\n", monitor->GetLastEvent() ); else { if ( have_output ) printf( "%c", separator ); printf( "%d", monitor->GetLastEvent() ); have_output = true; } } if ( function & FPS ) { if ( verbose ) printf( "Current capture rate: %.2f frames per second\n", monitor->GetFPS() ); else { if ( have_output ) printf( "%c", separator ); printf( "%.2f", monitor->GetFPS() ); have_output = true; } } if ( function & IMAGE ) { if ( verbose ) { if ( image_idx == -1 ) printf( "Dumping last image captured to %s.jpg\n", monitor->Name() ); else printf( "Dumping buffer image %d to %s.jpg\n", image_idx, monitor->Name() ); } monitor->GetImage( image_idx ); } if ( function & ZONES ) { if ( verbose ) printf( "Dumping zone image to %s-Zones.jpg\n", monitor->Name() ); monitor->DumpZoneImage(); } if ( function & ALARM ) { if ( verbose ) printf( "Forcing alarm on\n" ); monitor->ForceAlarmOn(); } if ( function & NOALARM ) { if ( verbose ) printf( "Forcing alarm off\n" ); monitor->ForceAlarmOff(); } if ( function & CANCEL ) { if ( verbose ) printf( "Cancelling forced alarm on/off\n" ); monitor->CancelForced(); } if ( function & QUERY ) { char mon_string[1024] = ""; monitor->DumpSettings( mon_string, verbose ); printf( "%s\n", mon_string ); } if ( function & BRIGHTNESS ) { if ( verbose ) { if ( brightness >= 0 ) printf( "New brightness: %d\n", monitor->Brightness( brightness ) ); else printf( "Current brightness: %d\n", monitor->Brightness() ); } else { if ( have_output ) printf( "%c", separator ); if ( brightness >= 0 ) printf( "%d", monitor->Brightness( brightness ) ); else printf( "%d", monitor->Brightness() ); have_output = true; } } if ( function & CONTRAST ) { if ( verbose ) { if ( contrast >= 0 ) printf( "New brightness: %d\n", monitor->Contrast( contrast ) ); else printf( "Current contrast: %d\n", monitor->Contrast() ); } else { if ( have_output ) printf( "%c", separator ); if ( contrast >= 0 ) printf( "%d", monitor->Contrast( contrast ) ); else printf( "%d", monitor->Contrast() ); have_output = true; } } if ( function & HUE ) { if ( verbose ) { if ( hue >= 0 ) printf( "New hue: %d\n", monitor->Hue( hue ) ); else printf( "Current hue: %d\n", monitor->Hue() ); } else { if ( have_output ) printf( "%c", separator ); if ( hue >= 0 ) printf( "%d", monitor->Hue( hue ) ); else printf( "%d", monitor->Hue() ); have_output = true; } } if ( function & COLOUR ) { if ( verbose ) { if ( colour >= 0 ) printf( "New colour: %d\n", monitor->Colour( colour ) ); else printf( "Current colour: %d\n", monitor->Colour() ); } else { if ( have_output ) printf( "%c", separator ); if ( colour >= 0 ) printf( "%d", monitor->Colour( colour ) ); else printf( "%d", monitor->Colour() ); have_output = true; } } if ( have_output ) { printf( "\n" ); } if ( !function ) { Usage(); } } else { fprintf( stderr, "Error, invalid monitor id %d", mon_id ); exit( -1 ); } } return( 0 ); }