curs_bkgrnd 3x 2024-12-28 ncurses 6.5 Library calls

curs_bkgrnd(3x)                  Library calls                 curs_bkgrnd(3x)




NAME

       bkgrnd,   wbkgrnd,   bkgrndset,  wbkgrndset,  getbkgrnd,  wgetbkgrnd  -
       manipulate background of a curses window of wide characters


SYNOPSIS

       #include <curses.h>

       int bkgrnd(const cchar_t *wch);
       int wbkgrnd(WINDOW *win, const cchar_t *wch);

       void bkgrndset(const cchar_t *wch);
       void wbkgrndset(WINDOW *win, const cchar_t *wch);

       int getbkgrnd(cchar_t *wch);
       int wgetbkgrnd(WINDOW *win, cchar_t *wch);


DESCRIPTION

       Every curses window has a background property.  In the  library's  wide
       configuration,  this  property  is  a  cchar_t  which combines a set of
       attributes with the  background  character  (see  curs_attr(3x)).   The
       background character is a spacing character.

       When  erasing  parts  of  the  screen,  curses fills the cells with the
       background character.  curses also  uses  the  window  background  when
       writing characters to the screen.

       o   The  attribute  part  of the background combines with all non-blank
           characters written into the window, as with  the  wadd_wch(3x)  and
           wins_wch(3x) families of functions.

       o   Both  the  character  and attribute parts of the background combine
           with blank characters that are written into the window.

       The background becomes a property of the character and  moves  with  it
       through any scrolling and insert/delete line/character operations.

       To  the  extent  possible  on  a  given  terminal,  curses displays the
       attributes of the background as the graphic rendition of the  character
       put on the screen.


bkgrnd, wbkgrnd

       bkgrnd  and  wbkgrnd  set  the  background  property  of  stdscr or the
       specified window and then apply this setting to every character cell in
       that window.

       o   The  rendition  of every character in the window changes to the new
           background rendition.

       o   Wherever the former background character appears, it changes to the
           new background character.

       ncurses  updates  the rendition of each character cell by comparing the
       character, non-color attributes, and color pair selection.  The library
       applies  to  following procedure to each cell in the window, whether or
       not it is blank.

       o   ncurses first compares  the  cell's  character  to  the  previously
           specified  background  character; if they match, ncurses writes the
           new background character to the cell.

       o   ncurses then checks if the cell uses color; that is, its color pair
           value  is  nonzero.   If not, it simply replaces the attributes and
           color  pair  in  the  cell  with  those  from  the  new  background
           character.

       o   If  the  cell  uses color, and its background color matches that of
           the current window background, ncurses removes attributes that  may
           have  come  from the current background and adds those from the new
           background.  It finishes by setting the cell's  background  to  use
           the new window background color.

       o   If  the  cell  uses  color, and its background color does not match
           that of the current window background,  ncurses  updates  only  the
           non-color  attributes, first removing those that may have come from
           the current background, and then adding  attributes  from  the  new
           background.

       If the new background's character is nonspacing, ncurses reuses the old
       background character, except for one special  case:  ncurses  treats  a
       background character value of zero (0) as a space.

       If  the  terminal  does  not  support  color,  or if color has not been
       initialized with start_color(3x), ncurses ignores  the  new  background
       character's color attribute.


bkgrndset, wbkgrndset

       bkgrndset  and  wbkgrndset  manipulate the background of the applicable
       window, without updating the character cells as bkgrnd and wbkgrnd  do;
       only future writes reflect the updated background.


getbkgrnd, wgetbkgrnd

       getbkgrnd  and  wgetbkgrnd  respectively  obtain  stdscr's or the given
       window's background character, attributes, and color pair, and store it
       in their wch argument.


RETURN VALUE

       bkgrndset and wbkgrndset do not return a value.

       The  other  functions  return ERR upon failure and OK upon success.  In
       ncurses, failure occurs if

       o   win is NULL, or

       o   wch is NULL.


NOTES

       bkgrnd, bkgrndset, and getbkgrnd may be implemented as macros.

       Unlike their counterparts in the  non-wide  configuration  of  ncurses,
       getbkgrnd  and wgetbkgrnd supply the background character and attribute
       in a modifiable cchar_t parameter, not as the return value.


PORTABILITY

       X/Open Curses, Issue 4 describes  these  functions.   It  specifies  no
       error conditions for them.

       X/Open Curses does not provide details of how the rendition is updated.
       ncurses follows the approach used in SVr4 curses's  non-wide  functions
       for manipulating the window background.


HISTORY

       These functions were initially specified by X/Open Curses, Issue 4.


SEE ALSO

       curs_bkgd(3x)  describes  the  corresponding  functions in the non-wide
       configuration of ncurses.

       curses(3x), curs_add_wch(3x), curs_attr(3x)



ncurses 6.5                       2024-12-28                   curs_bkgrnd(3x)