2017-02-13 10 views
0

Я хочу загрузить изображение с помощью OpenCV, а затем отобразить его в окне.C++ opencv, отображающий изображение в окне

Я знаю, как загрузить изображение с помощью opencv и как создать окно с помощью win32, но как я могу поместить изображение/циновку из Opencv в окно после этого?

Это, как я загрузить изображение из OpenCV:

#include <opencv2/core/core.hpp> 
#include <opencv2/imgcodecs.hpp> 
#include <opencv2/highgui/highgui.hpp> 

#include <iostream> 
#include <string> 
using namespace cv; 

using namespace std; 

int main(int argc, char** argv) 
{ 

    string imageName("C:/image.jpg"); // by default 
    if (argc > 1) 
    { 
     imageName = argv[1]; 
    } 

    Mat image; 



    image = imread(imageName.c_str(), IMREAD_COLOR); 


    if (image.empty())  
    { 
     cout << "Could not open or find the image" << std::endl; 
     return -1; 
    } 


    namedWindow("Display window", WINDOW_AUTOSIZE); 

    imshow("Display window", image); 


    waitKey(0); 
    return 0; 
} 

EDIT: Причина, я хочу сделать это на самом деле не создать окно во время выполнения, а затем отобразить изображение на нем, а я хочу найти окно с помощью функции FindWindow win32, а затем сделать изображение на что: D

+0

Что не так с 'imshow'? – Miki

+0

Ничего, я просто хотел бы узнать, как отображать изображения из opencv на окне win32 :) – stav

+1

Но но ... это окно win32 ..;) – Miki

ответ

0

Ну ...

не создать новое окно с помощью вызова «namedWindow()».

Затем позвоните по телефону imshow(nameOfExistingWindow, image).

Возможно, он будет работать.

+0

Спасибо, но окно, которое я хочу нарисовать, на самом деле не имеет имени, и все, что у меня есть, это HWND :( – stav

0

Я использую это довольно часто с моими проектами MFC. Если у вас есть только hwnd, а не CWnd, вам, возможно, придется немного поменять.

Это работает как с 8-битным цветом RGB, так и с одноканальным монохромным изображением.

void DrawImage(CWnd *wnd, int width, int height, int bpp, const unsigned char *buffer) 
{ 
    RECT rect; 
    wnd->GetWindowRect(&rect); 
    CDC *dc = wnd->GetDC(); 

    if(bpp == 3) // BGR 
    { 
     BITMAPINFO bmpinfo; 

     memset(&bmpinfo, 0, sizeof(bmpinfo)); 
     bmpinfo.bmiHeader.biSize = sizeof(BITMAPINFOHEADER); 
     bmpinfo.bmiHeader.biBitCount = 24; 
     bmpinfo.bmiHeader.biClrImportant = 0; 
     bmpinfo.bmiHeader.biClrUsed = 0; 
     bmpinfo.bmiHeader.biCompression = BI_RGB; 
     bmpinfo.bmiHeader.biWidth = width; 
     bmpinfo.bmiHeader.biHeight = -height; 
     bmpinfo.bmiHeader.biPlanes = 1; 
     bmpinfo.bmiHeader.biSizeImage = 0; 
     bmpinfo.bmiHeader.biXPelsPerMeter = 100; 
     bmpinfo.bmiHeader.biYPelsPerMeter = 100; 

     ::SetStretchBltMode(dc->GetSafeHdc(), COLORONCOLOR); 
     ::StretchDIBits( dc->GetSafeHdc(), 
         0, 
         0, 
         rect.right - rect.left, 
         rect.bottom - rect.top, 
         0, 
         0, 
         width, 
         height, 
         buffer, 
         &bmpinfo, 
         DIB_RGB_COLORS, 
         SRCCOPY); 
    } 
    else if (bpp == 1) // monochrome. 
    { 
     char bitmapInfoBuf[sizeof(BITMAPINFO) + 4 * 256]; 
     BITMAPINFO* pBmpInfo = (BITMAPINFO*)bitmapInfoBuf; 

     memset(pBmpInfo, 0, sizeof(BITMAPINFO) + 4 * 256); 
     pBmpInfo->bmiHeader.biSize = sizeof(BITMAPINFOHEADER); 
     pBmpInfo->bmiHeader.biWidth = width; 
     pBmpInfo->bmiHeader.biHeight = -height; 
     pBmpInfo->bmiHeader.biCompression = BI_RGB; 
     pBmpInfo->bmiHeader.biPlanes = 1; 
     pBmpInfo->bmiHeader.biBitCount = 8; 

     for(int i = 0; i < 256; i++) 
     { 
      pBmpInfo->bmiColors[i].rgbBlue=i; 
      pBmpInfo->bmiColors[i].rgbGreen=i; 
      pBmpInfo->bmiColors[i].rgbRed=i; 
      pBmpInfo->bmiColors[i].rgbReserved=255; 
     } 

     ::SetStretchBltMode(dc->GetSafeHdc(), COLORONCOLOR); 
     ::StretchDIBits(dc->GetSafeHdc(), 
         0, 
         0, 
         rect.right - rect.left, 
         rect.bottom - rect.top, 
         0, 
         0, 
         width, 
         height, 
         buffer, 
         pBmpInfo, 
         DIB_RGB_COLORS, 
         SRCCOPY); 
    } 

    wnd->ReleaseDC(dc); 
} 

void DrawCVImage(cv::Mat image, CWnd *picture) 
{ 
    if (image.cols % 4 == 0) 
    { 
     DrawImage(picture, 
      image.cols, 
      image.rows, 
      image.channels() == 3 ? 3 : 1, 
      image.data); 
    } 
    else 
    { 
     Mat image2(image.rows, image.cols + (4 - image.cols % 4), image.type()); 
     image2 = 0; 
     image.copyTo(image2(Rect(0, 0, image.cols, image.rows))); 

     DrawImage(picture, 
      image2.cols, 
      image2.rows, 
      image2.channels() == 3 ? 3 : 1, 
      image2.data); 
    } 
}