1

ここでlibanprを扱った人はいますか? 自動車両プレート認識用のライブラリです。コンパイルしようとしましたが、解決できないエラーがたくさんありました。ドキュメントが 1 ページも見つかりません。誰かが助けることができますか?

編集:

解決。

Linux ではコンパイルできませんでしたが、Windows ではコンパイルできました。今私の問題は、このライブラリに関するドキュメントも議論もないことです!. 次のコードを試しましたが、実行するとクラッシュし、(ステップバイステップで) デバッグするとコードは機能しますが、この方法で結果を取得することはできません。クラスや関数について何も知らないので、コードを操作することはできません!!

解決策を見つけるために私を共有することに興味がある人はいますか??

#include "../source/AvcodecImgSrc.h"
#include "../locate/CarLocate.h"
#include "../plate/PlateCut.h"
#include "../ocr/PlateOcr.h"
#include "../exception/Exception.h"

static void show(const std::vector<OcrData>& plates) {
for (int i=0;i<plates.size();i++)
printf("%s\n", plates[i].getPlate().c_str());

}

int main(int argc, const char* argv[]) {
      try {
         AvcodecImgSrc src(argv[1], 400, 3450);
         CarLocate car(2048/4, 1536/4, 8, 5);
         PlateCut plate;
    PlateOcr ocr;
    while (src.hasNext()) {
      NTCImg img = src.next();
      int w = img.dimx();
      int h = img.dimy();
      int w2 = w/2;
      int h2 = h/2;
      NTCImg img2 = img.getScale(w2, h2);
      int w4 = w/4;
      int h4 = h/4;
      NTCImg img4g = img.getScaleG(w4, h4);
      std::vector<CarData> cars = car.locate(img4g);
      for (int i=0;i<cars.size();i++) {
        printf("CAR[%dx%d]!\n", cars[i].getRect().getWidth(), cars[i].getRect().getHeight());
      }
      std::vector<PlateData> plates = plate.cut(img2, CarData::scale2(cars));
      for (int i=0;i<plates.size();i++) {
        printf("PLATE[%dx%d]!\n", plates[i].getRect().getWidth(), plates[i].getRect().getHeight());
      }
      //show(ocr.run(plate.cut(cars)));
    }
  } catch (const Exception& ex) {
    printf("Exception: %s\n", ex.getMsg().c_str());
  } catch (const Err& err) {
    printf("Err!\n");
  }
}
4

2 に答える 2