Russian Qt Forum
Март 28, 2024, 23:26 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: OpenCV 3.2 и Qt: проект падает до вызова main  (Прочитано 15184 раз)
lumer
Гость
« : Апрель 10, 2018, 16:25 »

Здравствуйте.

Собрал OpenCV 3.2.0 с помощью mingw установленного qt (из папки с qt).
Сначала прогнал через CMake.

Хочу скомпилировать пример с сайта https://docs.opencv.org/3.0-beta/doc/tutorials/highgui/raster-gdal/raster_io_gdal.html

Подключаю библиотеки правой кнопкой мыши в .pro файле

Код:
win32: LIBS += -L$$PWD/lib/OpenCV320/x86/mingw/lib/ -llibopencv_core320.dll

INCLUDEPATH += $$PWD/lib/OpenCV320/include/
DEPENDPATH += $$PWD/lib/OpenCV320/include/

win32: LIBS += -L$$PWD/lib/OpenCV320/x86/mingw/lib/ -llibopencv_highgui320.dll

INCLUDEPATH += $$PWD/lib/OpenCV320/include/
DEPENDPATH += $$PWD/lib/OpenCV320/include/

win32: LIBS += -L$$PWD/lib/OpenCV320/x86/mingw/lib/ -llibopencv_imgcodecs320.dll

INCLUDEPATH += $$PWD/lib/OpenCV320/include/
DEPENDPATH += $$PWD/lib/OpenCV320/include/

win32: LIBS += -L$$PWD/lib/OpenCV320/x86/mingw/lib/ -llibopencv_imgproc320.dll

INCLUDEPATH += $$PWD/lib/OpenCV320/include/
DEPENDPATH += $$PWD/lib/OpenCV320/include/

win32: LIBS += -L$$PWD/lib/OpenCV320/x86/mingw/lib/ -llibopencv_features2d320.dll

INCLUDEPATH += $$PWD/lib/OpenCV320/include/
DEPENDPATH += $$PWD/lib/OpenCV320/include/

win32: LIBS += -L$$PWD/lib/OpenCV320/x86/mingw/lib/ -llibopencv_calib3d320.dll

INCLUDEPATH += $$PWD/lib/OpenCV320/include/
DEPENDPATH += $$PWD/lib/OpenCV320/include/

Программа вылетает до вызова main с ошибкой during startup program exited with code 0xc0000135

Библиотеки закидывал и в папку с проектом и пытался подключить из внешней папки (например D:\OpenCV\build) но ошибка все равно остается.

Подскажи пожалуйста, в чем проблема ? Не правильно собранные библиотеки ?

Код программы (он же на сайте):
Код:
/// OpenCV Headers
#include "opencv2/core/core.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"

/// C++ Standard Libraries
#include <cmath>
#include <iostream>
#include <stdexcept>
#include <vector>

using namespace std;


/// define the corner points
///    Note that GDAL can natively determine this
cv::Point2d tl( -122.441017, 37.815664 );
cv::Point2d tr( -122.370919, 37.815311 );
cv::Point2d bl( -122.441533, 37.747167 );
cv::Point2d br( -122.3715,   37.746814 );

/// determine dem corners
cv::Point2d dem_bl( -122.0, 38);
cv::Point2d dem_tr( -123.0, 37);

/// range of the heat map colors
std::vector<std::pair<cv::Vec3b,double> > color_range;


/// List of all function prototypes
cv::Point2d lerp( const cv::Point2d&, const cv::Point2d&, const double& );

cv::Vec3b get_dem_color( const double& );

cv::Point2d world2dem( const cv::Point2d&, const cv::Size&);

cv::Point2d pixel2world( const int&, const int&, const cv::Size& );

void add_color( cv::Vec3b& pix, const uchar& b, const uchar& g, const uchar& r );



/**
 * Linear Interpolation
 * p1 - Point 1
 * p2 - Point 2
 * t  - Ratio from Point 1 to Point 2
*/
cv::Point2d lerp( cv::Point2d const& p1, cv::Point2d const& p2, const double& t ){
    return cv::Point2d( ((1-t)*p1.x) + (t*p2.x),
                        ((1-t)*p1.y) + (t*p2.y));
}

/**
 * Interpolate Colors
*/
template <typename DATATYPE, int N>
cv::Vec<DATATYPE,N> lerp( cv::Vec<DATATYPE,N> const& minColor,
                          cv::Vec<DATATYPE,N> const& maxColor,
                          double const& t ){

    cv::Vec<DATATYPE,N> output;
    for( int i=0; i<N; i++ ){
        output[i] = (uchar)(((1-t)*minColor[i]) + (t * maxColor[i]));
    }
    return output;
}

/**
 * Compute the dem color
*/
cv::Vec3b get_dem_color( const double& elevation ){

    // if the elevation is below the minimum, return the minimum
    if( elevation < color_range[0].second ){
        return color_range[0].first;
    }
    // if the elevation is above the maximum, return the maximum
    if( elevation > color_range.back().second ){
        return color_range.back().first;
    }

    // otherwise, find the proper starting index
    int idx=0;
    double t = 0;
    for( int x=0; x<(int)(color_range.size()-1); x++ ){

        // if the current elevation is below the next item, then use the current
        // two colors as our range
        if( elevation < color_range[x+1].second ){
            idx=x;
            t = (color_range[x+1].second - elevation)/
                    (color_range[x+1].second - color_range[x].second);

            break;
        }
    }

    // interpolate the color
    return lerp( color_range[idx].first, color_range[idx+1].first, t);
}

/**
 * Given a pixel coordinate and the size of the input image, compute the pixel location
 * on the DEM image.
*/
cv::Point2d world2dem( cv::Point2d const& coordinate, const cv::Size& dem_size   ){


    // relate this to the dem points
    // ASSUMING THAT DEM DATA IS ORTHORECTIFIED
    double demRatioX = ((dem_tr.x - coordinate.x)/(dem_tr.x - dem_bl.x));
    double demRatioY = 1-((dem_tr.y - coordinate.y)/(dem_tr.y - dem_bl.y));

    cv::Point2d output;
    output.x = demRatioX * dem_size.width;
    output.y = demRatioY * dem_size.height;

    return output;
}

/**
 * Convert a pixel coordinate to world coordinates
*/
cv::Point2d pixel2world( const int& x, const int& y, const cv::Size& size ){

    // compute the ratio of the pixel location to its dimension
    double rx = (double)x / size.width;
    double ry = (double)y / size.height;

    // compute LERP of each coordinate
    cv::Point2d rightSide = lerp(tr, br, ry);
    cv::Point2d leftSide  = lerp(tl, bl, ry);

    // compute the actual Lat/Lon coordinate of the interpolated coordinate
    return lerp( leftSide, rightSide, rx );
}

/**
 * Add color to a specific pixel color value
*/
void add_color( cv::Vec3b& pix, const uchar& b, const uchar& g, const uchar& r ){

    if( pix[0] + b < 255 && pix[0] + b >= 0 ){ pix[0] += b; }
    if( pix[1] + g < 255 && pix[1] + g >= 0 ){ pix[1] += g; }
    if( pix[2] + r < 255 && pix[2] + r >= 0 ){ pix[2] += r; }
}


/**
 * Main Function
*/

int main(int argc, char *argv[])
{
    /**
         * Check input arguments
        */
    if( argc < 3 ){
        cout << "usage: " << argv[0] << " <image> <dem>" << endl;
        return 1;
    }

    /// load the image (note that we don't have the projection information.  You will
    /// need to load that yourself or use the full GDAL driver.  The values are pre-defined
    /// at the top of this file
    cv::Mat image = cv::imread(argv[1], cv::IMREAD_LOAD_GDAL | cv::IMREAD_COLOR );

    /// load the dem model
    cv::Mat dem = cv::imread(argv[2], cv::IMREAD_LOAD_GDAL | cv::IMREAD_ANYDEPTH );

    /// create our output products
    cv::Mat output_dem(   image.size(), CV_8UC3 );
    cv::Mat output_dem_flood(   image.size(), CV_8UC3 );

    /// for sanity sake, make sure GDAL Loads it as a signed short
    if( dem.type() != CV_16SC1 ){ throw std::runtime_error("DEM image type must be CV_16SC1"); }

    /// define the color range to create our output DEM heat map
    //  Pair format ( Color, elevation );  Push from low to high
    //  Note:  This would be perfect for a configuration file, but is here for a working demo.
    color_range.push_back( std::pair<cv::Vec3b,double>(cv::Vec3b( 188, 154,  46),   -1));
    color_range.push_back( std::pair<cv::Vec3b,double>(cv::Vec3b( 110, 220, 110), 0.25));
    color_range.push_back( std::pair<cv::Vec3b,double>(cv::Vec3b( 150, 250, 230),   20));
    color_range.push_back( std::pair<cv::Vec3b,double>(cv::Vec3b( 160, 220, 200),   75));
    color_range.push_back( std::pair<cv::Vec3b,double>(cv::Vec3b( 220, 190, 170),  100));
    color_range.push_back( std::pair<cv::Vec3b,double>(cv::Vec3b( 250, 180, 140),  200));

    // define a minimum elevation
    double minElevation = -10;

    // iterate over each pixel in the image, computing the dem point
    for( int y=0; y<image.rows; y++ ){
        for( int x=0; x<image.cols; x++ ){

            // convert the pixel coordinate to lat/lon coordinates
            cv::Point2d coordinate = pixel2world( x, y, image.size() );

            // compute the dem image pixel coordinate from lat/lon
            cv::Point2d dem_coordinate = world2dem( coordinate, dem.size() );

            // extract the elevation
            double dz;
            if( dem_coordinate.x >=    0    && dem_coordinate.y >=    0     &&
                    dem_coordinate.x < dem.cols && dem_coordinate.y < dem.rows ){
                dz = dem.at<short>(dem_coordinate);
            }else{
                dz = minElevation;
            }

            // write the pixel value to the file
            output_dem_flood.at<cv::Vec3b>(y,x) = image.at<cv::Vec3b>(y,x);

            // compute the color for the heat map output
            cv::Vec3b actualColor = get_dem_color(dz);
            output_dem.at<cv::Vec3b>(y,x) = actualColor;

            // show effect of a 10 meter increase in ocean levels
            if( dz < 10 ){
                add_color( output_dem_flood.at<cv::Vec3b>(y,x), 90, 0, 0 );
            }
            // show effect of a 50 meter increase in ocean levels
            else if( dz < 50 ){
                add_color( output_dem_flood.at<cv::Vec3b>(y,x), 0, 90, 0 );
            }
            // show effect of a 100 meter increase in ocean levels
            else if( dz < 100 ){
                add_color( output_dem_flood.at<cv::Vec3b>(y,x), 0, 0, 90 );
            }

        }}

    // print our heat map
    cv::imwrite( "heat-map.jpg"   ,  output_dem );

    // print the flooding effect image
    cv::imwrite( "flooded.jpg",  output_dem_flood);

    return 0;
}
Записан
Apktyc
Самовар
**
Offline Offline

Сообщений: 129


Просмотр профиля
« Ответ #1 : Апрель 10, 2018, 16:44 »

during startup program exited with code 0xc0000135

Это когда очень хочется dll, а их нет. Положите необходимые библиотеки (помогает dependency walker) рядом с приложением (учитывая возможную структуру каталогов plugins и т.д.).
« Последнее редактирование: Апрель 10, 2018, 17:13 от Apktyc » Записан
lumer
Гость
« Ответ #2 : Апрель 10, 2018, 16:59 »

during startup program exited with code 0xc0000135

Это когда очень хочется dll, а их нет. Необходимо положить необходимые библиотеки (помогает dependency walker) рядом с приложением (учитывая возможную структуру каталогов plugins и т.д.).

Так лежат же. И в папке с проектом и в папке с дебагом (которая после компиляции создается). Не помогает.
Записан
Apktyc
Самовар
**
Offline Offline

Сообщений: 129


Просмотр профиля
« Ответ #3 : Апрель 10, 2018, 17:13 »

А dependency walker с Вами согласен?

И чет меня не кисло смущает подключение dll в LIBS  В замешательстве

Код
C++ (Qt)
LIBS += -L$$(PATH_TO_OPENCV_SDK)/x86/mingw/lib \
-lopencv_core320        \
-lopencv_highgui320     \
-lopencv_imgcodecs320   \
-lopencv_imgproc320     \
-lopencv_features2d320  \
-lopencv_calib3d320
Записан
__Heaven__
Джедай : наставник для всех
*******
Offline Offline

Сообщений: 2130



Просмотр профиля
« Ответ #4 : Апрель 11, 2018, 11:16 »

cmake вывод остался от сборки opencv? Подозреваю, что на компе несколько компиляторов и взялся не mingw, отчего бинарная несовместимость примера и библиотек.
Записан
lumer
Гость
« Ответ #5 : Апрель 12, 2018, 14:06 »

А dependency walker с Вами согласен?

И чет меня не кисло смущает подключение dll в LIBS  В замешательстве

Код
C++ (Qt)
LIBS += -L$$(PATH_TO_OPENCV_SDK)/x86/mingw/lib \
-lopencv_core320        \
-lopencv_highgui320     \
-lopencv_imgcodecs320   \
-lopencv_imgproc320     \
-lopencv_features2d320  \
-lopencv_calib3d320

Это у меня ? о_0 Возможно не туда смотрите.
Записан
lumer
Гость
« Ответ #6 : Апрель 12, 2018, 14:17 »

cmake вывод остался от сборки opencv? Подозреваю, что на компе несколько компиляторов и взялся не mingw, отчего бинарная несовместимость примера и библиотек.

Когда была ошибка линковки - там тупанул, собрал библиотеки с помощью mingw 7.1, а у qt стоит mingw 5.7. После этого снес лишние компиляторы, исправил переменную PATH, ошибка линковки исправилась и появилось это. Лог в приложении.

Есть предположение, что библиотеки собраны под релиз, а в qt работаю в дебаге. Но тут проблема - OpenCV не хочет собираться в дебаге, на 40% крашится Грустный


Записан
__Heaven__
Джедай : наставник для всех
*******
Offline Offline

Сообщений: 2130



Просмотр профиля
« Ответ #7 : Апрель 12, 2018, 17:14 »

Цитировать
 GUI:
    QT:                          NO
Смущает в логе. Может нужно донастроить opencv?
Но, наверное, это не должно влиять на вылеты из main...
Записан
Apktyc
Самовар
**
Offline Offline

Сообщений: 129


Просмотр профиля
« Ответ #8 : Апрель 12, 2018, 17:41 »

Это у меня ? о_0 Возможно не туда смотрите.

Это не у вас. Меня в принципе смущает прописывание *.dll в LIBS. Может я и не прав, но линкеру нужны *.lib (сойдут и исходники я полагаю). А *.dll обычно уж в /bin лежат.
« Последнее редактирование: Апрель 12, 2018, 17:44 от Apktyc » Записан
lumer
Гость
« Ответ #9 : Апрель 14, 2018, 14:47 »

Цитировать
 GUI:
    QT:                          NO
Смущает в логе. Может нужно донастроить opencv?
Но, наверное, это не должно влиять на вылеты из main...

Настраивал в cmake под qt, прописывал ему там все пути на то, что он просит - не собралось в mingw
Записан
__Heaven__
Джедай : наставник для всех
*******
Offline Offline

Сообщений: 2130



Просмотр профиля
« Ответ #10 : Апрель 16, 2018, 14:35 »

Написал, почему не собралось?
Записан
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.095 секунд. Запросов: 22.