Re: [PATCH 01/13] V4L: Extend V4L2_CID_COLORFX with more image effects
Hi Sylwester!
On Friday, April 27, 2012 11:52:54 Sylwester Nawrocki wrote:
> This patch adds definition of additional color effects:
> - V4L2_COLORFX_AQUA,
> - V4L2_COLORFX_ART_FREEZE,
> - V4L2_COLORFX_SILHOUETTE,
> - V4L2_COLORFX_SOLARIZATION,
> - V4L2_COLORFX_ANTIQUE,
> - V4L2_COLORFX_ARBITRARY_CBCR.
>
> The control's type in the documentation is changed from 'enum' to 'menu'
> - V4L2_CID_COLORFX has always been a menu, not an integer type control.
>
> The V4L2_COLORFX_ARBITRARY_CBCR option enables custom color effects,
> which are impossible or impractical to define as menu items. The
> V4L2_CID_BLUE_BALANCE and V4L2_CID_RED_BALANCE controls allow in this
> case to configure the Cb, Cr coefficients.
So this just hijacks the RED/BLUE_BALANCE controls for a different purpose?
If I understand this 'effect' correctly it just replaces the Cb and Cr
coefficients with fixed values, basically giving you a B&W picture (the Y
coefficient), except that it is really a 'Black&FixedColor' picture.
I think you should add a new control for setting this. V4L2_CID_COLORFX_COLOR
or something.
Regards,
Hans
>
> Signed-off-by: Sylwester Nawrocki <s.nawrocki@xxxxxxxxxxx>
> Signed-off-by: Kyungmin Park <kyungmin.park@xxxxxxxxxxx>
> ---
> Documentation/DocBook/media/v4l/compat.xml | 10 +++
> Documentation/DocBook/media/v4l/controls.xml | 92 ++++++++++++++++++++++----
> Documentation/DocBook/media/v4l/v4l2.xml | 5 +-
> drivers/media/video/v4l2-ctrls.c | 6 ++
> include/linux/videodev2.h | 26 +++++---
> 5 files changed, 114 insertions(+), 25 deletions(-)
>
> diff --git a/Documentation/DocBook/media/v4l/compat.xml b/Documentation/DocBook/media/v4l/compat.xml
> index 87339b2..a6a9c5c 100644
> --- a/Documentation/DocBook/media/v4l/compat.xml
> +++ b/Documentation/DocBook/media/v4l/compat.xml
> @@ -2422,6 +2422,16 @@ details.</para>
> &VIDIOC-SUBDEV-G-SELECTION; and
> &VIDIOC-SUBDEV-S-SELECTION;.</para>
> </listitem>
> + <listitem>
> + <para> Added <constant>V4L2_COLORFX_ANTIQUE</constant>,
> + <constant>V4L2_COLORFX_ART_FREEZE</constant>,
> + <constant>V4L2_COLORFX_AQUA</constant>,
> + <constant>V4L2_COLORFX_SILHOUETTE</constant>,
> + <constant>V4L2_COLORFX_SOLARIZATION</constant>,
> + <constant>V4L2_COLORFX_VIVID</constant> and
> + <constant>V4L2_COLORFX_ARBITRARY_CBCR</constant> menu items
> +to the <constant>V4L2_CID_COLORFX</constant> control.</para>
> + </listitem>
> </orderedlist>
> </section>
>
> diff --git a/Documentation/DocBook/media/v4l/controls.xml b/Documentation/DocBook/media/v4l/controls.xml
> index 5038a3a..8b604b0 100644
> --- a/Documentation/DocBook/media/v4l/controls.xml
> +++ b/Documentation/DocBook/media/v4l/controls.xml
> @@ -284,19 +284,85 @@ minimum value disables backlight compensation.</entry>
> </row>
> <row id="v4l2-colorfx">
> <entry><constant>V4L2_CID_COLORFX</constant></entry>
> - <entry>enum</entry>
> - <entry>Selects a color effect. Possible values for
> -<constant>enum v4l2_colorfx</constant> are:
> -<constant>V4L2_COLORFX_NONE</constant> (0),
> -<constant>V4L2_COLORFX_BW</constant> (1),
> -<constant>V4L2_COLORFX_SEPIA</constant> (2),
> -<constant>V4L2_COLORFX_NEGATIVE</constant> (3),
> -<constant>V4L2_COLORFX_EMBOSS</constant> (4),
> -<constant>V4L2_COLORFX_SKETCH</constant> (5),
> -<constant>V4L2_COLORFX_SKY_BLUE</constant> (6),
> -<constant>V4L2_COLORFX_GRASS_GREEN</constant> (7),
> -<constant>V4L2_COLORFX_SKIN_WHITEN</constant> (8) and
> -<constant>V4L2_COLORFX_VIVID</constant> (9).</entry>
> + <entry>menu</entry>
> + <entry>Selects a color effect. The following values are defined:
> + </entry>
> + </row><row>
> + <entry></entry>
> + <entry></entry>
> + <entrytbl spanname="descr" cols="2">
> + <tbody valign="top">
> + <row>
> + <entry><constant>V4L2_COLORFX_NONE</constant> </entry>
> + <entry>Color effect is disabled.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_ANTIQUE</constant> </entry>
> + <entry>An aging (old photo) effect.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_ART_FREEZE</constant> </entry>
> + <entry>Frost color effect.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_AQUA</constant> </entry>
> + <entry>Water color, cool tone.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_BW</constant> </entry>
> + <entry>Black and white.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_EMBOSS</constant> </entry>
> + <entry>Emboss, the highlights and shadows replace light/dark boundaries
> + and low contrast areas are set to a gray background.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_GRASS_GREEN</constant> </entry>
> + <entry>Grass green.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_NEGATIVE</constant> </entry>
> + <entry>Negative.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_SEPIA</constant> </entry>
> + <entry>Sepia tone.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_SKETCH</constant> </entry>
> + <entry>Sketch.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_SKIN_WHITEN</constant> </entry>
> + <entry>Skin whiten.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_SKY_BLUE</constant> </entry>
> + <entry>Sky blue.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_SOLARIZATION</constant> </entry>
> + <entry>Solarization, the image is partially reversed in tone,
> + only color values above or below a certain threshold are inverted.
> + </entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_SILHOUETTE</constant> </entry>
> + <entry>Silhouette (outline).</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_VIVID</constant> </entry>
> + <entry>Vivid colors.</entry>
> + </row>
> + <row>
> + <entry><constant>V4L2_COLORFX_ARBITRARY_CBCR</constant> </entry>
> + <entry>Arbitrary chroma components. The Cb, Cr coefficients
> +are determined by <constant>V4L2_CID_BLUE_BALANCE</constant> and <constant>
> +V4L2_CID_RED_BALANCE</constant> control respectively.</entry>
> + </row>
> + </tbody>
> + </entrytbl>
> </row>
> <row>
> <entry><constant>V4L2_CID_ROTATE</constant></entry>
> diff --git a/Documentation/DocBook/media/v4l/v4l2.xml b/Documentation/DocBook/media/v4l/v4l2.xml
> index fbf808d..e4e65d0 100644
> --- a/Documentation/DocBook/media/v4l/v4l2.xml
> +++ b/Documentation/DocBook/media/v4l/v4l2.xml
> @@ -141,9 +141,10 @@ applications. -->
> <revision>
> <revnumber>3.5</revnumber>
> <date>2012-04-02</date>
> - <authorinitials>sa</authorinitials>
> + <authorinitials>sa, sn</authorinitials>
> <revremark>Added V4L2_CTRL_TYPE_INTEGER_MENU and V4L2 subdev
> - selections API.
> + selections API. Corrected and extended the V4L2_CID_COLORFX
> + control description.
> </revremark>
> </revision>
>
> diff --git a/drivers/media/video/v4l2-ctrls.c b/drivers/media/video/v4l2-ctrls.c
> index c93a979..25132ec 100644
> --- a/drivers/media/video/v4l2-ctrls.c
> +++ b/drivers/media/video/v4l2-ctrls.c
> @@ -241,6 +241,12 @@ const char * const *v4l2_ctrl_get_menu(u32 id)
> "Grass Green",
> "Skin Whiten",
> "Vivid",
> + "Aqua",
> + "Art Freeze",
> + "Silhouette",
> + "Solarization",
> + "Antique",
> + "Arbitrary Cb/Cr",
> NULL
> };
> static const char * const tune_preemphasis[] = {
> diff --git a/include/linux/videodev2.h b/include/linux/videodev2.h
> index 5a09ac3..764f300 100644
> --- a/include/linux/videodev2.h
> +++ b/include/linux/videodev2.h
> @@ -1241,16 +1241,22 @@ enum v4l2_power_line_frequency {
> #define V4L2_CID_COLOR_KILLER (V4L2_CID_BASE+30)
> #define V4L2_CID_COLORFX (V4L2_CID_BASE+31)
> enum v4l2_colorfx {
> - V4L2_COLORFX_NONE = 0,
> - V4L2_COLORFX_BW = 1,
> - V4L2_COLORFX_SEPIA = 2,
> - V4L2_COLORFX_NEGATIVE = 3,
> - V4L2_COLORFX_EMBOSS = 4,
> - V4L2_COLORFX_SKETCH = 5,
> - V4L2_COLORFX_SKY_BLUE = 6,
> - V4L2_COLORFX_GRASS_GREEN = 7,
> - V4L2_COLORFX_SKIN_WHITEN = 8,
> - V4L2_COLORFX_VIVID = 9,
> + V4L2_COLORFX_NONE = 0,
> + V4L2_COLORFX_BW = 1,
> + V4L2_COLORFX_SEPIA = 2,
> + V4L2_COLORFX_NEGATIVE = 3,
> + V4L2_COLORFX_EMBOSS = 4,
> + V4L2_COLORFX_SKETCH = 5,
> + V4L2_COLORFX_SKY_BLUE = 6,
> + V4L2_COLORFX_GRASS_GREEN = 7,
> + V4L2_COLORFX_SKIN_WHITEN = 8,
> + V4L2_COLORFX_VIVID = 9,
> + V4L2_COLORFX_AQUA = 10,
> + V4L2_COLORFX_ART_FREEZE = 11,
> + V4L2_COLORFX_SILHOUETTE = 12,
> + V4L2_COLORFX_SOLARIZATION = 13,
> + V4L2_COLORFX_ANTIQUE = 14,
> + V4L2_COLORFX_ARBITRARY_CBCR = 15,
> };
> #define V4L2_CID_AUTOBRIGHTNESS (V4L2_CID_BASE+32)
> #define V4L2_CID_BAND_STOP_FILTER (V4L2_CID_BASE+33)
>
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
[Linux Input]
[Video for Linux]
[Mplayer Users]
[Linux USB Devel]
[Linux Audio Users]
[Photos]
[Yosemite Photos]
[Linux Kernel]
[Linux SCSI]
[XFree86]
[Devices]
[Yosemite Backpacking]