我需要相同的功能应用即时心率 。
其基本过程需要用户:
- 轻轻地放在食指的前端的照相机镜头上。
- 即使应用压力和覆盖整个镜头。
- 保持它稳定10秒,得到心脏速率。
这可以通过开启闪光灯来完成和血液移动通过食指观看光线的变化。
我怎样才能从视频捕捉光级数据? 我应该在哪里找呢? 我通过类看着AVCaptureDevice
但没有发现任何有用的东西。
我还发现AVCaptureDeviceSubjectAreaDidChangeNotification
,会是这样有用吗?
我需要相同的功能应用即时心率 。
其基本过程需要用户:
这可以通过开启闪光灯来完成和血液移动通过食指观看光线的变化。
我怎样才能从视频捕捉光级数据? 我应该在哪里找呢? 我通过类看着AVCaptureDevice
但没有发现任何有用的东西。
我还发现AVCaptureDeviceSubjectAreaDidChangeNotification
,会是这样有用吗?
看看这个..
// switch on the flash in torch mode
if([camera isTorchModeSupported:AVCaptureTorchModeOn]) {
[camera lockForConfiguration:nil];
camera.torchMode=AVCaptureTorchModeOn;
[camera unlockForConfiguration];
}
[session setSessionPreset:AVCaptureSessionPresetLow];
// Create the AVCapture Session
session = [[AVCaptureSession alloc] init];
// Get the default camera device
AVCaptureDevice* camera = [AVCaptureDevice defaultDeviceWithMediaType:AVMediaTypeVideo];
if([camera isTorchModeSupported:AVCaptureTorchModeOn]) {
[camera lockForConfiguration:nil];
camera.torchMode=AVCaptureTorchModeOn;
[camera unlockForConfiguration];
}
// Create a AVCaptureInput with the camera device
NSError *error=nil;
AVCaptureInput* cameraInput = [[AVCaptureDeviceInput alloc] initWithDevice:camera error:&error];
if (cameraInput == nil) {
NSLog(@"Error to create camera capture:%@",error);
}
// Set the output
AVCaptureVideoDataOutput* videoOutput = [[AVCaptureVideoDataOutput alloc] init];
// create a queue to run the capture on
dispatch_queue_t captureQueue=dispatch_queue_create("catpureQueue", NULL);
// setup our delegate
[videoOutput setSampleBufferDelegate:self queue:captureQueue];
// configure the pixel format
videoOutput.videoSettings = [NSDictionary dictionaryWithObjectsAndKeys:[NSNumber numberWithUnsignedInt:kCVPixelFormatType_32BGRA], (id)kCVPixelBufferPixelFormatTypeKey,
nil];
// cap the framerate
videoOutput.minFrameDuration=CMTimeMake(1, 10);
// and the size of the frames we want
[session setSessionPreset:AVCaptureSessionPresetLow];
// Add the input and output
[session addInput:cameraInput];
[session addOutput:videoOutput];
// Start the session
[session startRunning];
- (void)captureOutput:(AVCaptureOutput *)captureOutput didOutputSampleBuffer:(CMSampleBufferRef)sampleBuffer fromConnection:(AVCaptureConnection *)connection {
// this is the image buffer
CVImageBufferRef cvimgRef = CMSampleBufferGetImageBuffer(sampleBuffer);
// Lock the image buffer
CVPixelBufferLockBaseAddress(cvimgRef,0);
// access the data
int width=CVPixelBufferGetWidth(cvimgRef);
int height=CVPixelBufferGetHeight(cvimgRef);
// get the raw image bytes
uint8_t *buf=(uint8_t *) CVPixelBufferGetBaseAddress(cvimgRef);
size_t bprow=CVPixelBufferGetBytesPerRow(cvimgRef);
// get the average red green and blue values from the image
float r=0,g=0,b=0;
for(int y=0; y<height; y++) {
for(int x=0; x<width*4; x+=4) {
b+=buf[x];
g+=buf[x+1];
r+=buf[x+2];
}
buf+=bprow;
}
r/=255*(float) (width*height);
g/=255*(float) (width*height);
b/=255*(float) (width*height);
NSLog(@"%f,%f,%f", r, g, b);
}
示例代码 这里
其实可以很简单,你要分析所拍摄的图像的像素值。 一个简单的算法是:选择和区域在图像的中心,转换成灰度图像,获得像素的中间值的每个图像,你会最终有一个2D功能,此功能计算到最小值之间的距离或最大和问题就解决了。
如果你看一下在5秒钟获取的图像的直方图,你会发现灰度分布的变化。 如果你想要一个更强大的计算分析柱状图。
作为一个侧面说明,你可能有兴趣在此研究论文 。 这种方法甚至不需要一个手指(或任何东西)直接对镜头。