海康相机连续不断硬触发拍照代码

整了两天终于搞定了,还未优化,投影仪500帧/s投编码图案,触发相机拍照,连续不断拍,实现动态三维重建。代码还未整理,先记录一下


 


#include <stdio.h>

#include <Windows.h>

#include <conio.h>

#include "MvCameraControl.h"

#include <string>

#include "bmpLoader.h"

int nRet = MV_OK;

void* handle = NULL;

int expose1 = 1000;

std::string st2 = "D:\\siat_reconstruction\\projectreconstruction\\1_picture";

unsigned int g_nPayloadSize = 0;

unsigned char*  m_pBufForSaveImage;         // ch:用于保存图像的缓存 | en:Buffer to save image

unsigned int    m_nBufSizeForSaveImage;

// ch:等待按键输入 | en:Wait for key press

void WaitForKeyPress(void)

{

    while(!_kbhit())

    {

        Sleep(10);

    }

    _getch();

}



bool PrintDeviceInfo(MV_CC_DEVICE_INFO* pstMVDevInfo)

{

    if (NULL == pstMVDevInfo)

    {

        printf("The Pointer of pstMVDevInfo is NULL!\n");

        return false;

    }

    if (pstMVDevInfo->nTLayerType == MV_GIGE_DEVICE)

    {

        int nIp1 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0xff000000) >> 24);

        int nIp2 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x00ff0000) >> 16);

        int nIp3 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x0000ff00) >> 8);

        int nIp4 = (pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x000000ff);


        // ch:打印当前相机ip和用户自定义名字 | en:print current ip and user defined name

        printf("CurrentIp: %d.%d.%d.%d\n" , nIp1, nIp2, nIp3, nIp4);

        printf("UserDefinedName: %s\n\n" , pstMVDevInfo->SpecialInfo.stGigEInfo.chUserDefinedName);

    }

    else if (pstMVDevInfo->nTLayerType == MV_USB_DEVICE)

    {

        printf("UserDefinedName: %s\n\n", pstMVDevInfo->SpecialInfo.stUsb3VInfo.chUserDefinedName);

    }

    else

    {

        printf("Not support.\n");

    }


    return true;

}

int i = 0;

void __stdcall ImageCallBackEx(unsigned char * pData, MV_FRAME_OUT_INFO_EX* pFrameInfo, void* pUser)

{    

    if (pFrameInfo)

    {

        printf("Get One Frame: Width[%d], Height[%d], nFrameNum[%d]\n", 

            pFrameInfo->nWidth, pFrameInfo->nHeight, pFrameInfo->nFrameNum);

    }

    // ch:设置对应的相机参数 | en:Set camera parameter

    if (NULL == m_pBufForSaveImage)

    {

        // ch:BMP图片大小:width * height * 3 + 2048(预留BMP头大小)

        // en:// BMP image size: width * height * 3 + 2048 (Reserved BMP header size)

        m_nBufSizeForSaveImage = pFrameInfo->nWidth * pFrameInfo->nHeight * 3 + 2048;

        m_pBufForSaveImage = (unsigned char*)malloc(m_nBufSizeForSaveImage);

    }

    //MV_SAVE_IMAGE_PARAM_EX stParam = { 0 };

    //MV_SAVE_IAMGE_TYPE   m_nSaveImageType;      // ch:保存图像格式 | en:Save Image Type

    //m_nSaveImageType = MV_Image_Bmp;

    //stParam.enImageType = m_nSaveImageType; // ch:需要保存的图像类型 | en:Image format to save

    //stParam.enPixelType = pFrameInfo->enPixelType;  // ch:相机对应的像素格式 | en:Camera pixel type

    //stParam.nWidth = pFrameInfo->nWidth;         // ch:相机对应的宽 | en:Width

    //stParam.nHeight = pFrameInfo->nHeight;          // ch:相机对应的高 | en:Height

    //stParam.nDataLen = pFrameInfo->nFrameLen;

    //stParam.pData = pData;

    //stParam.pImageBuffer = m_pBufForSaveImage;

    //stParam.nBufferSize = m_nBufSizeForSaveImage;  // ch:存储节点的大小 | en:Buffer node size

    //stParam.nJpgQuality = 80;       // ch:jpg编码,仅在保存Jpg图像时有效。保存BMP时SDK内忽略该参数

    //MV_CC_SaveImageEx2(handle, &stParam);    // en:jpg encoding, only valid when saving as Jpg. SDK ignore this parameter when saving as BMP

    //

    //                                        //将转换之后图片数据保存成文件

    //char chImageName[100] = { 0 };


    //std::string s = std::to_string(i);

    //std::string ch1 = st2 + s +"\\%d.bmp";

    //char p[100];

    //int i = 0;

    //for (i = 0; i < ch1.length(); i++)

    //    p[i] = ch1[i];

    //p[i] = '\0';

 //   sprintf_s(chImageName, 100, p, pFrameInfo->nFrameNum);

 //   //std::string chImageName = "C:\\Users\\Administrator\\Desktop\\mianjiegouguangchongjian\\kls\\deviceone_picture\\"+std::to_string(stImageInfo.nFrameNum)+".bmp";

    //FILE* fp = fopen(chImageName, "wb+");

    //fwrite(m_pBufForSaveImage, 1, stParam.nImageLen, fp);

    //fclose(fp);

    //free(m_pBufForSaveImage);

    //i++;

    ////...其他图像数据处理                                        

    //                                        //for (int i = 0; i < 100; i++)

    ////    //保存图片

    ////{

    ////    printf("%d \n", pData[i]);

    ////}

    ////SaveBMPFile("d:\\kls.bmp", pData,   pFrameInfo->nWidth, pFrameInfo->nHeight);

    // ch:设置对应的相机参数 | en:Set camera parameter

    MV_SAVE_IAMGE_TYPE   m_nSaveImageType;      // ch:保存图像格式 | en:Save Image Type

    m_nSaveImageType = MV_Image_Bmp;

    MV_SAVE_IMAGE_PARAM_EX stParam = { 0 };

    stParam.enImageType = m_nSaveImageType; // ch:需要保存的图像类型 | en:Image format to save

    stParam.enPixelType = pFrameInfo->enPixelType;  // ch:相机对应的像素格式 | en:Camera pixel type

    stParam.nWidth = pFrameInfo->nWidth;         // ch:相机对应的宽 | en:Width

    stParam.nHeight = pFrameInfo->nHeight;          // ch:相机对应的高 | en:Height

    stParam.nDataLen = pFrameInfo->nFrameLen;

    stParam.pData = pData;

    stParam.pImageBuffer = m_pBufForSaveImage;

    stParam.nBufferSize = m_nBufSizeForSaveImage;  // ch:存储节点的大小 | en:Buffer node size

    stParam.nJpgQuality = 80;       // ch:jpg编码,仅在保存Jpg图像时有效。保存BMP时SDK内忽略该参数


    nRet = MV_CC_SaveImageEx2(handle, &stParam);

    if (0 == nRet)

    {

        printf(("write image failed, maybe you have no privilege"), 0);

    }


    char chImageName[64] = { 0 };

    sprintf_s(chImageName, 64, "D:\\siat_reconstruction\\1_picture\\%01d.bmp", pFrameInfo->nFrameNum);

    FILE* fp = fopen(chImageName, "wb");

    if (NULL == fp)

    {

        printf(("write image failed, maybe you have no privilege"), 0);

    }

    fwrite(m_pBufForSaveImage, 1, stParam.nImageLen, fp);

    fclose(fp);

}


int main()

{


    do 

    {

        // ch:枚举设备 | Enum device

        MV_CC_DEVICE_INFO_LIST stDeviceList;

        memset(&stDeviceList, 0, sizeof(MV_CC_DEVICE_INFO_LIST));

        nRet = MV_CC_EnumDevices(MV_GIGE_DEVICE | MV_USB_DEVICE, &stDeviceList);

        if (MV_OK != nRet)

        {

            printf("Enum Devices fail! nRet [0x%x]\n", nRet);

            break;

        }


        if (stDeviceList.nDeviceNum > 0)

        {

            for (unsigned int i = 0; i < stDeviceList.nDeviceNum; i++)

            {

                printf("[device %d]:\n", i);

                MV_CC_DEVICE_INFO* pDeviceInfo = stDeviceList.pDeviceInfo[i];

                if (NULL == pDeviceInfo)

                {

                    break;

                } 

                PrintDeviceInfo(pDeviceInfo);            

            }  

        } 

        else

        {

            printf("Find No Devices!\n");

            break;

        }


        printf("Please Intput camera index:");

        unsigned int nIndex = 0;

        scanf("%d", &nIndex);


        if (nIndex >= stDeviceList.nDeviceNum)

        {

            printf("Intput error!\n");

            break;

        }


        // ch:选择设备并创建句柄 | Select device and create handle

        nRet = MV_CC_CreateHandle(&handle, stDeviceList.pDeviceInfo[nIndex]);

        if (MV_OK != nRet)

        {

            printf("Create Handle fail! nRet [0x%x]\n", nRet);

            break;

        }


        // ch:打开设备 | Open device

        nRet = MV_CC_OpenDevice(handle);

        if (MV_OK != nRet)

        {

            printf("Open Device fail! nRet [0x%x]\n", nRet);

            break;

        }


        // ch:探测网络最佳包大小(只对GigE相机有效) | en:Detection network optimal package size(It only works for the GigE camera)

        if (stDeviceList.pDeviceInfo[nIndex]->nTLayerType == MV_GIGE_DEVICE)

        {

            int nPacketSize = MV_CC_GetOptimalPacketSize(handle);

            if (nPacketSize > 0)

            {

                nRet = MV_CC_SetIntValue(handle,"GevSCPSPacketSize",nPacketSize);

                if(nRet != MV_OK)

                {

                    printf("Warning: Set Packet Size fail nRet [0x%x]!", nRet);

                }

            }

            else

            {

                printf("Warning: Get Packet Size fail nRet [0x%x]!", nPacketSize);

            }

        }

        // ch:设置触发模式为off 

        nRet = MV_CC_SetEnumValue(handle, "TriggerMode", MV_TRIGGER_MODE_OFF);

        if (MV_OK != nRet)

        {

            printf("Set Trigger Mode fail! nRet [0x%x]\n", nRet);

            break;

        }


        //设置相机曝光时间

        nRet = MV_CC_SetEnumValue(handle, "ExposureAuto", MV_EXPOSURE_AUTO_MODE_OFF);

        if (MV_OK != nRet)

        {

            printf("Set ExposureAuto fail! nRet [0x%x]\n", nRet);

            break;

        }

        //Sleep(10);//如果不加这个sleep,曝光时间的设置会失败。

        nRet = MV_CC_SetFloatValue(handle, "ExposureTime", expose1);

        if (MV_OK != nRet)

        {

            printf("Set ExposureTime fail! nRet [0x%x]\n", nRet);

            break;

        }

        // ch:设置触发模式为on 

        nRet = MV_CC_SetEnumValue(handle, "TriggerMode", MV_TRIGGER_MODE_ON);

        if (MV_OK != nRet)

        {

            printf("Set Trigger Mode fail! nRet [0x%x]\n", nRet);

            break;

        }

        //设置Enum型参数

        unsigned int enMode = MV_TRIGGER_SOURCE_LINE0; //设置触发源为软触发

                                                       // ch:设置为硬触发模式 | en:Set trigger mode as hardware trigger

        nRet = MV_CC_SetEnumValue(handle, "TriggerSource", enMode);

        if (MV_OK != nRet)

        {

            printf("Set Trigger Source fail! nRet [0x%x]\n", nRet);

            break;

        }


        // ch:注册抓图回调 | en:Register image callback

        nRet = MV_CC_RegisterImageCallBackEx(handle, ImageCallBackEx, handle);

        if (MV_OK != nRet)

        {

            printf("Register Image CallBack fail! nRet [0x%x]\n", nRet);

            break;

        }



        // ch:获取数据包大小 | en:Get payload size

        MVCC_INTVALUE stParama1;

        memset(&stParama1, 0, sizeof(MVCC_INTVALUE));

        nRet = MV_CC_GetIntValue(handle, "PayloadSize", &stParama1);

        if (MV_OK != nRet)

        {

            printf("Get PayloadSize fail! nRet [0x%x]\n", nRet);

            break;

        }

        g_nPayloadSize = stParama1.nCurValue;

        // ch:开始取流 | en:Start grab image

        nRet = MV_CC_StartGrabbing(handle);

        if (MV_OK != nRet)

        {

            printf("Start Grabbing fail! nRet [0x%x]\n", nRet);

            break;

        }

        printf("Press a key to stop grabbing.\n");

        WaitForKeyPress();


        // ch:停止取流 | en:Stop grab image

        nRet = MV_CC_StopGrabbing(handle);

        if (MV_OK != nRet)

        {

            printf("Stop Grabbing fail! nRet [0x%x]\n", nRet);

            break;

        }


        // ch:关闭设备 | en:Close device

        nRet = MV_CC_CloseDevice(handle);

        if (MV_OK != nRet)

        {

            printf("Close Device fail! nRet [0x%x]\n", nRet);

            break;

        }


        // ch:销毁句柄 | en:Destroy handle

        nRet = MV_CC_DestroyHandle(handle);

        if (MV_OK != nRet)

        {

            printf("Destroy Handle fail! nRet [0x%x]\n", nRet);

            break;

        }

    } while (0);


    if (nRet != MV_OK)

    {

        if (handle != NULL)

        {

            MV_CC_DestroyHandle(handle);

            handle = NULL;

        }

    }


    printf("Press a key to exit.\n");

    WaitForKeyPress();


    return 0;

}


 


直接存入硬盘有点慢,有些图片来不及触发,还是写入内存再保存到硬盘里靠谱

#include <stdio.h>
#include <Windows.h>
#include <conio.h>
#include "MvCameraControl.h"
#include <string>
#include "bmpLoader.h"
//#include <opencv2/core/core.hpp>  
//#include <opencv2/highgui/highgui.hpp>  
#include<opencv2/opencv.hpp>
int nRet = MV_OK;
void* handle = NULL;
int expose1 = 1000;
unsigned int g_nPayloadSize = 0;
unsigned int    m_nBufSizeForSaveImage;
unsigned int    save_imagesze= NULL;
// ch:等待按键输入 | en:Wait for key press
std::vector<unsigned char* > image;
void WaitForKeyPress(void)
{
    while(!_kbhit())
    {
        Sleep(10);
    }
    _getch();
}
 
 
 
 
 
 
bool PrintDeviceInfo(MV_CC_DEVICE_INFO* pstMVDevInfo)
{
    if (NULL == pstMVDevInfo)
    {
        printf("The Pointer of pstMVDevInfo is NULL!\n");
        return false;
    }
    if (pstMVDevInfo->nTLayerType == MV_GIGE_DEVICE)
    {
        int nIp1 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0xff000000) >> 24);
        int nIp2 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x00ff0000) >> 16);
        int nIp3 = ((pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x0000ff00) >> 8);
        int nIp4 = (pstMVDevInfo->SpecialInfo.stGigEInfo.nCurrentIp & 0x000000ff);
 
        // ch:打印当前相机ip和用户自定义名字 | en:print current ip and user defined name
        printf("CurrentIp: %d.%d.%d.%d\n" , nIp1, nIp2, nIp3, nIp4);
        printf("UserDefinedName: %s\n\n" , pstMVDevInfo->SpecialInfo.stGigEInfo.chUserDefinedName);
    }
    else if (pstMVDevInfo->nTLayerType == MV_USB_DEVICE)
    {
        printf("UserDefinedName: %s\n\n", pstMVDevInfo->SpecialInfo.stUsb3VInfo.chUserDefinedName);
    }
    else
    {
        printf("Not support.\n");
    }
 
    return true;
}
int i = 0;
void __stdcall ImageCallBackEx(unsigned char * pData, MV_FRAME_OUT_INFO_EX* pFrameInfo, void* pUser)
{    
	unsigned char*  m_pBufForSaveImage= NULL;         // ch:用于保存图像的缓存 | en:Buffer to save image
    if (pFrameInfo)
    {
        printf("Get One Frame: Width[%d], Height[%d], nFrameNum[%d]\n", 
            pFrameInfo->nWidth, pFrameInfo->nHeight, pFrameInfo->nFrameNum);
    }
	// ch:设置对应的相机参数 | en:Set camera parameter
	if (NULL == m_pBufForSaveImage)
	{
		// ch:BMP图片大小:width * height * 3 + 2048(预留BMP头大小)
		// en:// BMP image size: width * height * 3 + 2048 (Reserved BMP header size)
		m_nBufSizeForSaveImage = pFrameInfo->nWidth * pFrameInfo->nHeight * 3 + 2048;
		m_pBufForSaveImage = (unsigned char*)malloc(m_nBufSizeForSaveImage);
	}
	//MV_SAVE_IMAGE_PARAM_EX stParam = { 0 };
	//MV_SAVE_IAMGE_TYPE   m_nSaveImageType;      // ch:保存图像格式 | en:Save Image Type
	//m_nSaveImageType = MV_Image_Bmp;
	//stParam.enImageType = m_nSaveImageType; // ch:需要保存的图像类型 | en:Image format to save
	//stParam.enPixelType = pFrameInfo->enPixelType;  // ch:相机对应的像素格式 | en:Camera pixel type
	//stParam.nWidth = pFrameInfo->nWidth;         // ch:相机对应的宽 | en:Width
	//stParam.nHeight = pFrameInfo->nHeight;          // ch:相机对应的高 | en:Height
	//stParam.nDataLen = pFrameInfo->nFrameLen;
	//stParam.pData = pData;
	//stParam.pImageBuffer = m_pBufForSaveImage;
	//stParam.nBufferSize = m_nBufSizeForSaveImage;  // ch:存储节点的大小 | en:Buffer node size
	//stParam.nJpgQuality = 80;       // ch:jpg编码,仅在保存Jpg图像时有效。保存BMP时SDK内忽略该参数
	//MV_CC_SaveImageEx2(handle, &stParam);	// en:jpg encoding, only valid when saving as Jpg. SDK ignore this parameter when saving as BMP
	//
	//										//将转换之后图片数据保存成文件
	//char chImageName[100] = { 0 };
 
	//std::string s = std::to_string(i);
	//std::string ch1 = st2 + s +"\\%d.bmp";
	//char p[100];
	//int i = 0;
	//for (i = 0; i < ch1.length(); i++)
	//	p[i] = ch1[i];
	//p[i] = '\0';
 //   sprintf_s(chImageName, 100, p, pFrameInfo->nFrameNum);
 //   //std::string chImageName = "C:\\Users\\Administrator\\Desktop\\mianjiegouguangchongjian\\kls\\deviceone_picture\\"+std::to_string(stImageInfo.nFrameNum)+".bmp";
	//FILE* fp = fopen(chImageName, "wb+");
	//fwrite(m_pBufForSaveImage, 1, stParam.nImageLen, fp);
	//fclose(fp);
	//free(m_pBufForSaveImage);
	//i++;
	////...其他图像数据处理										
	//										//for (int i = 0; i < 100; i++)
	////	//保存图片
	////{
	////	printf("%d \n", pData[i]);
	////}
	////SaveBMPFile("d:\\kls.bmp", pData,   pFrameInfo->nWidth, pFrameInfo->nHeight);
	// ch:设置对应的相机参数 | en:Set camera parameter
	MV_SAVE_IAMGE_TYPE   m_nSaveImageType;      // ch:保存图像格式 | en:Save Image Type
    m_nSaveImageType = MV_Image_Bmp;
	MV_SAVE_IMAGE_PARAM_EX stParam = { 0 };
	stParam.enImageType = m_nSaveImageType; // ch:需要保存的图像类型 | en:Image format to save
	stParam.enPixelType = pFrameInfo->enPixelType;  // ch:相机对应的像素格式 | en:Camera pixel type
	stParam.nWidth = pFrameInfo->nWidth;         // ch:相机对应的宽 | en:Width
	stParam.nHeight = pFrameInfo->nHeight;          // ch:相机对应的高 | en:Height
	stParam.nDataLen = pFrameInfo->nFrameLen;
	stParam.pData = pData;
	stParam.pImageBuffer = m_pBufForSaveImage;
	stParam.nBufferSize = m_nBufSizeForSaveImage;  // ch:存储节点的大小 | en:Buffer node size
	stParam.nJpgQuality = 80;       // ch:jpg编码,仅在保存Jpg图像时有效。保存BMP时SDK内忽略该参数
 
	nRet = MV_CC_SaveImageEx2(handle, &stParam);
	
 
	image.push_back(m_pBufForSaveImage);
	if (NULL == save_imagesze)
	{
		save_imagesze = stParam.nImageLen;
	}
	
}
 
int main()
{
 
    do 
    {
        // ch:枚举设备 | Enum device
        MV_CC_DEVICE_INFO_LIST stDeviceList;
        memset(&stDeviceList, 0, sizeof(MV_CC_DEVICE_INFO_LIST));
        nRet = MV_CC_EnumDevices(MV_GIGE_DEVICE | MV_USB_DEVICE, &stDeviceList);
        if (MV_OK != nRet)
        {
            printf("Enum Devices fail! nRet [0x%x]\n", nRet);
            break;
        }
 
        if (stDeviceList.nDeviceNum > 0)
        {
            for (unsigned int i = 0; i < stDeviceList.nDeviceNum; i++)
            {
                printf("[device %d]:\n", i);
                MV_CC_DEVICE_INFO* pDeviceInfo = stDeviceList.pDeviceInfo[i];
                if (NULL == pDeviceInfo)
                {
                    break;
                } 
                PrintDeviceInfo(pDeviceInfo);            
            }  
        } 
        else
        {
            printf("Find No Devices!\n");
            break;
        }
 
        printf("Please Intput camera index:");
        unsigned int nIndex = 0;
        scanf("%d", &nIndex);
 
        if (nIndex >= stDeviceList.nDeviceNum)
        {
            printf("Intput error!\n");
            break;
        }
 
        // ch:选择设备并创建句柄 | Select device and create handle
        nRet = MV_CC_CreateHandle(&handle, stDeviceList.pDeviceInfo[nIndex]);
        if (MV_OK != nRet)
        {
            printf("Create Handle fail! nRet [0x%x]\n", nRet);
            break;
        }
 
        // ch:打开设备 | Open device
        nRet = MV_CC_OpenDevice(handle);
        if (MV_OK != nRet)
        {
            printf("Open Device fail! nRet [0x%x]\n", nRet);
            break;
        }
 
        // ch:探测网络最佳包大小(只对GigE相机有效) | en:Detection network optimal package size(It only works for the GigE camera)
        if (stDeviceList.pDeviceInfo[nIndex]->nTLayerType == MV_GIGE_DEVICE)
        {
            int nPacketSize = MV_CC_GetOptimalPacketSize(handle);
            if (nPacketSize > 0)
            {
                nRet = MV_CC_SetIntValue(handle,"GevSCPSPacketSize",nPacketSize);
                if(nRet != MV_OK)
                {
                    printf("Warning: Set Packet Size fail nRet [0x%x]!", nRet);
                }
            }
            else
            {
                printf("Warning: Get Packet Size fail nRet [0x%x]!", nPacketSize);
            }
        }
		// ch:设置触发模式为off 
		nRet = MV_CC_SetEnumValue(handle, "TriggerMode", MV_TRIGGER_MODE_OFF);
		if (MV_OK != nRet)
		{
			printf("Set Trigger Mode fail! nRet [0x%x]\n", nRet);
			break;
		}
 
		//设置相机曝光时间
		nRet = MV_CC_SetEnumValue(handle, "ExposureAuto", MV_EXPOSURE_AUTO_MODE_OFF);
		if (MV_OK != nRet)
		{
			printf("Set ExposureAuto fail! nRet [0x%x]\n", nRet);
			break;
		}
		//Sleep(10);//如果不加这个sleep,曝光时间的设置会失败。
		nRet = MV_CC_SetFloatValue(handle, "ExposureTime", expose1);
		if (MV_OK != nRet)
		{
			printf("Set ExposureTime fail! nRet [0x%x]\n", nRet);
			break;
		}
		// ch:设置触发模式为on 
		nRet = MV_CC_SetEnumValue(handle, "TriggerMode", MV_TRIGGER_MODE_ON);
		if (MV_OK != nRet)
		{
			printf("Set Trigger Mode fail! nRet [0x%x]\n", nRet);
			break;
		}
		//设置Enum型参数
		unsigned int enMode = MV_TRIGGER_SOURCE_LINE0; //设置触发源为软触发
													   // ch:设置为硬触发模式 | en:Set trigger mode as hardware trigger
		nRet = MV_CC_SetEnumValue(handle, "TriggerSource", enMode);
		if (MV_OK != nRet)
		{
			printf("Set Trigger Source fail! nRet [0x%x]\n", nRet);
			break;
		}
 
        // ch:注册抓图回调 | en:Register image callback
        nRet = MV_CC_RegisterImageCallBackEx(handle, ImageCallBackEx, handle);
        if (MV_OK != nRet)
        {
            printf("Register Image CallBack fail! nRet [0x%x]\n", nRet);
            break;
        }
 
 
		// ch:获取数据包大小 | en:Get payload size
		MVCC_INTVALUE stParama1;
		memset(&stParama1, 0, sizeof(MVCC_INTVALUE));
		nRet = MV_CC_GetIntValue(handle, "PayloadSize", &stParama1);
		if (MV_OK != nRet)
		{
			printf("Get PayloadSize fail! nRet [0x%x]\n", nRet);
			break;
		}
		g_nPayloadSize = stParama1.nCurValue;
        // ch:开始取流 | en:Start grab image
        nRet = MV_CC_StartGrabbing(handle);
        if (MV_OK != nRet)
        {
            printf("Start Grabbing fail! nRet [0x%x]\n", nRet);
            break;
        }
        printf("Press a key to stop grabbing.\n");
        WaitForKeyPress();
 
        // ch:停止取流 | en:Stop grab image
        nRet = MV_CC_StopGrabbing(handle);
        if (MV_OK != nRet)
        {
            printf("Stop Grabbing fail! nRet [0x%x]\n", nRet);
            break;
        }
		printf("开始保存图片\n");
		//保存图片
		for (int i = 0; i<image.size(); i++)
		{
			char chImageName[64] = { 0 };
			sprintf_s(chImageName, 64, "D:\\1_picture\\%01d.bmp", i);
			FILE* fp = fopen(chImageName, "wb");
			fwrite(image.at(i), 1, save_imagesze, fp);
			fclose(fp);
		}
		printf("保存图片结束\n");
        // ch:关闭设备 | en:Close device
        nRet = MV_CC_CloseDevice(handle);
        if (MV_OK != nRet)
        {
            printf("Close Device fail! nRet [0x%x]\n", nRet);
            break;
        }
 
        // ch:销毁句柄 | en:Destroy handle
        nRet = MV_CC_DestroyHandle(handle);
        if (MV_OK != nRet)
        {
            printf("Destroy Handle fail! nRet [0x%x]\n", nRet);
            break;
        }
    } while (0);
 
    if (nRet != MV_OK)
    {
        if (handle != NULL)
        {
            MV_CC_DestroyHandle(handle);
            handle = NULL;
        }
    }
 
    //printf("Press a key to exit.\n");
    //WaitForKeyPress();
 
	while (1);
    return 0;
}



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

版权声明:本文为CSDN博主「哈哈kls」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/konglingshneg/java/article/details/89084543


本文出自勇哥的网站《少有人走的路》wwww.skcircle.com,转载请注明出处!讨论可扫码加群:

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

会员中心
搜索
«    2024年4月    »
1234567
891011121314
15161718192021
22232425262728
2930
网站分类
标签列表
最新留言
    热门文章 | 热评文章 | 随机文章
文章归档
友情链接
  • 订阅本站的 RSS 2.0 新闻聚合
  • 扫描加本站机器视觉QQ群,验证答案为:halcon勇哥的机器视觉
  • 点击查阅微信群二维码
  • 扫描加勇哥的非标自动化群,验证答案:C#/C++/VB勇哥的非标自动化群
  • 扫描加站长微信:站长微信:abc496103864
  • 扫描加站长QQ:
  • 扫描赞赏本站:
  • 留言板:

Powered By Z-BlogPHP 1.7.2

Copyright Your skcircle.com Rights Reserved.

鄂ICP备18008319号


站长QQ:496103864 微信:abc496103864