mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-21 01:01:43 +00:00
Years update, references to WIND_BASE were removed, and WPILib license was moved to the root directory of the project. If there was already a comment block, a year range through 2016 was created using the first year in the comment. If there was no comment block, a block with just the year 2016 was added. Comments were not added to files from external sources (NI, CTRE). Change-Id: Iff4f098ab908b90b8d929902dea903de2f596acc
44 lines
1.8 KiB
C++
44 lines
1.8 KiB
C++
/*----------------------------------------------------------------------------*/
|
|
/* Copyright (c) FIRST 2014-2016. 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 the root directory of */
|
|
/* the project. */
|
|
/*----------------------------------------------------------------------------*/
|
|
|
|
#pragma once
|
|
|
|
#include "MonoImage.h"
|
|
/**
|
|
* Included for ParticleAnalysisReport definition
|
|
* TODO: Eliminate this dependency!
|
|
*/
|
|
#include "Vision/VisionAPI.h"
|
|
|
|
#include <vector>
|
|
#include <algorithm>
|
|
|
|
class BinaryImage : public MonoImage {
|
|
public:
|
|
virtual ~BinaryImage() = default;
|
|
int GetNumberParticles();
|
|
ParticleAnalysisReport GetParticleAnalysisReport(int particleNumber);
|
|
void GetParticleAnalysisReport(int particleNumber,
|
|
ParticleAnalysisReport *par);
|
|
std::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);
|
|
};
|