0

OpenCVを使用してVS 2010でプログラムを開発しています。コンピュータのカメラがキャプチャするすべてのフレームの輝度を測定したいと考えています。ただし、カメラのソフトウェアは、2 ~ 3 フレーム後に輝度を安定させます。たとえば、親指をカメラの前に置くと、最初のフレームの輝度は 2 (スケール 0 から 255) ですが、親指をカメラの前に置いたままにしておくと、輝度は 7 になり、20 になります。次のフレーム。そのため、カメラは暗すぎる写真を明るくし、明るすぎる写真を暗くしようとします。

カメラの干渉なしで実際の輝度を測定するにはどうすればよいですか? 私のコードは次のとおりです。

#ifdef _CH_
#pragma package <opencv>
#endif
#include "stdafx.h"
#include <highgui.h>

#include "cv.h"
#include <stdio.h>
#include <stdlib.h>
#include "..\utilities.h"

int _tmain(int argc, _TCHAR* argv[])
{
FILE *file;
IplImage *img;
IplImage* grayscale_image;
int c, i, j, Luminance = 0, Pixel_Num = 0;
int Avg_Luminance;
int width_step;
int pixel_step;
// allocate memory for an image

// capture from video device #1
CvCapture* capture;
// create a window to display the images
cvNamedWindow("mainWin", CV_WINDOW_AUTOSIZE);
// position the window
cvMoveWindow("mainWin", 5, 5);
while(1)
{
    if(file = fopen("luminance_value.txt", "w+"))
    {
        // retrieve the captured frame
        capture= cvCaptureFromCAM(1);
        img=cvQueryFrame(capture);

        grayscale_image = cvCreateImage( cvGetSize(img), 8, 1 );
        cvConvertImage( img, grayscale_image );
        width_step= grayscale_image->widthStep;
        pixel_step= grayscale_image->widthStep/grayscale_image->width;
        Pixel_Num = grayscale_image->width * grayscale_image->height;
        for(i = 0; i < grayscale_image->height; i++)
        {
            for(j = 0; j < grayscale_image->width; j++)
            {
                unsigned char* point = GETPIXELPTRMACRO( grayscale_image, j, i, width_step, pixel_step);
                Luminance += point[0];
            }
        }
        Avg_Luminance = Luminance / Pixel_Num;
        //Avg_Luminance = cvGetCaptureProperty(capture,CV_CAP_PROP_BRIGHTNESS);
        //file = fopen("luminance_value.txt", "w+");
        fprintf(file, "%d", Avg_Luminance);
        fclose(file);
        printf("Avg_Luminance = %d\n", Avg_Luminance);
        Luminance = 0;
        Pixel_Num = 0;
        // show the image in the window
        cvShowImage("mainWin", grayscale_image );
        cvReleaseCapture(&capture);
        // wait 10 ms for a key to be pressed
        c=cvWaitKey(10000);
        // escape key terminates program
        if(c == 27)
        break;
    }
    else
    {
        continue;
    }

    }
 return 0;
}
4

0 に答える 0