В настоящее время я пытаюсь объединить два отдельных изображения камеры в одно изображение как Anaglyph. Результат должен выглядеть примерно как this image here.Как смешивать стереоизображение с EmguCV?
Вот мой код, который я написал, чтобы захватить две камеры изображений и конвертирования их в черный & белый:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using Emgu.CV;
using Emgu.CV.CvEnum;
using Emgu.CV.Structure;
using Emgu.Util;
namespace CameraStereoCapture {
public partial class CameraStereoCapture : Form {
private bool captureInProgress;
private VideoCapture cameraLeft = null;
private VideoCapture cameraRight = null;
private Mat leftRawFrame;
private Mat rightRawFrame;
private Mat leftGrayFrame;
private Mat rightGrayFrame;
private Mat stereoFrame;
public CameraStereoCapture() {
InitializeComponent();
CvInvoke.UseOpenCL = false;
try {
cameraLeft = new VideoCapture(1);
cameraLeft.ImageGrabbed += ProcessFrame;
cameraRight = new VideoCapture(0);
cameraRight.ImageGrabbed += ProcessFrame;
} catch (NullReferenceException ex) {
MessageBox.Show(ex.Message);
}
leftRawFrame = new Mat();
rightRawFrame = new Mat();
leftGrayFrame = new Mat();
rightGrayFrame = new Mat();
stereoFrame = new Mat();
}
private void cmdCapture_Click(object sender, EventArgs e) {
if (cameraLeft != null) {
if (captureInProgress) {
// stop the capture
cmdCapture.Text = "Start Capture";
cameraLeft.Pause();
cameraRight.Pause();
} else {
// start the capture
cmdCapture.Text = "Stop Capture";
cameraLeft.Start();
cameraRight.Start();
}
captureInProgress = !captureInProgress;
}
}
private void ProcessFrame(object sender, EventArgs arg) {
// capture and cache image from left camera
if (cameraLeft != null && cameraLeft.Ptr != IntPtr.Zero) {
cameraLeft.Retrieve(leftRawFrame, 0);
imgLeft.Image = leftRawFrame;
}
// capture and cache image from right camera
if (cameraRight != null && cameraRight.Ptr != IntPtr.Zero) {
cameraRight.Retrieve(rightRawFrame, 0);
imgRight.Image = rightRawFrame;
}
// calculate stereo image by combining the left and right image
if (leftRawFrame != null && rightRawFrame!=null) {
CvInvoke.CvtColor(leftRawFrame, leftGrayFrame, ColorConversion.Bgr2Gray);
CvInvoke.CvtColor(rightRawFrame, rightGrayFrame, ColorConversion.Bgr2Gray);
// TODO: how to convert 'leftRawImage to Cyan' ???
// TODO: how to convert 'rightRawImage to Magenta' ???
CvInvoke.AddWeighted(leftGrayFrame, 0.5, rightGrayFrame, 0.5, 1.0, stereoFrame);
imgStereo.Image = stereoFrame;
}
}
}
}
Мой вопрос, как преобразовать серые изображения в Cyan
и Magenta
или Red
и Blue
(cp. Строки в фрагменте кода, которые обозначены как TODO:
)?
Благодарим за предложение! Я реализовал это в C#/EmguCV, но преобразование матрицы-> изображения кажется слишком медленным и не может идти в ногу с событиями съемки. Я ищу матричное решение (см. Мой код в вопросе). Есть идеи? – salocinx
Я не знаком с EmguCV. Но другим решением может быть не доступ к отдельному пикселю, как мой вышеприведенный код, а к копированию всего канала (например, скопировать весь imgLeft в R-канал imgStereo). Могут быть mixChannels или функции слияния, такие как [здесь] (http://stackoverflow.com/questions/20341910/opencv-taking-a-3-channel-rgb-image-splitting-channels-and-viewing-an-image-wi) и [здесь] (http://stackoverflow.com/questions/6699374/access-to-each-separate-channel-in-opencv) – Hardtack