2020-10-20 10:40:45 +02:00
|
|
|
.. _nxgraphics:
|
|
|
|
|
2020-07-21 00:18:26 +02:00
|
|
|
=====================
|
|
|
|
NX Graphics Subsystem
|
|
|
|
=====================
|
|
|
|
|
|
|
|
This document describes the tiny graphics support included in NuttX. It
|
|
|
|
includes an overview description of that graphics support, detailed
|
|
|
|
descriptions of the NuttX graphics APIs, and discussion of code
|
|
|
|
organization, and OS configuration options.
|
|
|
|
|
|
|
|
.. figure:: NuttXScreenShot.jpg
|
|
|
|
:align: center
|
2020-10-18 18:48:44 +02:00
|
|
|
|
2020-07-21 00:18:26 +02:00
|
|
|
**Figure 1**. This screnshot shows the final frame for the NuttX example
|
|
|
|
at ``apps/examples/nx`` running on the simulated, Linux x86 platform with
|
|
|
|
simulated framebuffer output to an X window. This picture shows to framed window
|
|
|
|
with (blank) toolbars. Each window has displayed text as received from the
|
|
|
|
NX keyboard interface The second window has just been raised to the top of the display.
|
|
|
|
|
|
|
|
Objectives
|
|
|
|
==========
|
|
|
|
|
|
|
|
The objective of this development was to provide a tiny windowing system
|
|
|
|
in the spirit of X, but greatly scaled down and appropriate for most
|
|
|
|
resource-limited embedded environments. The current NX implementation
|
|
|
|
supports the general following, high-level features:
|
|
|
|
|
|
|
|
- **Virtual Vertical Graphics Space**. Windows that reside in a
|
|
|
|
virtual, *vertical* space so that it makes sense to talk about one
|
|
|
|
window being on top of another and obscuring the window below it.
|
|
|
|
- **Client/Server Model**. A standard client server/model was adopted.
|
|
|
|
NX may be considered a server and other logic that presents the
|
|
|
|
windows are NX clients.
|
|
|
|
- **Multi-User Support**. NX includes *front-end* logic to support a
|
|
|
|
separate NX server thread that can serve multiple NX client threads.
|
|
|
|
The NX is a server thread/daemon the serializes graphics operations
|
|
|
|
from multiple clients.
|
|
|
|
- **Minimal Graphics Toolset**. The actual implementation of the
|
|
|
|
graphics operations is performed by common, *back-end* logic. This
|
|
|
|
back-end supports only a primitive set of graphic and rendering
|
|
|
|
operations.
|
|
|
|
- **Device Interface**. NX supports any graphics device either of two
|
|
|
|
device interfaces:
|
|
|
|
|
|
|
|
- Any device with random access video memory using the NuttX
|
|
|
|
framebuffer driver interface (see ``include/nuttx/video/fb.h``).
|
|
|
|
- Any LCD-like device than can accept raster line *runs* through a
|
|
|
|
parallel or serial interface (see ``include/nuttx/lcd/lcd.h``). By
|
|
|
|
default, NX is configured to use the frame buffer driver unless
|
|
|
|
``CONFIG_NX_LCDDRIVER`` is defined =y in your NuttX configuration
|
|
|
|
file.
|
|
|
|
|
|
|
|
- **Transparent to NX Client**. The window client on "sees" the
|
|
|
|
sub-window that is operates in and does not need to be concerned with
|
|
|
|
the virtual, vertical space (other that to respond to *redraw*
|
|
|
|
requests from NX when needed).
|
|
|
|
- **Framed Windows and Toolbars**. NX also adds the capability to
|
|
|
|
support windows with frames and toolbars on top of the basic
|
|
|
|
windowing support. These are windows such as those shown in the
|
|
|
|
`screenshot <#screenshot>`__ above. These framed windows sub-divide
|
|
|
|
one one window into three relatively independent subwindows: A frame,
|
|
|
|
the contained window and an (optional) toolbar window.
|
|
|
|
- **Mouse Support**. NX provides support for a mouse or other X/Y
|
|
|
|
pointing devices. APIs are provided to allow external devices to give
|
|
|
|
X/Y position information and mouse button presses to NX. NX will then
|
|
|
|
provide the mouse input to the relevant window clients via callbacks.
|
|
|
|
Client windows only receive the mouse input callback if the mouse is
|
|
|
|
positioned over a visible portion of the client window; X/Y position
|
|
|
|
is provided to the client in the relative coordinate system of the
|
|
|
|
client window.
|
|
|
|
- **Keyboard input**. NX also supports keyboard/keypad devices. APIs
|
|
|
|
are provided to allow external devices to give keypad information to
|
|
|
|
NX. NX will then provide the mouse input to the top window on the
|
|
|
|
display (the window that has the *focus*) via a callback function.
|
|
|
|
|
|
|
|
Organization
|
|
|
|
============
|
|
|
|
|
|
|
|
NX is organized into 6 (and perhaps someday 7 or 8) logical modules.
|
|
|
|
These logical modules also correspond to the directory organization.
|
|
|
|
That NuttX directory organization is discussed in `Appendix
|
|
|
|
B <#grapicsdirs>`__ of this document. The logic modules are discussed in
|
|
|
|
the following sub-paragraphs.
|
|
|
|
|
2023-05-16 06:04:16 +02:00
|
|
|
.. figure:: NXOrganization.png
|
2020-07-21 00:18:26 +02:00
|
|
|
:align: center
|
|
|
|
|
|
|
|
NX Graphics Library (``NXGL``)
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
NXGLIB is a standalone library that contains low-level graphics
|
|
|
|
utilities and direct framebuffer or LCD rendering logic. NX is built on
|
|
|
|
top NXGLIB.
|
|
|
|
|
|
|
|
NX (``NXSU`` and ``NXMU``)
|
|
|
|
--------------------------
|
|
|
|
|
|
|
|
NX is the tiny NuttX windowing system for raw windows (i.e., simple
|
|
|
|
regions of graphics memory). NX includes a small-footprint, multi-user
|
|
|
|
implementation (NXMU as described below). NX can be used without
|
|
|
|
NxWidgets and without NXTOOLKIT for raw window displays.
|
|
|
|
|
|
|
|
:sup:`1`\ NXMU and NXSU are interchangeable other than (1) certain
|
|
|
|
start-up and initialization APIs (as described below), and (2) timing.
|
|
|
|
With NXSU, NX APIs execute immediately; with NXMU, NX APIs defer and
|
|
|
|
serialize the operations and, hence, introduce different timing and
|
|
|
|
potential race conditions that you would not experience with NXSU.
|
|
|
|
|
|
|
|
**NXNULL?** At one time, I also envisioned a *NULL* front-end that did
|
|
|
|
not support windowing at all but, rather, simply provided the entire
|
|
|
|
framebuffer or LCD memory as one dumb window. This has the advantage
|
|
|
|
that the same NX APIs can be used on the one dumb window as for the
|
|
|
|
other NX windows. This would be in the NuttX spirit of scalability.
|
|
|
|
|
|
|
|
However, the same end result can be obtained by using the
|
|
|
|
```nx_requestbkgd()`` <#nxrequestbkgd>`__ API. It still may be possible
|
|
|
|
to reduce the footprint in this usage case by developing and even
|
|
|
|
thinner NXNULL front-end. That is a possible future development.
|
|
|
|
|
|
|
|
NX Tool Kit (``NXTK``)
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
NXTK is a s set of C graphics tools that provide higher-level window
|
|
|
|
drawing operations. This is the module where the framed windows and
|
|
|
|
toolbar logic is implemented. NXTK is built on top of NX and does not
|
|
|
|
depend on NxWidgets.
|
|
|
|
|
|
|
|
NX Fonts Support (``NXFONTS``)
|
|
|
|
------------------------------
|
|
|
|
|
|
|
|
A set of C graphics tools for present (bitmap) font images. The font
|
|
|
|
implementation is at a very low level or graphics operation, comparable
|
|
|
|
to the logic in NXGLIB. NXFONTS does not depend on any NX module other
|
|
|
|
than some utilities and types from NXGLIB.
|
|
|
|
|
|
|
|
NX Widgets (``NxWidgets``)
|
|
|
|
--------------------------
|
|
|
|
|
2020-10-20 10:40:45 +02:00
|
|
|
:ref:`NxWidgets <nxwidgets>` is a higher level, C++, object-oriented
|
2020-07-21 00:18:26 +02:00
|
|
|
library for object-oriented access to graphical "widgets." NxWidgets is
|
|
|
|
provided as a separate library in the ``apps/`` repository NxWidgets is
|
|
|
|
built on top of the core NuttX graphics subsystem, but is part of the
|
|
|
|
application space rather than part of the core OS graphics subsystems.
|
|
|
|
|
|
|
|
Terminal Driver (``NxTerm``)
|
|
|
|
----------------------------
|
|
|
|
|
|
|
|
NxTerm is a write-only character device (not shown) that is built on top
|
|
|
|
of an NX window. This character device can be used to provide ``stdout``
|
|
|
|
and ``stderr`` and, hence, can provide the output side of NuttX console.
|
|
|
|
).
|
|
|
|
|
|
|
|
NX Header Files
|
|
|
|
===============
|
|
|
|
|
2020-10-18 18:48:44 +02:00
|
|
|
``include/nuttx/nx/nxglib.h``
|
2020-07-21 00:18:26 +02:00
|
|
|
Describes the NXGLIB C interfaces
|
2020-10-18 18:48:44 +02:00
|
|
|
``include/nuttx/nx/nx.h``
|
2020-07-21 00:18:26 +02:00
|
|
|
Describes the NX C interfaces
|
2020-10-18 18:48:44 +02:00
|
|
|
``include/nutt/nxtk.h``
|
2020-07-21 00:18:26 +02:00
|
|
|
Describe the NXTOOLKIT C interfaces
|
2020-10-18 18:48:44 +02:00
|
|
|
``include/nutt/nxfont.h``
|
2020-07-21 00:18:26 +02:00
|
|
|
Describe sthe NXFONT C interfaces
|
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:Caption: User APIs
|
2020-10-18 18:48:44 +02:00
|
|
|
|
2020-07-21 00:18:26 +02:00
|
|
|
nxgl.rst
|
|
|
|
nx.rst
|
|
|
|
nxtk.rst
|
|
|
|
nxfonts.rst
|
|
|
|
nxcursor.rst
|
|
|
|
sample.rst
|
|
|
|
appendix.rst
|
2020-10-18 18:48:44 +02:00
|
|
|
|