mirror of
https://github.com/kerberos-io/openalpr-base.git
synced 2025-10-07 07:40:56 +08:00
Added setCountry function to main API.
This allows the country to be changed without reloading the library and runtime_data
This commit is contained in:
@@ -87,6 +87,10 @@ namespace alpr
|
||||
return AlprImpl::fromJson(json);
|
||||
}
|
||||
|
||||
void Alpr::setCountry(std::string country) {
|
||||
impl->setCountry(country);
|
||||
}
|
||||
|
||||
|
||||
void Alpr::setDetectRegion(bool detectRegion)
|
||||
{
|
||||
|
@@ -137,6 +137,9 @@ namespace alpr
|
||||
Alpr(const std::string country, const std::string configFile = "", const std::string runtimeDir = "");
|
||||
virtual ~Alpr();
|
||||
|
||||
// Set the country used for plate recognition
|
||||
void setCountry(std::string country);
|
||||
|
||||
void setDetectRegion(bool detectRegion);
|
||||
void setTopN(int topN);
|
||||
void setDefaultRegion(std::string region);
|
||||
|
@@ -45,19 +45,7 @@ namespace alpr
|
||||
return;
|
||||
}
|
||||
|
||||
for (unsigned int i = 0; i < config->loaded_countries.size(); i++)
|
||||
{
|
||||
config->setCountry(config->loaded_countries[i]);
|
||||
|
||||
AlprRecognizers recognizer;
|
||||
recognizer.plateDetector = createDetector(config);
|
||||
recognizer.ocr = new OCR(config);
|
||||
|
||||
recognizer.stateDetector = new StateDetector(this->config->country, this->config->config_file_path, this->config->runtimeBaseDir);
|
||||
|
||||
recognizers[config->country] = recognizer;
|
||||
|
||||
}
|
||||
loadRecognizers();
|
||||
|
||||
setNumThreads(0);
|
||||
|
||||
@@ -666,6 +654,11 @@ namespace alpr
|
||||
return allResults;
|
||||
}
|
||||
|
||||
void AlprImpl::setCountry(std::string country) {
|
||||
config->load_countries(country);
|
||||
loadRecognizers();
|
||||
}
|
||||
|
||||
|
||||
void AlprImpl::setDetectRegion(bool detectRegion)
|
||||
{
|
||||
@@ -691,6 +684,28 @@ namespace alpr
|
||||
return ss.str();
|
||||
}
|
||||
|
||||
|
||||
void AlprImpl::loadRecognizers() {
|
||||
for (unsigned int i = 0; i < config->loaded_countries.size(); i++)
|
||||
{
|
||||
config->setCountry(config->loaded_countries[i]);
|
||||
|
||||
if (recognizers.find(config->country) == recognizers.end())
|
||||
{
|
||||
// Country training data has not already been loaded. Load it.
|
||||
AlprRecognizers recognizer;
|
||||
recognizer.plateDetector = createDetector(config);
|
||||
recognizer.ocr = new OCR(config);
|
||||
|
||||
recognizer.stateDetector = new StateDetector(this->config->country, this->config->config_file_path, this->config->runtimeBaseDir);
|
||||
|
||||
recognizers[config->country] = recognizer;
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
cv::Mat AlprImpl::getCharacterTransformMatrix(PipelineData* pipeline_data ) {
|
||||
std::vector<Point2f> crop_corners;
|
||||
crop_corners.push_back(Point2f(0,0));
|
||||
|
@@ -92,6 +92,7 @@ namespace alpr
|
||||
|
||||
AlprFullDetails analyzeSingleCountry(cv::Mat colorImg, cv::Mat grayImg, std::vector<cv::Rect> regionsOfInterest);
|
||||
|
||||
void setCountry(std::string country);
|
||||
void setDetectRegion(bool detectRegion);
|
||||
void setTopN(int topn);
|
||||
void setDefaultRegion(std::string region);
|
||||
@@ -116,6 +117,8 @@ namespace alpr
|
||||
bool detectRegion;
|
||||
std::string defaultRegion;
|
||||
|
||||
void loadRecognizers();
|
||||
|
||||
cv::Mat getCharacterTransformMatrix(PipelineData* pipeline_data );
|
||||
std::vector<AlprCoordinate> getCharacterPoints(cv::Rect char_rect, cv::Mat transmtx);
|
||||
std::vector<cv::Rect> convertRects(std::vector<AlprRegionOfInterest> regionsOfInterest);
|
||||
|
@@ -111,36 +111,45 @@ namespace alpr
|
||||
return;
|
||||
}
|
||||
|
||||
this->loaded_countries = this->parse_country_string(country);
|
||||
|
||||
if (this->loaded_countries.size() == 0)
|
||||
{
|
||||
std::cerr << "--(!) Country not specified." << endl;
|
||||
return;
|
||||
}
|
||||
for (unsigned int i = 0; i < loaded_countries.size(); i++)
|
||||
{
|
||||
bool country_loaded = setCountry(this->loaded_countries[i]);
|
||||
if (!country_loaded)
|
||||
{
|
||||
return;
|
||||
}
|
||||
}
|
||||
setCountry(this->loaded_countries[0]);
|
||||
|
||||
bool countries_loaded = load_countries(country);
|
||||
|
||||
if (this->debugGeneral)
|
||||
{
|
||||
std::cout << debug_message << endl;
|
||||
}
|
||||
|
||||
this->loaded = true;
|
||||
this->loaded = countries_loaded;
|
||||
}
|
||||
|
||||
Config::~Config()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
bool Config::load_countries(const std::string countries) {
|
||||
|
||||
this->loaded_countries = this->parse_country_string(countries);
|
||||
|
||||
if (this->loaded_countries.size() == 0)
|
||||
{
|
||||
std::cerr << "--(!) Country not specified." << endl;
|
||||
return false;
|
||||
}
|
||||
for (unsigned int i = 0; i < loaded_countries.size(); i++)
|
||||
{
|
||||
bool country_loaded = setCountry(this->loaded_countries[i]);
|
||||
if (!country_loaded)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
setCountry(this->loaded_countries[0]);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
void Config::loadCommonValues(string configFile)
|
||||
{
|
||||
|
||||
@@ -344,10 +353,22 @@ namespace alpr
|
||||
return parsed_countries;
|
||||
}
|
||||
|
||||
bool Config::country_is_loaded(std::string country) {
|
||||
for (uint32_t i = 0; i < loaded_countries.size(); i++)
|
||||
{
|
||||
if (loaded_countries[i] == country)
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
bool Config::setCountry(std::string country)
|
||||
{
|
||||
this->country = country;
|
||||
|
||||
|
||||
|
||||
std::string country_config_file = this->runtimeBaseDir + "/config/" + country + ".conf";
|
||||
if (fileExists(country_config_file.c_str()) == false)
|
||||
{
|
||||
@@ -363,6 +384,9 @@ namespace alpr
|
||||
return false;
|
||||
}
|
||||
|
||||
if (!country_is_loaded(country))
|
||||
this->loaded_countries.push_back(country);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@@ -40,6 +40,8 @@ namespace alpr
|
||||
Config(const std::string country, const std::string config_file = "", const std::string runtime_dir = "");
|
||||
virtual ~Config();
|
||||
|
||||
bool load_countries(const std::string countries);
|
||||
|
||||
bool loaded;
|
||||
|
||||
std::string config_file_path;
|
||||
@@ -153,6 +155,7 @@ namespace alpr
|
||||
float stateIdImagePercent;
|
||||
|
||||
std::vector<std::string> parse_country_string(std::string countries);
|
||||
bool country_is_loaded(std::string country);
|
||||
|
||||
void loadCommonValues(std::string configFile);
|
||||
void loadCountryValues(std::string configFile, std::string country);
|
||||
|
Reference in New Issue
Block a user