2

私は、同僚によって書かれた比較的大きな OpenCV ベースのプログラムを編集しています。私が直面している問題は、プログラムが大文字と小文字のキーストロークを区別しないことです (つまり、キーストローク 'd' と 'D' の両方が 0x65 として認識されます)。ソースから直接彼のマシン上の OpenCV ライブラリ。

私は初心者ですが、なぜそのようなことが起こるのか、OpenCV のインストールとどのように関連するのかにも興味があります!

私のマシンにはまだ問題がありますが、openCV の再インストールは試していません。

編集: OS Linux-Ubuntu 12.10 64bit 文字はキーボードからのキーストロークであり、switch ステートメントで使用されます。

    static int process_key(struct cam_segment* cs, int key){
    int res = 0;
    double pdist;
    struct stat sb;
    char fn[4096];
    static int out_id = 0;
    fprintf( stderr, "%d\n", key&0xff );
    switch (key & 0xff) {
    case 'm':
        show_merged = !show_merged;
        res = 1;
        break;
    case '1':
    case '2':
    case '3':
    case '4':
    case '5':
    case '6':
        cam_id = (key & 0xff) - '1';
        res = 1;
        break;
    case 'D':
        ocv_mgrid_set_distortion( cs->mg, 0 );
        res = 1;
        break;
    case 'd':
        ocv_mgrid_set_distortion( cs->mg, 1 );
        res = 1;
        break;
    case 'n':
        res = 1;
        break;
    case 'C':
        init_calibration(cs);
        calibrate_camera_distortion(cs->mg);
        output_calibration_results(cs);
        cs->calib_mode = 1;
        res = 1;

        break;
    case 'c':
        init_calibration(cs);
        fprintf(stderr,"searching.....");
        calibrate_camera_rotation(cs->mg);
        output_calibration_results(cs);
        fprintf(stderr,"e1 %f\n",water_error(cs->mg));
        cs->calib_mode = 1;
        res = 1;
        break;
    case 'M':
        init_calibration(cs);
        fprintf(stderr,"searching pricipal point.....");
        calibrate_camera_center(cs->mg);
        output_calibration_results(cs);
        cs->calib_mode = 1;
        res = 1;
        break;
    case 'a':
        init_calibration(cs);
        int misscnt;
        double e,en;
        en = e = HUGE;
        misscnt = 0;
        for(int i=0;i<20;i++) {
            e = water_error(cs->mg);
            fprintf(stderr,"e1 %f %d \n",e,misscnt);
            calibrate_camera_rotation(cs->mg);
            output_calibration_results(cs);
            en = water_error(cs->mg);
            fprintf(stderr,"en1 %f\n",en);
            if (en >= e)
                misscnt++;
            else
                misscnt = 0;
            if (misscnt > 3)
                break;
            e = water_error(cs->mg);
            fprintf(stderr,"e %f %d\n",e,misscnt);
            calibrate_coupled_focal_length(cs->mg);
            output_calibration_results(cs);
            en = water_error(cs->mg);
            fprintf(stderr,"en %f\n",en);
            if (en >= e)
                misscnt++;
            else
                misscnt = 0;
            if (misscnt > 3)
                break;
            e = water_error(cs->mg);
            if (e > 100) 
                continue;
            fprintf(stderr,"e %f %d\n",e,misscnt);
            calibrate_camera_distortion(cs->mg);
            output_calibration_results(cs);
            en = water_error(cs->mg);
            fprintf(stderr,"en %f\n",en);
            if (en >= e)
                misscnt++;
            else
                misscnt = 0;
            if (misscnt > 3)
                break;
        }
        cs->calib_mode = 1;
        res = 1;
        break;
    case 'p':
        init_calibration(cs);
        calibrate_coupled_focal_length(cs->mg);
        output_calibration_results(cs);
        cs->calib_mode = 1;
        res = 1;
        break;
    case 'F':
        init_calibration(cs);
        calibrate_focal_lengths(cs->mg);
        output_calibration_results(cs);
        cs->calib_mode = 1;
        res = 1;
        break;
    case 't':
        init_calibration(cs);
        calibrate_target(cs->mg);
        output_calibration_results(cs);
        cs->calib_mode = 1;
        res = 1;
        break;
    case 'e':
        sprintf(fn, "%s_%03d.png",cs->inp_prefix, cs->inp_id);
        if (!(input = cvLoadImage(fn, CV_LOAD_IMAGE_COLOR))) {
            fprintf(stderr,"error calc: loading input failed\n");
        } else if (!(ocv_mgrid_set_input(cs->mg, input))) {
            fprintf(stderr,"error calc error 1\n");
        }
        pdist = water_error(cs->mg);
        fprintf(stderr,"watererror: %f\n",pdist);
        break;
    case 'N':
        res = 1;
        cs->inp_id++;
        cerr << "inp_id=" << cs->inp_id << "\n";
        break;
    case 'P':
        res = 1;
        cs->inp_id--;
        cerr << "inp_id=" << cs->inp_id << "\n";
        break;

    case 'z':
        cs->color_mode = OCV_MGRID_CMODE_THETA;
        res = 1;
        break;
    case 'Z':
        cs->color_mode = OCV_MGRID_CMODE_THETA_CHECK;
        res = 1;
        break;
    case 'l':
        cs->draw_legend = !(cs->draw_legend);
        res = 1;
        break;
    case 'x':
        cs->color_mode = OCV_MGRID_CMODE_X;
        res = 1;
        break;
    case 'y':
        cs->color_mode = OCV_MGRID_CMODE_Y;
        res = 1;
        break;
    case 'X':
        cs->color_mode = OCV_MGRID_CMODE_X_CHECK;
        res = 1;
        break;
    case 'Y':
        cs->color_mode = OCV_MGRID_CMODE_Y_CHECK;
        res = 1;
        break;
    case 'o':
        cs->color_mode = OCV_MGRID_CMODE_NONE;
        res = 1;
        break;
    case 's':

        sprintf(fn, "input_%03d.png",out_id);
        while(stat(fn, &sb) != -1) {
            out_id++;
            sprintf(fn, "input_%03d.png",out_id);
        }
        fprintf(stderr,"saving %s \n",fn);
        cvSaveImage(fn,OCV_MGRID_GET_INPUT(cs->mg));
        break;
    case 'r':
        if (projection)
            cvResetImageROI(projection);
        if (merged_projection)
            cvResetImageROI(merged_projection);
        if (merged_grid)
            cvResetImageROI(merged_grid);
        if (output)
            cvResetImageROI(output);
        break;
    case 'R':
        reset_defaults();
        reset_trackbars();
        break;
    case 'f':
        ocv_mgrid_get_best_projection_distance(cs->mg, &pdist);
        fprintf(stderr,"best match %f\n",pdist);
        tb_pdist = (int) pdist;
        cvSetTrackbarPos("proj_distance", "tbars", tb_pdist);
        res = 1;
        break;
    case 'w':
        if (use_camera)
            if (!(ocv_ueye_whitebalance(cs->ueye)))
                return 1;
        break;
    case 'W':
        save_params(cs);
        break;
    default:
        break;
    }
    return res;
}
4

1 に答える 1

0

理由は今のところわかりません!しかし、古い OpenCV ライブラリを削除し、最新バージョンをコンパイルしました。これで、大文字と小文字が区別されます。

新しいバージョンには、必ずしも良いとは限らない微妙な違いがいくつかあります。たとえば、トラック バーの値をクリックしても編集できなくなりました。さらに (@ kebs) キー ストロークを 0xff でマスクする必要があります。

私はずっと奇妙なOpenCVバージョンを持っていたのかもしれません!

于 2013-02-13T14:09:44.567 に答える