Ubuntu16.04下配置Basler工業(yè)相機(jī)(使用QtCreator)

Basler工業(yè)相機(jī)網(wǎng)上資料少渊抽,寫的博客更少,當(dāng)時(shí)為了把這個(gè)Basler相機(jī)用起來零院,不知道耗費(fèi)了我多少心血溉跃。
查閱了Basler的官方文檔,還有各種語焉不詳?shù)牟┛兔欧啵K于能夠在Linux下調(diào)用Basler相機(jī)了喊积。
所以我決定寫一篇非常詳細(xì)的博客,好讓后來者少踩些坑玄妈。


我的第一個(gè)工業(yè)相機(jī)乾吻,據(jù)說這玩意要近萬塊錢

其實(shí)Linux下配置Basler攝像頭時(shí)和配置OpenCV時(shí)相差不大。
先去 官網(wǎng)下載對(duì)應(yīng)的安裝包
https://www.baslerweb.com/cn/sales-support/downloads/software-downloads/#type=pylonsoftware;version=all;os=windows
根據(jù)自己的系統(tǒng)選擇x86或者x86_64(即x64)版本拟蜻。

我的相機(jī)型號(hào)為acA1920-40gc绎签。

下載好后,對(duì)壓縮包進(jìn)行解壓操作酝锅,可以選擇解壓文件到自己選擇的目錄诡必,此處我們選擇默認(rèn)當(dāng)前目錄:

$ tar -xzvf  pylon-5.0.***.tar.gz

解壓文件后,打開文件搔扁,里邊還有一個(gè)壓縮包爸舒,此壓縮包即為安裝文件,解壓此文件到/opt目錄下:

$ sudo tar -C /opt -xzvf pylon***armhf.tar.gz

安裝完畢后就開始在qtcreator中進(jìn)行配置稿蹲,以便在Qtcreator中調(diào)用該相機(jī)扭勉。
1、首先打開Qtcreator苛聘,如下圖所示涂炎,創(chuàng)建控制臺(tái)項(xiàng)目或者空項(xiàng)目


————————————————————————————
2忠聚、然后打開.pro文件,在其中配置Basler相機(jī):

先找到INCLUDEPATH的路徑:
(1)點(diǎn)開“計(jì)算機(jī)”唱捣,點(diǎn)開文件夾“opt”



(2)接著打開pylon5文件夾



那么INCLUDEPATH 的內(nèi)容為:
INCLUDEPATH += /opt/pylon5/include \
/opt/pylon5/include/pylon

例子:(下圖中我是把OpenCV和Basler一起配置)


——————————————————————————————————

3两蟀、寫好了INCLUDEPATH,再來寫LIBS震缭。
LIBS(我目前知道的)有2種寫法:
第一種是直接寫出路徑來:

例子:
LIBS += /usr/local/lib/libopencv_calib3d.so \
/usr/local/lib/libopencv_calib3d.so.3.2 \
/usr/local/lib/libopencv_calib3d.so.3.2.0 \
/usr/local/lib/libopencv_core.so \

第二種方法是先寫一個(gè)總的赂毯,再寫分的:

例子:
LIBS +=-L/opt/pylon5/lib64 \
-lbxapi-5.0.11 \
-lbxapi \
-lFirmwareUpdate_gcc_v3_0_Basler_pylon_v5_0 \
-lGCBase_gcc_v3_0_Basler_pylon_v5_0 \
-lGenApi_gcc_v3_0_Basler_pylon_v5_0 \
-lgxapi-5.0.11 \

這2種寫法都是一樣的,是通用的蛀序。

先找到LIB所在的路徑為 opt / pylon5 / lib64



可以看到里面有很多后綴為.so的文件欢瞪,把這些文件的路徑寫到.pro文件中就行了。



這里我把我總的.pro文件內(nèi)容貼出來徐裸,可供參考:
(我這里面同時(shí)配置了OpenCV和Basler,注意我的Basler的版本為5.0.11)
TEMPLATE = app
CONFIG += console c++11
CONFIG -= app_bundle
CONFIG -= qt

SOURCES += main.cpp

INCLUDEPATH += /usr/local/include \
/usr/local/include/opencv \
/usr/local/include/opencv2 \
/opt/pylon5/include \
/opt/pylon5/include/pylon

LIBS += /usr/local/lib/libopencv_calib3d.so \
/usr/local/lib/libopencv_calib3d.so.3.2 \
/usr/local/lib/libopencv_calib3d.so.3.2.0 \
/usr/local/lib/libopencv_core.so \
/usr/local/lib/libopencv_core.so.3.2 \
/usr/local/lib/libopencv_core.so.3.2.0 \
/usr/local/lib/libopencv_features2d.so \
/usr/local/lib/libopencv_features2d.so.3.2 \
/usr/local/lib/libopencv_features2d.so.3.2.0 \
/usr/local/lib/libopencv_flann.so \
/usr/local/lib/libopencv_flann.so.3.2 \
/usr/local/lib/libopencv_flann.so.3.2.0 \
/usr/local/lib/libopencv_highgui.so \
/usr/local/lib/libopencv_highgui.so.3.2 \
/usr/local/lib/libopencv_highgui.so.3.2.0 \
/usr/local/lib/libopencv_imgcodecs.so \
/usr/local/lib/libopencv_imgcodecs.so.3.2 \
/usr/local/lib/libopencv_imgcodecs.so.3.2.0 \
/usr/local/lib/libopencv_imgproc.so \
/usr/local/lib/libopencv_imgproc.so.3.2 \
/usr/local/lib/libopencv_imgproc.so.3.2.0 \
/usr/local/lib/libopencv_ml.so \
/usr/local/lib/libopencv_ml.so.3.2 \
/usr/local/lib/libopencv_ml.so.3.2.0 \
/usr/local/lib/libopencv_objdetect.so \
/usr/local/lib/libopencv_objdetect.so.3.2 \
/usr/local/lib/libopencv_objdetect.so.3.2.0 \
/usr/local/lib/libopencv_photo.so \
/usr/local/lib/libopencv_photo.so.3.2 \
/usr/local/lib/libopencv_photo.so.3.2.0 \
/usr/local/lib/libopencv_shape.so \
/usr/local/lib/libopencv_shape.so.3.2 \
/usr/local/lib/libopencv_shape.so.3.2.0 \
/usr/local/lib/libopencv_stitching.so \
/usr/local/lib/libopencv_stitching.so.3.2 \
/usr/local/lib/libopencv_stitching.so.3.2.0 \
/usr/local/lib/libopencv_superres.so \
/usr/local/lib/libopencv_superres.so.3.2 \
/usr/local/lib/libopencv_superres.so.3.2.0 \
/usr/local/lib/libopencv_video.so \
/usr/local/lib/libopencv_video.so.3.2 \
/usr/local/lib/libopencv_video.so.3.2.0 \
/usr/local/lib/libopencv_videoio.so \
/usr/local/lib/libopencv_videoio.so.3.2 \
/usr/local/lib/libopencv_videoio.so.3.2.0 \
/usr/local/lib/libopencv_videostab.so \
/usr/local/lib/libopencv_videostab.so.3.2 \
/usr/local/lib/libopencv_videostab.so.3.2.0 \
/usr/local/lib/libopencv_viz.so \
/usr/local/lib/libopencv_viz.so.3.2 \
/usr/local/lib/libopencv_viz.so.3.2.0 \
-L/opt/pylon5/lib64 \
-lbxapi-5.0.11 \
-lbxapi \
-lFirmwareUpdate_gcc_v3_0_Basler_pylon_v5_0 \
-lGCBase_gcc_v3_0_Basler_pylon_v5_0 \
-lGenApi_gcc_v3_0_Basler_pylon_v5_0 \
-lgxapi-5.0.11 \
-lgxapi \
-llog4cpp_gcc_v3_0_Basler_pylon_v5_0 \
-lLog_gcc_v3_0_Basler_pylon_v5_0 \
-lMathParser_gcc_v3_0_Basler_pylon_v5_0 \
-lNodeMapData_gcc_v3_0_Basler_pylon_v5_0 \
-lpylonbase-5.0.11 \
-lpylonbase \
-lpylonc-5.0.11 \
-lpylonc \
-lpylon_TL_bcon-5.0.11 \
-lpylon_TL_bcon \
-lpylon_TL_camemu-5.0.11 \
-lpylon_TL_camemu \
-lpylon_TL_gige-5.0.11 \
-lpylon_TL_gige \
-lpylon_TL_usb-5.0.11 \
-lpylon_TL_usb \
-lpylonutility-5.0.11 \
-lpylonutility \
-luxapi-5.0.11 \
-luxapi \
-lXmlParser_gcc_v3_0_Basler_pylon_v5_0 \

4啸盏、這樣配置好了.pro文件重贺,就能開始寫程序了。
在Linux中調(diào)用Basler攝像頭回懦,需要一段比較長(zhǎng)的代碼气笙,代碼如下:

//定義是否保存圖片
#define saveImages 0
//定義是否記錄視頻
#define recordVideo 0

// 加載OpenCV API
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/video/video.hpp>
#include<opencv2/opencv.hpp>

//加載PYLON API.
#include <pylon/PylonIncludes.h>

#include <pylon/gige/BaslerGigEInstantCamera.h> //自動(dòng)調(diào)節(jié)

//加載C++ 頭文件
#include<iostream>


//命名空間.
using namespace Pylon;
using namespace cv;
using namespace std;

using namespace Basler_GigECameraParams; //自動(dòng)調(diào)節(jié)

typedef Pylon::CBaslerGigEInstantCamera Camera_t; //自動(dòng)調(diào)節(jié)
typedef Camera_t::GrabResultPtr_t GrabResultPtr_t; //自動(dòng)調(diào)節(jié)


static const uint32_t c_countOfImagesToGrab = 2000;

int saveImage_flag=0; //保存一張圖片

int main()
{
                 cout<<"000"<<endl;
    //Pylon自動(dòng)初始化和終止
    Pylon::PylonAutoInitTerm autoInitTerm;

    try
    {
               cout<<"0"<<endl;

        // 原程序?qū)amera的定義
        //CInstantCamera camera(CTlFactory::GetInstance().CreateFirstDevice());

       CDeviceInfo info;
       info.SetDeviceClass( Camera_t::DeviceClass());

       // Create an instant camera object with the first found camera device that matches the specified device class.
       Camera_t camera( CTlFactory::GetInstance().CreateFirstDevice( info));


              cout<<"1"<<endl;

        // 打印相機(jī)的名稱
        std::cout << "Using device " << camera.GetDeviceInfo().GetModelName() << endl;
                cout<<"2"<<endl;

        //獲取相機(jī)節(jié)點(diǎn)映射以獲得相機(jī)參數(shù)
        GenApi::INodeMap& nodemap = camera.GetNodeMap();
                            cout<<"3"<<endl;

        //打開相機(jī)
        camera.Open();
                cout<<"4"<<endl;


        //獲取相機(jī)成像寬度和高度
        GenApi::CIntegerPtr width = nodemap.GetNode("Width");
        GenApi::CIntegerPtr height = nodemap.GetNode("Height");
                            cout<<"5"<<endl;

        //設(shè)置相機(jī)最大緩沖區(qū),默認(rèn)為10
        camera.MaxNumBuffer = 5;
        // 新建pylon ImageFormatConverter對(duì)象.
        CImageFormatConverter formatConverter;
                        cout<<"6"<<endl;

        //確定輸出像素格式
        formatConverter.OutputPixelFormat = PixelType_BGR8packed;
        // 創(chuàng)建一個(gè)Pylonlmage后續(xù)將用來創(chuàng)建OpenCV images
        CPylonImage pylonImage;
                    cout<<"7"<<endl;

        //聲明一個(gè)整形變量用來計(jì)數(shù)抓取的圖像,以及創(chuàng)建文件名索引
        int grabbedlmages = 0;

        // 新建一個(gè)OpenCV video creator對(duì)象.
        VideoWriter cvVideoCreator;
        //新建一個(gè)OpenCV image對(duì)象.

        Mat openCvImage;
        // 視頻文件名
                    cout<<"8"<<endl;

        std::string videoFileName = "openCvVideo.avi";
        // 定義視頻幀大小
        cv::Size frameSize = Size((int)width->GetValue(), (int)height->GetValue());
                        cout<<"9"<<endl;
        cout<<"Width: "<<frameSize.width<<endl;
        cout<<"Height: "<<frameSize.height<<endl;


        //設(shè)置視頻編碼類型和幀率怯晕,有三種選擇
        // 幀率必須小于等于相機(jī)成像幀率!!!!
        cvVideoCreator.open(videoFileName, CV_FOURCC('D', 'I', 'V','X'), 10, frameSize, true);
        //cvVideoCreator.open(videoFileName, CV_F0URCC('M','P',,4','2’), 20, frameSize, true);
        //cvVideoCreator.open(videoFileName, CV_FOURCC('M', '3', 'P', 'G'), 20, frameSize, true);
            cout<<"10"<<endl;

        // 開始抓取c_countOfImagesToGrab images.
        //相機(jī)默認(rèn)設(shè)置連續(xù)抓取模式
        camera.StartGrabbing(-1, GrabStrategy_LatestImageOnly); //c_countOfImagesToGrab

        //抓取結(jié)果數(shù)據(jù)指針
        CGrabResultPtr ptrGrabResult;

        // 當(dāng)c_countOfImagesToGrab images獲取恢復(fù)成功時(shí)潜圃,Camera.StopGrabbing()
        //被RetrieveResult()方法自動(dòng)調(diào)用停止抓取


        cout << "Initial Gain = " << camera.GainRaw.GetValue() << endl;


        cout << "Initial exposure time = ";
        cout << camera.ExposureTimeAbs.GetValue() << " us" << endl;


        cout << "Initial balance ratio: ";
        camera.BalanceRatioSelector.SetValue(BalanceRatioSelector_Red);
            cout << "R = " << camera.BalanceRatioAbs.GetValue() << "   ";
        camera.BalanceRatioSelector.SetValue(BalanceRatioSelector_Green);
            cout << "G = " << camera.BalanceRatioAbs.GetValue() << "   ";
        camera.BalanceRatioSelector.SetValue(BalanceRatioSelector_Blue);
            cout << "B = " << camera.BalanceRatioAbs.GetValue() << endl;


        while (camera.IsGrabbing())
        {
            // 等待接收和恢復(fù)圖像,超時(shí)時(shí)間設(shè)置為5000 ms.
            camera.RetrieveResult(5000, ptrGrabResult, TimeoutHandling_ThrowException);

            //如果圖像抓取成功
            if (ptrGrabResult->GrabSucceeded())
            {
                // 獲取圖像數(shù)據(jù)
             //   cout <<"SizeX: "<<ptrGrabResult->GetWidth()<<endl;
             //   cout <<"SizeY: "<<ptrGrabResult->GetHeight()<<endl;


                //將抓取的緩沖數(shù)據(jù)轉(zhuǎn)化成pylon image.
                formatConverter.Convert(pylonImage, ptrGrabResult);


                // 將 pylon image轉(zhuǎn)成OpenCV image.
                openCvImage = cv::Mat(ptrGrabResult->GetHeight(), ptrGrabResult->GetWidth(), CV_8UC3, (uint8_t *) pylonImage.GetBuffer());



                //如果需要保存圖片
                if (saveImages)
                {
                   std::ostringstream s;
                    // 按索引定義文件名存儲(chǔ)圖片
                   s << "image_" << grabbedlmages << ".jpg";
                   std::string imageName(s.str());
                    //保存OpenCV image.
                   imwrite(imageName, openCvImage);
                   grabbedlmages++;
                }

                //如果需要記錄視頻
                if (recordVideo)
                {
                    cvVideoCreator.write(openCvImage);
                }


                //新建OpenCV display window.
                namedWindow("OpenCV Display Window", CV_WINDOW_NORMAL); // other options: CV_AUTOSIZE, CV_FREERATIO
                //顯示及時(shí)影像.
                  if(!openCvImage.data)
                  {
                      cout<<"opencvImage fail"<<endl;
                      continue;
                  }

                imshow("OpenCV Display Window", openCvImage);

                if(saveImage_flag==0) //只保存一張圖片
                {
                    imwrite("/home/fsac/2.jpg",openCvImage);
                    saveImage_flag=1;
                }


                // Define a timeout for customer's input in
                // '0' means indefinite, i.e. the next image will be displayed after closing the window.
                // '1' means live stream

                waitKey(10);

            }
            else
            {
                cout<<"圖像讀取失敗,即ptrGrabResult->GrabSucceeded()未成功"<<endl;
                continue;
            }
        }

        if(!camera.IsGrabbing())
            cout<<"camera.IsGrabbing() is failed"<<endl;


    }
    catch (GenICam::GenericException &e)
    {
        // Error handling.
        cerr << "An exception occurred." << endl
            << e.GetDescription() << endl;
    }
    return 0;
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末舟茶,一起剝皮案震驚了整個(gè)濱河市谭期,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌吧凉,老刑警劉巖隧出,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異阀捅,居然都是意外死亡胀瞪,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門饲鄙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來凄诞,“玉大人,你說我怎么就攤上這事忍级》” “怎么了?”我有些...
    開封第一講書人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵颤练,是天一觀的道長(zhǎng)既忆。 經(jīng)常有香客問我驱负,道長(zhǎng),這世上最難降的妖魔是什么患雇? 我笑而不...
    開封第一講書人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任跃脊,我火速辦了婚禮,結(jié)果婚禮上苛吱,老公的妹妹穿的比我還像新娘酪术。我一直安慰自己,他們只是感情好翠储,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開白布绘雁。 她就那樣靜靜地躺著,像睡著了一般援所。 火紅的嫁衣襯著肌膚如雪庐舟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,475評(píng)論 1 312
  • 那天住拭,我揣著相機(jī)與錄音挪略,去河邊找鬼。 笑死滔岳,一個(gè)胖子當(dāng)著我的面吹牛杠娱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播谱煤,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼摊求,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了刘离?” 一聲冷哼從身側(cè)響起室叉,我...
    開封第一講書人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎寥闪,沒想到半個(gè)月后太惠,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疲憋,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年凿渊,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缚柳。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡埃脏,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出秋忙,到底是詐尸還是另有隱情彩掐,我是刑警寧澤,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布灰追,位于F島的核電站堵幽,受9級(jí)特大地震影響狗超,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜朴下,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一努咐、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧殴胧,春花似錦渗稍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至灸姊,卻和暖如春拱燃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背力惯。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工扼雏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人夯膀。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像苍蔬,于是被迫代替她去往敵國(guó)和親诱建。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容