notcurses/doc/man/man3/notcurses_directmode.3.md
nick black 70f062aff5
v1.7.1
2020-08-31 21:49:39 -04:00

128 lines
4.6 KiB
Markdown

% ncdirect_init(3)
% nick black <nickblack@linux.com>
% v1.7.1
# NAME
ncdirect_init - minimal notcurses instances for styling text
# SYNOPSIS
**#include <notcurses/direct.h>**
**struct ncdirect* ncdirect_init(const char* termtype, FILE* fp, uint64_t flags);**
**unsigned ncdirect_palette_size(const struct ncdirect* nc);**
**int ncdirect_bg_rgb8(struct ncdirect* nc, unsigned r, unsigned g, unsigned b);**
**int ncdirect_fg_rgb8(struct ncdirect* nc, unsigned r, unsigned g, unsigned b);**
**int ncdirect_fg(struct ncdirect* nc, unsigned rgb);**
**int ncdirect_bg(struct ncdirect* nc, unsigned rgb);**
**int ncdirect_fg_default(struct ncdirect* nc);**
**int ncdirect_bg_default(struct ncdirect* nc);**
**int ncdirect_dim_x(const struct ncdirect* nc);**
**int ncdirect_dim_y(const struct ncdirect* nc);**
**int ncdirect_styles_set(struct ncdirect* n, unsigned stylebits);**
**int ncdirect_styles_on(struct ncdirect* n, unsigned stylebits);**
**int ncdirect_styles_off(struct ncdirect* n, unsigned stylebits);**
**int ncdirect_clear(struct ncdirect* nc)**
**int ncdirect_stop(struct ncdirect* nc);**
**int ncdirect_cursor_move_yx(struct ncdirect* n, int y, int x);**
**int ncdirect_cursor_enable(struct ncdirect* nc);**
**int ncdirect_cursor_disable(struct ncdirect* nc);**
**int ncdirect_cursor_up(struct ncdirect* nc, int num);**
**int ncdirect_cursor_left(struct ncdirect* nc, int num);**
**int ncdirect_cursor_right(struct ncdirect* nc, int num);**
**int ncdirect_cursor_down(struct ncdirect* nc, int num);**
**int ncdirect_putstr(struct ncdirect* nc, uint64_t channels, const char* utf8);**
**bool ncdirect_canopen_images(const struct ncdirect* n);**
**bool ncdirect_canutf8(const struct ncdirect* n);**
**int ncdirect_hline_interp(struct ncdirect* n, const char* egc, int len, uint64_t h1, uint64_t h2);**
**int ncdirect_vline_interp(struct ncdirect* n, const char* egc, int len, uint64_t h1, uint64_t h2);**
**int ncdirect_box(struct ncdirect* n, uint64_t ul, uint64_t ur, uint64_t ll, uint64_t lr, const wchar_t* wchars, int ylen, int xlen, unsigned ctlword);**
**int ncdirect_rounded_box(struct ncdirect* n, uint64_t ul, uint64_t ur, uint64_t ll, uint64_t lr, int ylen, int xlen, unsigned ctlword);**
**int ncdirect_double_box(struct ncdirect* n, uint64_t ul, uint64_t ur, uint64_t ll, uint64_t lr, int ylen, int xlen, unsigned ctlword);**
**int ncdirect_render_image(struct ncdirect* n, const char* filename, ncblitter_e blitter, ncscale_e scale);**
# DESCRIPTION
**ncdirect_init** prepares the **FILE** provided as **fp** (which must
be attached to a terminal) for colorizing and styling. On success, a pointer to
a valid **struct ncdirect** is returned. **NULL** is returned on failure.
Before the process exits, **ncdirect_stop** should be called to reset the
terminal and free up resources. **ncdirect_init** places the terminal into
"cbreak" (also known as "rare") mode, disabling line-buffering and echo of
input. **ncdirect_stop** restores the terminal state as it was when the
corresponding **ncdirect_init** call was made.
The **flags** parameter to **ncdirect_init** does not yet have any flags
defined, and should be passed as 0 for now.
An appropriate **terminfo(5)** entry must exist for the terminal. This entry is
usually selected using the value of the **TERM** environment variable (see
**getenv(3)**), but a non-**NULL** value for **termtype** will override this. An
invalid terminfo specification can lead to reduced performance, reduced
display capabilities, and/or display errors. notcurses natively targets
24bpp/8bpc RGB color, and it is thus desirable to use a terminal with the
**rgb** capability (e.g. xterm's **xterm-direct**).
**ncdirect_dim_x** returns the current number of columns, and **ncdirect_dim_y**
the current number of rows.
**ncdirect_clear** clears the screen using a control code if one exists in
terminfo. Otherwise, it prints successive newlines to scroll everything off.
**ncdirect_cursor_move_yx** moves the cursor to the specified coordinate. -1 can
be specified for either **y** or **x** to leave that axis unchanged.
**ncdirect_enable_cursor** and **ncdirect_disable_cursor** always flush the
output stream, taking effect immediately.
**ncdirect_cursor_up** and friends all move relative to the current position.
Attempting to e.g. move up while on the top row will return 0, but have no
effect.
# RETURN VALUES
**ncdirect_init** returns **NULL** on failure. Otherwise, the return value
points to a valid **struct ncdirect**, which can be used until it is provided
to **ncdirect_stop**.
All other functions return 0 on success, and non-zero on error.
# SEE ALSO
**getenv(3)**,
**termios(3)**,
**notcurses(3)**,
**notcurses_plane(3)**,
**terminfo(5)**