mirror of
https://github.com/team2059/Dent
synced 2025-01-27 22:21:07 -05:00
Removed extra vision code (untested)
This commit is contained in:
parent
2037008242
commit
4f6ea560e3
@ -1,11 +1,11 @@
|
|||||||
#include "cv.h"
|
#include "cv.h"
|
||||||
#include "highgui.h"
|
#include "highgui.h"
|
||||||
IplImage* GetThresholdedImage(IplImage* img)
|
IplImage* GetThresholdedImage(IplImage* img){
|
||||||
{
|
|
||||||
// Convert the image into an HSV image
|
// Convert the image into an HSV image
|
||||||
IplImage* imgHSV = cvCreateImage(cvGetSize(img), 8, 3);
|
IplImage* imgHSV = cvCreateImage(cvGetSize(img), 8, 3);
|
||||||
cvCvtColor(img, imgHSV, CV_BGR2HSV);
|
cvCvtColor(img, imgHSV, CV_BGR2HSV);
|
||||||
IplImage* imgThreshed = cvCreateImage(cvGetSize(img), 8, 1);
|
IplImage* imgThreshed = cvCreateImage(cvGetSize(img), 8, 1);
|
||||||
|
// Set yellow to white and all other colors to black
|
||||||
//cvInRangeS(imgHSV, cvScalar(20, 100, 100), cvScalar(30, 255, 255), imgThreshed);
|
//cvInRangeS(imgHSV, cvScalar(20, 100, 100), cvScalar(30, 255, 255), imgThreshed);
|
||||||
cvInRangeS(imgHSV, cvScalar(10, 100, 100), cvScalar(40, 255, 255), imgThreshed);
|
cvInRangeS(imgHSV, cvScalar(10, 100, 100), cvScalar(40, 255, 255), imgThreshed);
|
||||||
cvReleaseImage(&imgHSV);
|
cvReleaseImage(&imgHSV);
|
||||||
@ -19,20 +19,13 @@ int main()
|
|||||||
capture = cvCaptureFromCAM(0);
|
capture = cvCaptureFromCAM(0);
|
||||||
|
|
||||||
// Couldn't get a device? Throw an error and quit
|
// Couldn't get a device? Throw an error and quit
|
||||||
if(!capture)
|
if(!capture){
|
||||||
{
|
|
||||||
printf("Could not initialize capturing...");
|
printf("Could not initialize capturing...");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
// The two windows we'll be using
|
|
||||||
cvNamedWindow("video");
|
cvNamedWindow("video");
|
||||||
cvNamedWindow("thresh");
|
cvNamedWindow("thresh");
|
||||||
// This image holds the "scribble" data...
|
while(true){
|
||||||
// the tracked positions of the ball
|
|
||||||
IplImage* imgScribble = NULL;
|
|
||||||
// An infinite loop
|
|
||||||
while(true)
|
|
||||||
{
|
|
||||||
// Will hold a frame captured from the camera
|
// Will hold a frame captured from the camera
|
||||||
IplImage* frame = 0;
|
IplImage* frame = 0;
|
||||||
frame = cvQueryFrame(capture);
|
frame = cvQueryFrame(capture);
|
||||||
@ -40,56 +33,18 @@ int main()
|
|||||||
if(!frame)
|
if(!frame)
|
||||||
break;
|
break;
|
||||||
// If this is the first frame, we need to initialize it
|
// If this is the first frame, we need to initialize it
|
||||||
if(imgScribble == NULL)
|
|
||||||
{
|
|
||||||
imgScribble = cvCreateImage(cvGetSize(frame), 8, 3);
|
|
||||||
}
|
|
||||||
// Holds the yellow thresholded image (yellow = white, rest = black)
|
// Holds the yellow thresholded image (yellow = white, rest = black)
|
||||||
IplImage* imgYellowThresh = GetThresholdedImage(frame);
|
IplImage* imgYellowThresh = GetThresholdedImage(frame);
|
||||||
// Calculate the moments to estimate the position of the ball
|
|
||||||
CvMoments *moments = (CvMoments*)malloc(sizeof(CvMoments));
|
|
||||||
|
|
||||||
cvMoments(imgYellowThresh, moments, 1);
|
|
||||||
|
|
||||||
// The actual moment values
|
|
||||||
double moment10 = cvGetSpatialMoment(moments, 1, 0);
|
|
||||||
double moment01 = cvGetSpatialMoment(moments, 0, 1);
|
|
||||||
|
|
||||||
double area = cvGetCentralMoment(moments, 0, 0);
|
|
||||||
// Holding the last and current ball positions
|
|
||||||
static int posX = 0;
|
|
||||||
|
|
||||||
static int posY = 0;
|
|
||||||
|
|
||||||
int lastX = posX;
|
|
||||||
|
|
||||||
int lastY = posY;
|
|
||||||
|
|
||||||
posX = moment10/area;
|
|
||||||
posY = moment01/area;
|
|
||||||
// Print it out for debugging purposes
|
|
||||||
printf("position (%d,%d)", posX, posY);
|
|
||||||
// We want to draw a line only if its a valid position
|
|
||||||
if(lastX>0 && lastY>0 && posX>0 && posY>0)
|
|
||||||
{
|
|
||||||
// Draw a yellow line from the previous point to the current point
|
|
||||||
cvLine(imgScribble, cvPoint(posX, posY), cvPoint(lastX, lastY), cvScalar(0,255,255), 5);
|
|
||||||
|
|
||||||
}
|
|
||||||
// Add the scribbling image and the frame...
|
|
||||||
cvAdd(frame, imgScribble, frame);
|
|
||||||
cvShowImage("thresh", imgYellowThresh);
|
cvShowImage("thresh", imgYellowThresh);
|
||||||
cvShowImage("video", frame);
|
cvShowImage("video", frame);
|
||||||
// Wait for a keypress
|
// Quit on keypress
|
||||||
int c = cvWaitKey(10);
|
int c = cvWaitKey(10);
|
||||||
if(c!=-1)
|
if(c!=-1){
|
||||||
{
|
|
||||||
// If pressed, break out of the loop
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// Release the thresholded image+moments... we need no memory leaks.. please
|
|
||||||
cvReleaseImage(&imgYellowThresh);
|
cvReleaseImage(&imgYellowThresh);
|
||||||
delete moments;
|
|
||||||
}
|
}
|
||||||
// We're done using the camera. Other applications can now use it
|
// We're done using the camera. Other applications can now use it
|
||||||
cvReleaseCapture(&capture);
|
cvReleaseCapture(&capture);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user