genode/repos/gems/src/app/backdrop
Norman Feske 366bba0227 Exclude higher-level repos from strict warnings
This is a follow-up commit to "Increase default warning level", which
overrides Genode's new default warning level for targets contained in
higher-level repositories. By explicitly whitelisting all those targets,
we can selectively adjust them to the new strictness over time - by
looking out for 'CC_CXX_WARN_STRICT' in the target description files.

Issue #465
2018-01-17 12:14:36 +01:00
..
genode_logo.png gems: new backdrop application 2014-08-22 16:16:39 +02:00
grid.png gems: new backdrop application 2014-08-22 16:16:39 +02:00
main.cc Follow practices suggested by "Effective C++" 2018-01-17 12:14:35 +01:00
README gems: new backdrop application 2014-08-22 16:16:39 +02:00
target.mk Exclude higher-level repos from strict warnings 2018-01-17 12:14:36 +01:00

This directory contains a backdrop program for Nitpicker. It composes a
background image out of a solid color and an arbitrary number of PNG image
files. It is able to dynamically respond to configuration changes as well
as a changed screen size.


Configuration
~~~~~~~~~~~~~

A typical example configuration looks as follows.

! <config>
!   <libc>
!     <vfs>
!       <rom name="genode_logo.png"/>
!       <rom name="grid.png"/>
!     </vfs>
!   </libc>
!   <fill color="#224433" />
!   <image png="grid.png"        tiled="yes" alpha="200" />
!   <image png="genode_logo.png" anchor="bottom_right" alpha="150"
!                                xpos="-20" ypos="-20" />
! </config>

Backdrop obtains PNG images file from the libc VFS. In the example, the VFS is
configured to present two ROM modules as files in the root directory. Those
files are then referred to by the subsequent '<image>' nodes.

The final background image is generated by applying a number of graphical
operations in the order of their appearance in the configuration. The
'<fill>' operation fills the entire screen with the solid color as
specified by the 'color' attribute. The default color is black.

The '<image>' operation loads a PNG image from the VFS, scales and positions
it according to the '<image>' attributes, and paints it either as tiles
covering the whole screen or as a single image. The supported attributes are

:tiled (default "no"):

  If set to "yes", the image will be used as tile to cover the entire screen.

:alpha (default is opaque):

  A number in the range of 0..255 that specifies the opacity of the image
  when painted.

:anchor (default "center"):

  Defines the screen position that is used as a basis for positioning the
  image. Supported values are "top_left", "top", "top_right", "left",
  "center", "right", "bottom_left", "bottom", and "bottom_right".
  In the example above, the _genode_logo.png_ image will be positioned
  in the bottom-right corner of the screen.

:xpos and ypos (default "0"):

  The 'xpos' and 'ypos' attributes define the position of the image relative
  to the anchor. It is meant for allowing the pixel-perfect fine tuning of
  positions.

:scale (no scaling by default):

  The 'attribute' specifies the way of how the image should be adjusted to
  the screen size by the means of proportional scaling. Possible values are
  "fit" and "zoom". The former scales the image such that the entire image
  is visible on screen. The latter makes sure that the entire screen is
  filled with (a viewport of) the image. When using the "zoom" value, the
  viewport can be defined via the 'anchor', 'xpos', and 'ypos' attributes.


Example
~~~~~~~

Please refer to the _gems/run/wm.run_ script for a practical example of
using the backdrop.