yeah! it simulates the user activity! woo! awesome
[ozzloy@gmail.com/oble] / hello-world.cpp
index 7d68365d76f153bf8073e24d9bb86514fc125d96..045c11442a759cdf7322363af28cb3c58111a520 100644 (file)
@@ -1,10 +1,44 @@
+//use the camera to aid the decision to sleep.
+//Copyright 2009 Daniel Watson
+/*
+        This file is part of oble.
+
+        oble 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 3 of the License, or
+        (at your option) any later version.
+
+        oble 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 oble.  If not, see <http://www.gnu.org/licenses/>.
+
+*/
 #include <cv.h>
 #include <highgui.h>
 #include <stdio.h>
+#include <iostream>
+#include <dbus/dbus.h>
+#include <dbus/dbus-glib.h>
+
+using namespace std;
+
+DBusGConnection *connection;
+GError *error;
+DBusGProxy *proxy;
+char **name_list;
+char **name_list_ptr;
+
+
+// argument for cvFlip(src, dest, FLIP_TYPE)
+#define MIRROR 1
 
 CvHaarClassifierCascade* load_object_detector(const char* cascade_path)
 {
-       return (CvHaarClassifierCascade*)cvLoad( cascade_path );
+       return (CvHaarClassifierCascade*)cvLoad(cascade_path);
 }
 
 void detect_and_draw_objects(IplImage* image,
@@ -18,74 +52,107 @@ void detect_and_draw_objects(IplImage* image,
 
        /* if the flag is specified, down-scale the input image to get a
                 performance boost w/o loosing quality (perhaps) */
-       if( do_pyramids )
+       if(do_pyramids)
        {
-               small_image = cvCreateImage( cvSize(image->width/2,image->height/2), IPL_DEPTH_8U, 3 );
-               cvPyrDown( image, small_image, CV_GAUSSIAN_5x5 );
+               small_image = cvCreateImage(cvSize(image->width/2,image->height/2),
+                               IPL_DEPTH_8U, 3);
+               cvPyrDown(image, small_image, CV_GAUSSIAN_5x5);
                scale = 2;
        }
 
        /* use the fastest variant */
-       faces = cvHaarDetectObjects( small_image, cascade, storage, 1.2, 2, CV_HAAR_DO_CANNY_PRUNING );
+       faces = cvHaarDetectObjects(small_image, cascade, storage, 1.2, 2,
+                       CV_HAAR_DO_CANNY_PRUNING);
+
+       if(0 < faces->total)
+       {
+               dbus_g_proxy_call_no_reply(proxy, "SimulateUserActivity", G_TYPE_INVALID);
+       }
 
        /* draw all the rectangles */
-       for( i = 0; i < faces->total; i++ )
+       for(i = 0; i < faces->total; i++)
        {
                /* extract the rectangles only */
-               //CvRect face_rect = *(CvRect*)cvGetSeqElem( faces, i, 0 );
-               CvRect face_rect = *(CvRect*)cvGetSeqElem( faces, i);
-               cvRectangle( image, cvPoint(face_rect.x*scale,face_rect.y*scale),
-                               cvPoint((face_rect.x+face_rect.width)*scale,
-                                       (face_rect.y+face_rect.height)*scale),
-                               CV_RGB(255,0,0), 3 );
+               CvRect face = *(CvRect*)cvGetSeqElem(faces, i);
+               CvPoint upperLeft = cvPoint(face.x*scale,face.y*scale);
+               CvPoint bottomRight = cvPoint((face.x+face.width)*scale,
+                               (face.y+face.height)*scale);
+               cvRectangle(image, upperLeft, bottomRight, CV_RGB(255,0,0), 3);
        }
 
-       if( small_image != image )
-               cvReleaseImage( &small_image );
-       cvReleaseMemStorage( &storage );
+       if(small_image != image)
+               cvReleaseImage(&small_image);
+       cvReleaseMemStorage(&storage);
 }
 
 // A Simple Camera Capture Framework.
->>>>>>> experimental:hello-world.cpp
-int main( int argc, char** argv )
+int main(int argc, char** argv)
 {
+       g_type_init ();
+
+       error = NULL;
+       connection = dbus_g_bus_get (DBUS_BUS_SESSION,
+                       &error);
+       if (connection == NULL)
+       {
+               g_printerr ("Failed to open connection to bus: %s\n",
+                               error->message);
+               g_error_free (error);
+               exit (1);
+       }
+
+       /* Create a proxy object for the "bus driver" (name "org.freedesktop.DBus") */
+
+       proxy = dbus_g_proxy_new_for_name (connection,
+                       "org.gnome.ScreenSaver",
+                       "/org/gnome/ScreenSaver",
+                       "org.gnome.ScreenSaver");
+
        CvHaarClassifierCascade* cascade = load_object_detector(argv[1]);
 
-       CvCapture* capture = cvCaptureFromCAM( CV_CAP_ANY );
-       if( !capture ) {
-               fprintf( stderr, "ERROR: capture is NULL \n" );
+       CvCapture* capture = cvCaptureFromCAM(CV_CAP_ANY);
+       if(!capture) {
+               cerr << "ERROR: capture is NULL " << endl;
                getchar();
                return -1;
        }
 
        // Create a window in which the captured images will be presented
-       cvNamedWindow( "mywindow", CV_WINDOW_AUTOSIZE );
+       cvNamedWindow("mywindow", CV_WINDOW_AUTOSIZE);
 
+       IplImage* frame = cvQueryFrame(capture);
+       if(!frame) {
+               cerr << "ERROR: frame is null..." << endl;
+               getchar();
+               return -1;
+       }
+       IplImage* mirrored =
+               cvCreateImage(cvGetSize(frame), frame->depth, frame->nChannels);
        // Show the image captured from the camera in the window and repeat
-       while( 1 ) {
+       while(1) {
                // Get one frame
-               IplImage* frame = cvQueryFrame(capture);
-               IplImage* flipped = cvCreateImage(cvSize(frame->width, frame->height),
-                               frame->depth, frame->nChannels);
-               if( !frame ) {
-                       fprintf( stderr, "ERROR: frame is null...\n" );
+               frame = cvQueryFrame(capture);
+               if(!frame) {
+                       cerr << "ERROR: frame is null..." << endl;
                        getchar();
                        break;
                }
 
-               cvFlip(frame, flipped, 1);
+               //flip the image so displayed right/left corresponds to physical right/left
+               cvFlip(frame, mirrored, MIRROR);
 
-               detect_and_draw_objects(flipped, cascade, 1);
-               cvShowImage( "mywindow", flipped);
+               detect_and_draw_objects(mirrored, cascade, 1);
+               cvShowImage("mywindow", mirrored);
                // Do not release the frame!
 
                //If ESC key pressed, Key=0x10001B under OpenCV 0.9.7(linux version),
                //remove higher bits using AND operator
-               if( (cvWaitKey(10) & 255) == 27 ) break;
+               if((cvWaitKey(10) & 255) == 27) break;
        }
 
        // Release the capture device housekeeping
-       cvReleaseCapture( &capture );
-       cvDestroyWindow( "mywindow" );
+       cvReleaseCapture(&capture);
+       cvDestroyWindow("mywindow");
+       cvReleaseImage(&mirrored);
        return 0;
 }