mirror of
https://github.com/dankamongmen/notcurses.git
synced 2024-11-08 01:10:23 +00:00
91 lines
2.8 KiB
Markdown
91 lines
2.8 KiB
Markdown
% notcurses_multiselector(3)
|
|
% nick black <nickblack@linux.com>
|
|
% v2.3.0
|
|
|
|
# NAME
|
|
|
|
notcurses_multiselector - high level widget for selecting from a set
|
|
|
|
# SYNOPSIS
|
|
|
|
**#include <notcurses/notcurses.h>**
|
|
|
|
```c
|
|
struct ncplane;
|
|
struct notcurses;
|
|
struct ncmultiselector;
|
|
|
|
struct ncmselector_item {
|
|
char* option;
|
|
char* desc;
|
|
bool selected;
|
|
};
|
|
|
|
typedef struct ncmultiselector_options {
|
|
char* title; // title may be NULL, inhibiting riser
|
|
char* secondary; // secondary may be NULL
|
|
char* footer; // footer may be NULL
|
|
struct ncmselector_item* items; // initial items, statuses
|
|
// default item (selected at start)
|
|
unsigned defidx;
|
|
// maximum number of options to display at once
|
|
unsigned maxdisplay;
|
|
// exhaustive styling options
|
|
uint64_t opchannels; // option channels
|
|
uint64_t descchannels; // description channels
|
|
uint64_t titlechannels;// title channels
|
|
uint64_t footchannels; // secondary and footer channels
|
|
uint64_t boxchannels; // border channels
|
|
uint64_t flags; // bitfield over NCMULTISELECTOR_OPTION_*
|
|
} ncmultiselector_options;
|
|
```
|
|
|
|
**struct ncmultiselector* ncmultiselector_create(struct ncplane* ***n***, const ncmultiselector_options* ***opts***);**
|
|
|
|
**int ncmultiselector_selected(bool* ***selected***, unsigned ***n***);**
|
|
|
|
**struct ncplane* ncmultiselector_plane(struct ncmultiselector* ***n***);**
|
|
|
|
**bool ncmultiselector_offer_input(struct ncmultiselector* ***n***, const ncinput* ***nc***);**
|
|
|
|
**void ncmultiselector_destroy(struct ncmultiselector* ***n***);**
|
|
|
|
# DESCRIPTION
|
|
|
|
# NOTES
|
|
|
|
The **ncplane** **n** provided to **ncmultiselector_create** must not be
|
|
**NULL**. It will be freely resized by the new **ncmultiselector**.
|
|
|
|
**ncmultiselector_selected** returns the index of the option currently
|
|
highlighted. It stores to the **n**-ary bitmap pointed to by **selected**
|
|
based on the currently-selected options.
|
|
|
|
**ncmultiselector_plane** will return the **ncplane** on which the widget is
|
|
drawn.
|
|
|
|
Input should be run through **ncmultiselector_offer_input** to take advantage
|
|
of common controls. It will handle the up and down arrows, along with PageUp
|
|
and PageDown. If the mouse is enabled, the mouse scrollwheel and mouse clicks
|
|
on the scroll arrows will be handled.
|
|
|
|
**ncmultiselector_destroy** destroys the backing **ncplane**, as does
|
|
**ncmultiselector_create** in the event of any error.
|
|
|
|
# RETURN VALUES
|
|
|
|
**ncmultiselector_create** returns **NULL** on an error, in which case the
|
|
passed **ncplane** is destroyed.
|
|
|
|
**ncmultiselector_selected** returns -1 if there are no items, or if **n** is
|
|
not equal to the number of items. It otherwise returns the index of the
|
|
currently highlighted option, and writes a bitmap to **selected** based off
|
|
the selected items.
|
|
|
|
# SEE ALSO
|
|
|
|
**notcurses(3)**,
|
|
**notcurses_input(3)**,
|
|
**notcurses_plane(3)**
|
|
**notcurses_selector(3)**
|