exponenta event banner

Альфа-смешение пар потоковых изображений

В этом примере показано, как захватывать потоковые изображения из устройства получения изображения, выполнять обработку изображения в режиме реального времени для каждого кадра и отображать обработанные кадры.

Результатом является альфа-смесь двух изображений, один из которых неподвижный маятник, другой маятник в движении, что делает движущиеся элементы прозрачными.

Шаг 1: захват фонового изображения

Регистрация и отображение снимка фона без движущихся элементов.

% Access an image acquisition device.
vidobj = videoinput('winvideo', 1, 'RGB24_320X240');

% Using the preview window, properly position the camera.
preview(vidobj)
pause(1)

% Capture an image with no moving features.
background = getsnapshot(vidobj);

% Convert the background from uint8 to double.
background = double(background)/255;

% Display the background image in a figure window.
imagesc(background);

Шаг 2: Обработка зарегистрированных данных

Используя полученные данные изображения, выполните интерактивную обработку изображения и отобразите обработанные изображения в окне рисунка.

Для каждого кадра потокового изображения вычислите линейную комбинацию между этим кадром и фоновым изображением. Линейная комбинация эффективно альфа смешивает два изображения, так что любые движущиеся элементы выглядят прозрачными.

% Set the object into motion.
pause(2);

% Configure the figure to produce flash-free rendering.
fig = gcf;
fig.DoubleBuffer' = 'on';

% Configure the acquisition.
vidobj.FramesPerTrigger = 20;

% Start the acquisition.
start(vidobj)

% While logging data, perform a linear combination between
% the current and background images.
current = getdata(vidobj, 1, 'double');
transparent = (current * 0.5) + (background * 0.5);

% Display the processed image.
imagesc(transparent);

% Repeat for all remaining images.
while (vidobj.FramesAvailable > 0),
    % Perform a linear combination between the current and background images.
    current = getdata(vidobj, 1, 'double');
    transparent = (current * 0.5) + (background * 0.5);

    % Display the processed image.
    imagesc(transparent);
end

% Once the video input object is no longer needed, delete
% it and clear it from the workspace.
delete(vidobj)
clear vidobj