144 lines
4.6 KiB
ReStructuredText
144 lines
4.6 KiB
ReStructuredText
|
.. Permission is granted to copy, distribute and/or modify this
|
|||
|
.. document under the terms of the GNU Free Documentation License,
|
|||
|
.. Version 1.1 or any later version published by the Free Software
|
|||
|
.. Foundation, with no Invariant Sections, no Front-Cover Texts
|
|||
|
.. and no Back-Cover Texts. A copy of the license is included at
|
|||
|
.. Documentation/media/uapi/fdl-appendix.rst.
|
|||
|
..
|
|||
|
.. TODO: replace it to GFDL-1.1-or-later WITH no-invariant-sections
|
|||
|
|
|||
|
.. _VIDIOC_CROPCAP:
|
|||
|
|
|||
|
********************
|
|||
|
ioctl VIDIOC_CROPCAP
|
|||
|
********************
|
|||
|
|
|||
|
Name
|
|||
|
====
|
|||
|
|
|||
|
VIDIOC_CROPCAP - Information about the video cropping and scaling abilities
|
|||
|
|
|||
|
|
|||
|
Synopsis
|
|||
|
========
|
|||
|
|
|||
|
.. c:function:: int ioctl( int fd, VIDIOC_CROPCAP, struct v4l2_cropcap *argp )
|
|||
|
:name: VIDIOC_CROPCAP
|
|||
|
|
|||
|
|
|||
|
Arguments
|
|||
|
=========
|
|||
|
|
|||
|
``fd``
|
|||
|
File descriptor returned by :ref:`open() <func-open>`.
|
|||
|
|
|||
|
``argp``
|
|||
|
Pointer to struct :c:type:`v4l2_cropcap`.
|
|||
|
|
|||
|
|
|||
|
Description
|
|||
|
===========
|
|||
|
|
|||
|
Applications use this function to query the cropping limits, the pixel
|
|||
|
aspect of images and to calculate scale factors. They set the ``type``
|
|||
|
field of a v4l2_cropcap structure to the respective buffer (stream)
|
|||
|
type and call the :ref:`VIDIOC_CROPCAP` ioctl with a pointer to this
|
|||
|
structure. Drivers fill the rest of the structure. The results are
|
|||
|
constant except when switching the video standard. Remember this switch
|
|||
|
can occur implicit when switching the video input or output.
|
|||
|
|
|||
|
This ioctl must be implemented for video capture or output devices that
|
|||
|
support cropping and/or scaling and/or have non-square pixels, and for
|
|||
|
overlay devices.
|
|||
|
|
|||
|
.. c:type:: v4l2_cropcap
|
|||
|
|
|||
|
.. tabularcolumns:: |p{4.4cm}|p{4.4cm}|p{8.7cm}|
|
|||
|
|
|||
|
.. flat-table:: struct v4l2_cropcap
|
|||
|
:header-rows: 0
|
|||
|
:stub-columns: 0
|
|||
|
:widths: 1 1 2
|
|||
|
|
|||
|
* - __u32
|
|||
|
- ``type``
|
|||
|
- Type of the data stream, set by the application. Only these types
|
|||
|
are valid here: ``V4L2_BUF_TYPE_VIDEO_CAPTURE``, ``V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE``,
|
|||
|
``V4L2_BUF_TYPE_VIDEO_OUTPUT``, ``V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE`` and
|
|||
|
``V4L2_BUF_TYPE_VIDEO_OVERLAY``. See :c:type:`v4l2_buf_type` and the note below.
|
|||
|
* - struct :ref:`v4l2_rect <v4l2-rect-crop>`
|
|||
|
- ``bounds``
|
|||
|
- Defines the window within capturing or output is possible, this
|
|||
|
may exclude for example the horizontal and vertical blanking
|
|||
|
areas. The cropping rectangle cannot exceed these limits. Width
|
|||
|
and height are defined in pixels, the driver writer is free to
|
|||
|
choose origin and units of the coordinate system in the analog
|
|||
|
domain.
|
|||
|
* - struct :ref:`v4l2_rect <v4l2-rect-crop>`
|
|||
|
- ``defrect``
|
|||
|
- Default cropping rectangle, it shall cover the "whole picture".
|
|||
|
Assuming pixel aspect 1/1 this could be for example a 640 × 480
|
|||
|
rectangle for NTSC, a 768 × 576 rectangle for PAL and SECAM
|
|||
|
centered over the active picture area. The same co-ordinate system
|
|||
|
as for ``bounds`` is used.
|
|||
|
* - struct :c:type:`v4l2_fract`
|
|||
|
- ``pixelaspect``
|
|||
|
- This is the pixel aspect (y / x) when no scaling is applied, the
|
|||
|
ratio of the actual sampling frequency and the frequency required
|
|||
|
to get square pixels.
|
|||
|
|
|||
|
When cropping coordinates refer to square pixels, the driver sets
|
|||
|
``pixelaspect`` to 1/1. Other common values are 54/59 for PAL and
|
|||
|
SECAM, 11/10 for NTSC sampled according to [:ref:`itu601`].
|
|||
|
|
|||
|
.. note::
|
|||
|
Unfortunately in the case of multiplanar buffer types
|
|||
|
(``V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE`` and ``V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE``)
|
|||
|
this API was messed up with regards to how the :c:type:`v4l2_cropcap` ``type`` field
|
|||
|
should be filled in. Some drivers only accepted the ``_MPLANE`` buffer type while
|
|||
|
other drivers only accepted a non-multiplanar buffer type (i.e. without the
|
|||
|
``_MPLANE`` at the end).
|
|||
|
|
|||
|
Starting with kernel 4.13 both variations are allowed.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
.. _v4l2-rect-crop:
|
|||
|
|
|||
|
.. tabularcolumns:: |p{4.4cm}|p{4.4cm}|p{8.7cm}|
|
|||
|
|
|||
|
.. flat-table:: struct v4l2_rect
|
|||
|
:header-rows: 0
|
|||
|
:stub-columns: 0
|
|||
|
:widths: 1 1 2
|
|||
|
|
|||
|
* - __s32
|
|||
|
- ``left``
|
|||
|
- Horizontal offset of the top, left corner of the rectangle, in
|
|||
|
pixels.
|
|||
|
* - __s32
|
|||
|
- ``top``
|
|||
|
- Vertical offset of the top, left corner of the rectangle, in
|
|||
|
pixels.
|
|||
|
* - __u32
|
|||
|
- ``width``
|
|||
|
- Width of the rectangle, in pixels.
|
|||
|
* - __u32
|
|||
|
- ``height``
|
|||
|
- Height of the rectangle, in pixels.
|
|||
|
|
|||
|
|
|||
|
Return Value
|
|||
|
============
|
|||
|
|
|||
|
On success 0 is returned, on error -1 and the ``errno`` variable is set
|
|||
|
appropriately. The generic error codes are described at the
|
|||
|
:ref:`Generic Error Codes <gen-errors>` chapter.
|
|||
|
|
|||
|
EINVAL
|
|||
|
The struct :c:type:`v4l2_cropcap` ``type`` is
|
|||
|
invalid.
|
|||
|
|
|||
|
ENODATA
|
|||
|
Cropping is not supported for this input or output.
|