logpolar.m 1.13 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
#! /usr/bin/env octave
cv;
highgui;

global g;
g.src=[];
g.dst=[];
g.src2=[];

function on_mouse( event, x, y, flags, param )
  global g;
  global cv;
  global highgui;

  if(!swig_this(g.src) )
    return;
  endif

  if (event==highgui.CV_EVENT_LBUTTONDOWN)
    cvLogPolar( g.src, g.dst, cvPoint2D32f(x,y), 40, cv.CV_INTER_LINEAR+cv.CV_WARP_FILL_OUTLIERS );
    cvLogPolar( g.dst, g.src2, cvPoint2D32f(x,y), 40, cv.CV_INTER_LINEAR+cv.CV_WARP_FILL_OUTLIERS+cv.CV_WARP_INVERSE_MAP );
    cvShowImage( "log-polar", g.dst );
    cvShowImage( "inverse log-polar", g.src2 );
  endif
endfunction

filename = "../c/fruits.jpg"
if (size(argv, 1)>1)
  filename=argv(){1};
endif

g.src = cvLoadImage(filename,1);
if (!swig_this(g.src))
  printf("Could not open %s",filename);
  exit(-1)
endif

cvNamedWindow( "original",1 );
cvNamedWindow( "log-polar", 1 );
cvNamedWindow( "inverse log-polar", 1 );


g.dst = cvCreateImage( cvSize(256,256), 8, 3 );
g.src2 = cvCreateImage( cvGetSize(g.src), 8, 3 );

cvSetMouseCallback( "original", @on_mouse );
on_mouse( CV_EVENT_LBUTTONDOWN, g.src.width/2, g.src.height/2, [], []);

cvShowImage( "original", g.src );
cvWaitKey();