Preview Live Data from Image Acquisition Device
Introduction
After you connect MATLAB® to the image acquisition device you can view the live video stream using the Video Preview window. Previewing the video data can help you make sure that the image being captured is satisfactory.
For example, by looking at a preview, you can verify that the lighting and focus are correct. If you change characteristics of the image, by using video input object and video source object properties, the image displayed in the Video Preview window changes to reflect the new property settings.
The following sections provide more information about using the Video Preview window.
Instead of using the toolbox's Video Preview window, you can display the live video preview stream in any graphics image object you specify. In this way, you can include video previewing in a GUI of your own creation. The following sections describe this capability.
Opening a Video Preview Window
To open a Video Preview window, use the preview function. The
                Video Preview window displays the live video stream from the device. You can only
                open one preview window per device. If multiple devices are used, you can open
                multiple preview windows at the same time.
The following example creates a video input object and then opens a Video Preview window for the video input object.
vid = videoinput('winvideo');
preview(vid);The following figure shows the Video Preview window created by this example. The
                Video Preview window displays the live video stream. The size of the preview image
                is determined by the value of the video input object's
                    ROIPosition property. The Video Preview window displays the
                video data at 100% magnification. 
In addition to the preview image, the Video Preview window includes information about the image, such as the timestamp of the video frame, the video resolution, the frame rate, and the current status of the video input object.
Note
Because video formats typically express resolution as width-by-height, the Video Preview window expresses the size of the image frame as column-by-row, rather than the standard MATLAB row-by-column format.

Note
The Image Acquisition Toolbox™ Preview
                    window supports the display of up to 16-bit image data. The Preview window was
                    designed to only show 8-bit data, but many cameras return 10-, 12-, 14-, or
                    16-bit data. The Preview window display supports these higher bit-depth cameras.
                    However, larger bit data is scaled to 8-bit for the purpose of displaying
                    previewed data. To capture the image data in the Preview window in its full bit
                    depth for grayscale images, set the PreviewFullBitDepth
                    property to 'on'.
Stopping the Preview Video Stream
When you use the preview function to start previewing image
                data, the Video Preview window displays a view of the live video stream coming from
                the device. To stop the updating of the live video stream, call the
                    stoppreview function.
This example creates a video input object and opens a Video Preview window. The
                example then calls the stoppreview function on this video input
                object. The Video Preview window stops updating the image displayed and stops
                updating the timestamp. The status displayed in the Video Preview window also
                changes to indicate that previewing has been stopped.
vid = videoinput('winvideo');
preview(vid)
stoppreview(vid)To restart the video stream in the Video Preview window, call
                    preview again on the same video input object.
preview(vid)
Closing a Video Preview Window
To close a particular Video Preview window, use the closepreview function, specifying the video input object as an
                argument. You do not need to stop the live video stream displayed in the Video
                Preview window before closing it.
closepreview(vid)
To close all currently open Video Preview windows, use the
                    closepreview function without any arguments. 
closepreview
Note
When called without an argument, the closepreview function
                    only closes Video Preview windows. The closepreview function
                    does not close any other figure windows in which you have directed the live
                    preview video stream. For more information, see Previewing Data in Custom GUIs.
Previewing Data in Custom GUIs
Instead of using the toolbox's Video Preview window, you can use the
                    preview function to direct the live video stream to any
                graphics image object. In this way, you can incorporate the toolbox's previewing
                capability in a GUI of your own creation. (You can also perform custom processing as
                the live video is displayed. For information, see Performing Custom Processing of Previewed Data.)
To use this capability, create an image object and then call the
                    preview function, specifying a handle to the image object as
                an argument. The preview function outputs the live video stream
                to the image object you specify. 
The following example creates a figure window and then creates an image object in
                the figure, the same size as the video frames. The example then calls the
                    preview function, specifying a handle to the image
                object.
% Create a video input object. vid = videoinput('winvideo'); % Create a figure window. This example turns off the default % toolbar, menubar, and figure numbering. figure('Toolbar','none',... 'Menubar', 'none',... 'NumberTitle','Off',... 'Name','My Preview Window'); % Create the image object in which you want to display % the video preview data. Make the size of the image % object match the dimensions of the video frames. vidRes = vid.VideoResolution; nBands = vid.NumberOfBands; hImage = image( zeros(vidRes(2), vidRes(1), nBands) ); % Display the video data in your GUI. preview(vid, hImage);
When you run this example, it creates the GUI shown in the following figure.
Custom Preview

Performing Custom Processing of Previewed Data
When you specify an image object to the preview function (see
                    Previewing Data in Custom GUIs), you can optionally
                also specify a function that preview executes every time it
                receives an image frame.
To use this capability, follow these steps:
- Create the function you want executed for each image frame, called the update preview window function. For information about this function, see Creating the Update Preview Window Function. 
- Create an image object. 
- Configure the value of the image object's - 'UpdatePreviewWindowFcn'application-defined data to be a function handle to your update preview window function. For more information, see Specifying the Update Preview Function.
- Call the - previewfunction, specifying the handle of the image object as an argument.
Note
If you specify an update preview window function, in addition to whatever
                    processing your function performs, it must display the video data in the image
                    object. You can do this by updating the CData of the image
                    object with the incoming video frames. For some performance guidelines about
                    updating the data displayed in an image object, see Technical Solution 1-1B022.
Creating the Update Preview Window Function
When preview calls the update preview window function you
                    specify, it passes your function the following arguments. 
| Argument | Description | |
|---|---|---|
| 
 | Handle to the video input object being previewed | |
| 
 | A data structure containing the following fields: | |
| 
 | Current image frame specified as an H-by-W-by-B array,
                                        where H is the image height and W is the image width, as
                                        specified in the  | |
| 
 | Character vector specifying the current image width and
                                        height, as defined by the  | |
| 
 | Character vector describing the status of the video input object | |
| 
 | Character vector specifying the time associated with
                                        the current image frame, in the format
                                             | |
| 
 | Character vector specifying the current frame rate of the video input object in frames per second | |
| 
 | Handle to the image object in which the data is to be displayed | |
The following example creates an update preview window function that displays
                    the timestamp of each incoming video frame as a text label in the custom GUI.
                    The update preview window function uses getappdata to
                    retrieve a handle to the text label uicontrol object from
                    application-defined data in the image object. The custom GUI stores this handle
                    to the text label uicontrol object — see Specifying the Update Preview Function. 
Note that the update preview window function also displays the video data by
                    updating the CData of the image object.
function mypreview_fcn(obj,event,himage) % Example update preview window function. % Get timestamp for frame. tstampstr = event.Timestamp; % Get handle to text label uicontrol. ht = getappdata(himage,'HandleToTimestampLabel'); % Set the value of the text label. ht.String = tstampstr; % Display image data. himage.CData = event.Data
Specifying the Update Preview Function
To use an update preview window function, store a function handle to your
                    function in the 'UpdatePreviewWindowFcn' application-defined
                    data of the image object. The following example uses the
                        setappdata function to configure this application-defined
                    data to a function handle to the update preview window function described in
                        Creating the Update Preview Window Function.
This example extends the simple custom preview window created in Previewing Data in Custom GUIs. This example adds
                    three push button uicontrol objects to the GUI: Start Preview, Stop
                        Preview, and Close
                    Preview.
In addition, to illustrate using an update preview window function, the
                    example GUI includes a text label uicontrol object to display
                    the timestamp value. The update preview window function updates this text label
                    each time a framed is received. The example uses setappdata
                    to store a handle to the text label uicontrol object in
                    application-defined data in the image object. The update preview window function
                    retrieves this handle to update the timestamp display.
% Create a video input object. vid = videoinput('winvideo'); % Create a figure window. This example turns off the default % toolbar and menubar in the figure. hFig = figure('Toolbar','none',... 'Menubar', 'none',... 'NumberTitle','Off',... 'Name','My Custom Preview GUI'); % Set up the push buttons uicontrol('String', 'Start Preview',... 'Callback', 'preview(vid)',... 'Units','normalized',... 'Position',[0 0 0.15 .07]); uicontrol('String', 'Stop Preview',... 'Callback', 'stoppreview(vid)',... 'Units','normalized',... 'Position',[.17 0 .15 .07]); uicontrol('String', 'Close',... 'Callback', 'close(gcf)',... 'Units','normalized',... 'Position',[0.34 0 .15 .07]); % Create the text label for the timestamp hTextLabel = uicontrol('style','text','String','Timestamp', ... 'Units','normalized',... 'Position',[0.85 -.04 .15 .08]); % Create the image object in which you want to % display the video preview data. vidRes = vid.VideoResolution; imWidth = vidRes(1); imHeight = vidRes(2); nBands = vid.NumberOfBands; hImage = image( zeros(imHeight, imWidth, nBands) ); % Specify the size of the axes that contains the image object % so that it displays the image at the right resolution and % centers it in the figure window. figSize = get(hFig,'Position'); figWidth = figSize(3); figHeight = figSize(4); gca.unit = 'pixels'; gca.position = [ ((figWidth - imWidth)/2)... ((figHeight - imHeight)/2)... imWidth imHeight ]; % Set up the update preview window function. setappdata(hImage,'UpdatePreviewWindowFcn',@mypreview_fcn); % Make handle to text label available to update function. setappdata(hImage,'HandleToTimestampLabel',hTextLabel); preview(vid, hImage);
When you run this example, it creates the GUI shown in the following figure.
                    Each time preview receives a video frame, it calls the update
                    preview window function that you specified, which updates the timestamp text
                    label in the GUI.
Custom Preview GUI with Timestamp Text Label
