This is the latest WPILib src, VisionSample2013, cRIO image, ... pulled down from firstforge.wpi.edu.
There might be risks in using the top of tree rather than an official release, but the commit messages do mention fixes for some deadlocks and race conditions.
git-svn-id: https://robotics.mvla.net/svn/frc971/2013/trunk/src@4066 f308d9b7-e957-4cde-b6ac-9a88185e7312
diff --git a/azaleasource/WPILibCProgramming/trunk/WPILib/Vision/BinaryImage.h b/azaleasource/WPILibCProgramming/trunk/WPILib/Vision/BinaryImage.h
new file mode 100644
index 0000000..b71f86a
--- /dev/null
+++ b/azaleasource/WPILibCProgramming/trunk/WPILib/Vision/BinaryImage.h
@@ -0,0 +1,42 @@
+/*----------------------------------------------------------------------------*/
+/* Copyright (c) FIRST 2008. All Rights Reserved. */
+/* Open Source Software - may be modified and shared by FRC teams. The code */
+/* must be accompanied by the FIRST BSD license file in $(WIND_BASE)/WPILib. */
+/*----------------------------------------------------------------------------*/
+
+#ifndef __BINARY_IMAGE_H__
+#define __BINARY_IMAGE_H__
+
+#include "MonoImage.h"
+/**
+ * Included for ParticleAnalysisReport definition
+ * TODO: Eliminate this dependency!
+ */
+#include "Vision2009/VisionAPI.h"
+
+#include <vector>
+#include <algorithm>
+using namespace std;
+
+class BinaryImage : public MonoImage
+{
+public:
+ BinaryImage();
+ virtual ~BinaryImage();
+ int GetNumberParticles();
+ ParticleAnalysisReport GetParticleAnalysisReport(int particleNumber);
+ void GetParticleAnalysisReport(int particleNumber, ParticleAnalysisReport *par);
+ vector<ParticleAnalysisReport>* GetOrderedParticleAnalysisReports();
+ BinaryImage *RemoveSmallObjects(bool connectivity8, int erosions);
+ BinaryImage *RemoveLargeObjects(bool connectivity8, int erosions);
+ BinaryImage *ConvexHull(bool connectivity8);
+ BinaryImage *ParticleFilter(ParticleFilterCriteria2 *criteria, int criteriaCount);
+ virtual void Write(const char *fileName);
+private:
+ bool ParticleMeasurement(int particleNumber, MeasurementType whatToMeasure, int *result);
+ bool ParticleMeasurement(int particleNumber, MeasurementType whatToMeasure, double *result);
+ static double NormalizeFromRange(double position, int range);
+ static bool CompareParticleSizes(ParticleAnalysisReport particle1, ParticleAnalysisReport particle2);
+};
+
+#endif