Difference between revisions of "OpenCV"
(OpenCV moved to OpenCV Tennis balls recognizing tutorial: We will have a more general OpenCV page.) |
(→Using v4lsink GStreamer plugin and v4l2loopback) |
||
(10 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
− | # | + | =Single image= |
+ | You can use [[imgsrv]] to download a single image from the [[circbuf]]. MJPEG live stream is also available from [[imgsrv]]. | ||
+ | |||
+ | You can use [http://www.gnu.org/software/wget/ wget] to download the image to your computer or implement a small HTTP client in your software. | ||
+ | |||
+ | =Live video= | ||
+ | ==Using AVLD== | ||
+ | AVLD stand for [[AVLD - Another Video Loopback Device]]. It's a very CPU and RAM consuming way to present an Elphel network camera as V4l device. | ||
+ | |||
+ | While it is the only solution with proprietary v4l compatible software products (such as skype), it's a total waste of resources for a free software app what can be adapted to receive an RTP stream. | ||
+ | |||
+ | Moreover, you can proceed to download the source code from: | ||
+ | http://allonlinux.free.fr/Projets/AVLD/src/avld_0.1.4.tar.bz2 | ||
+ | |||
+ | Then: | ||
+ | $ tar -jxvf avld_0.1.4.tar.bz2 | ||
+ | $ cd avld_0.1.4 | ||
+ | $ make && sudo make install | ||
+ | |||
+ | Right now you can mount your dummy device typing: | ||
+ | $sudo modprobe avld width=<camera width resolution> height=<camera height resolution> fps=<camera fps> | ||
+ | |||
+ | Finally, you need to use mencoder in order to redirect the rtsp source to the dummy device: | ||
+ | $ sudo mencoder rtsp://192.168.1.180 -nosound -ovc raw -vf format=bgr24 -of rawvideo -o /dev/video0 | ||
+ | |||
+ | With this, you just need a simple code in order to preview the scene: | ||
+ | |||
+ | #include "highgui.h" | ||
+ | #include "cv.h" | ||
+ | #include "cvaux.h" | ||
+ | #include <ml.h> | ||
+ | |||
+ | int main(int argc,char *argv[]) | ||
+ | { | ||
+ | cvNamedWindow( "Current Frame"); | ||
+ | IplImage* pCurrentFrame = NULL; | ||
+ | CvSize frame_size; | ||
+ | CvCapture* capture = cvCaptureFromCAM ( 0 ); //the dummy device make the job :) | ||
+ | char c; | ||
+ | while ( 1 ) | ||
+ | { | ||
+ | //Request frame from Camera | ||
+ | pCurrentFrame = cvQueryFrame ( capture ); | ||
+ | //video input file finished | ||
+ | if( !pCurrentFrame ) break; | ||
+ | cvShowImage( "Current Frame", pCurrentFrame ); | ||
+ | c = cvWaitKey(10); | ||
+ | if ( c == 27 ) break; | ||
+ | } | ||
+ | cvReleaseImage ( &pCurrentFrame ); | ||
+ | cvDestroyAllWindows (); | ||
+ | return 0; | ||
+ | } | ||
+ | |||
+ | --[[User:maurosc3ner|Esteban Correa]] 21:54, 29 July 2010 (CDT) | ||
+ | |||
+ | ==Using v4lsink GStreamer plugin and v4l2loopback== | ||
+ | This is basically an AVLD fork that now evolved into v4l2loopback and a special gstreamer sink to the loopback device. | ||
+ | |||
+ | You can find the projects homepages at: http://code.google.com/p/v4lsink/ & http://code.google.com/p/v4l2loopback/ (This version does not compile due to vala dependencies, somebody cloned and patched the project, it is available from github: http://github.com/umlaeute/gst-v4l2loopback) | ||
+ | |||
+ | To install it do: | ||
+ | hg clone https://v4l2loopback.googlecode.com/hg/ v4l2loopback | ||
+ | cd v4l2loopback | ||
+ | make | ||
+ | make install | ||
+ | |||
+ | load the module: | ||
+ | modprobe v4l2loopback | ||
+ | |||
+ | To compile v4lsink you will need Vala compiler >= 0.8.1, the easy way is to install the package from Vala PPA: | ||
+ | sudo add-apt-repository ppa:vala-team/ppa | ||
+ | sudo apt-get update | ||
+ | sudo apt-get install valac vala-utils | ||
+ | It will install valac 0.9.1 instead of default 0.8.0 under Ubuntu 10.04. | ||
+ | |||
+ | Install v4lsink: | ||
+ | git clone http://github.com/umlaeute/gst-v4l2loopback.git | ||
+ | cd gst-v4l2loopback | ||
+ | ./autogen.sh | ||
+ | make | ||
+ | make install | ||
+ | This will install the new gstreamer module in ~/.gstreamer-0.10/plugins/ folder. Now you can try "gst-inspect v4l2loopback" | ||
+ | |||
+ | Default resolution is fixed to 640x480, if you want to change the resolution, you can change it in the two places of the v4l2loopback.c file and recompile/reinstall v4lsink. | ||
+ | |||
+ | To test it with an RTSP stream from an Elphel camera you need to feed the stream into the loopback device: | ||
+ | gst-launch -e -m rtspsrc location=rtsp://192.168.0.9:554 latency=50 ! rtpjpegdepay ! jpegdec ! ffmpegcolorspace ! v4l2loopback | ||
+ | |||
+ | Now you can open the stream as v4l2 device with any compatible program: | ||
+ | mplayer tv:// -tv device=/dev/video1 | ||
+ | |||
+ | To test with OpenCV simply change the v4l2 device number: | ||
+ | // CvCapture* capture = 0; | ||
+ | CvCapture* capture = 1; | ||
+ | |||
+ | ==Using OpenCV with FFMPEG== | ||
+ | |||
+ | |||
+ | ==Using OpenCV with GStreamer== | ||
+ | |||
+ | ==Design your OpenCV code as GStreamer plugin== | ||
+ | http://github.com/Elleo/gst-opencv | ||
+ | |||
+ | =Portability= | ||
+ | |||
+ | =Tutorials= | ||
+ | ==Tennis balls recognizing== | ||
+ | [[OpenCV Tennis balls recognizing tutorial]] | ||
+ | |||
+ | ==Go game record (kifu) generator== | ||
+ | [[Kifu:_Go_game_record_(kifu)_generator]] |
Latest revision as of 07:31, 29 August 2010
Contents
Single image
You can use imgsrv to download a single image from the circbuf. MJPEG live stream is also available from imgsrv.
You can use wget to download the image to your computer or implement a small HTTP client in your software.
Live video
Using AVLD
AVLD stand for AVLD - Another Video Loopback Device. It's a very CPU and RAM consuming way to present an Elphel network camera as V4l device.
While it is the only solution with proprietary v4l compatible software products (such as skype), it's a total waste of resources for a free software app what can be adapted to receive an RTP stream.
Moreover, you can proceed to download the source code from:
http://allonlinux.free.fr/Projets/AVLD/src/avld_0.1.4.tar.bz2
Then:
$ tar -jxvf avld_0.1.4.tar.bz2 $ cd avld_0.1.4 $ make && sudo make install
Right now you can mount your dummy device typing:
$sudo modprobe avld width=<camera width resolution> height=<camera height resolution> fps=<camera fps>
Finally, you need to use mencoder in order to redirect the rtsp source to the dummy device:
$ sudo mencoder rtsp://192.168.1.180 -nosound -ovc raw -vf format=bgr24 -of rawvideo -o /dev/video0
With this, you just need a simple code in order to preview the scene:
#include "highgui.h" #include "cv.h" #include "cvaux.h" #include <ml.h> int main(int argc,char *argv[]) { cvNamedWindow( "Current Frame"); IplImage* pCurrentFrame = NULL; CvSize frame_size; CvCapture* capture = cvCaptureFromCAM ( 0 ); //the dummy device make the job :) char c; while ( 1 ) { //Request frame from Camera pCurrentFrame = cvQueryFrame ( capture ); //video input file finished if( !pCurrentFrame ) break; cvShowImage( "Current Frame", pCurrentFrame ); c = cvWaitKey(10); if ( c == 27 ) break; } cvReleaseImage ( &pCurrentFrame ); cvDestroyAllWindows (); return 0; }
--Esteban Correa 21:54, 29 July 2010 (CDT)
Using v4lsink GStreamer plugin and v4l2loopback
This is basically an AVLD fork that now evolved into v4l2loopback and a special gstreamer sink to the loopback device.
You can find the projects homepages at: http://code.google.com/p/v4lsink/ & http://code.google.com/p/v4l2loopback/ (This version does not compile due to vala dependencies, somebody cloned and patched the project, it is available from github: http://github.com/umlaeute/gst-v4l2loopback)
To install it do:
hg clone https://v4l2loopback.googlecode.com/hg/ v4l2loopback cd v4l2loopback make make install
load the module:
modprobe v4l2loopback
To compile v4lsink you will need Vala compiler >= 0.8.1, the easy way is to install the package from Vala PPA:
sudo add-apt-repository ppa:vala-team/ppa sudo apt-get update sudo apt-get install valac vala-utils
It will install valac 0.9.1 instead of default 0.8.0 under Ubuntu 10.04.
Install v4lsink:
git clone http://github.com/umlaeute/gst-v4l2loopback.git cd gst-v4l2loopback ./autogen.sh make make install
This will install the new gstreamer module in ~/.gstreamer-0.10/plugins/ folder. Now you can try "gst-inspect v4l2loopback"
Default resolution is fixed to 640x480, if you want to change the resolution, you can change it in the two places of the v4l2loopback.c file and recompile/reinstall v4lsink.
To test it with an RTSP stream from an Elphel camera you need to feed the stream into the loopback device:
gst-launch -e -m rtspsrc location=rtsp://192.168.0.9:554 latency=50 ! rtpjpegdepay ! jpegdec ! ffmpegcolorspace ! v4l2loopback
Now you can open the stream as v4l2 device with any compatible program:
mplayer tv:// -tv device=/dev/video1
To test with OpenCV simply change the v4l2 device number:
// CvCapture* capture = 0; CvCapture* capture = 1;
Using OpenCV with FFMPEG
Using OpenCV with GStreamer
Design your OpenCV code as GStreamer plugin
http://github.com/Elleo/gst-opencv
Portability
Tutorials
Tennis balls recognizing
OpenCV Tennis balls recognizing tutorial