4#ifndef FTXUI_DOM_ELEMENTS_HPP
5#define FTXUI_DOM_ELEMENTS_HPP
65 Color unselected_color,
66 Color selected_color);
69 Color unselected_color,
70 Color selected_color);
200#include "ftxui/dom/take_any_args.hpp"
Decorator bgcolor(Color)
使用背景顏色進行裝飾。
Element window(Element title, Element content, BorderStyle border=ROUNDED)
繪製帶有標題和邊框的視窗。
Element borderDouble(Element)
在元素周圍繪製雙線邊框。
Element focusCursorBarBlinking(Element)
與 focus 相同,但將游標形狀設置為閃爍條狀。
Element xflex(Element)
在 X 軸上盡可能擴展/在需要時最小化。
Element gaugeDirection(float progress, Direction direction)
繪製一個指定方向的高解析度進度條。
Decorator focusPositionRelative(float x, float y)
在 frame 內部使用,這會強制視圖滾動到給定位置。該位置以請求大小的比例表示。
Element separatorStyled(BorderStyle)
在兩個元素之間繪製垂直或水平分隔線。
Element xflex_grow(Element)
在 X 軸上盡可能擴展。
Element underlinedDouble(Element)
對文字應用雙底線。
Element clear_under(Element element)
在繪製 |child| 之前,清除下方的像素。這在與 dbox 結合使用時非常有用。
Element borderDashed(Element)
在元素周圍繪製虛線邊框。
Element separatorEmpty()
使用 EMPTY 樣式在兩個元素之間繪製垂直或水平分隔線。
Element vscroll_indicator(Element)
在右側顯示一個垂直捲軸。 顏色與內容一致。
Element nothing(Element element)
一個什麼都不做的裝飾器。
Decorator size(WidthOrHeight, Constraint, int value)
限制元素的大小。
Direction
Direction 是一個列舉,表示四個主要方向。
Element flex(Element)
使子元素按比例擴展以佔據容器中剩餘的空間。
Element paragraphAlignRight(const std::string &text)
回傳一個在多行上繪製段落並靠右對齊的元素。
Element gaugeRight(float progress)
繪製一個從左到右進展的高解析度進度條。
Element focusCursorUnderlineBlinking(Element)
與 focus 相同,但將游標形狀設置為閃爍底線。
Element bold(Element)
使用粗體字型,用於需要更多強調的元素。
Element separatorLight()
使用 LIGHT 樣式在兩個元素之間繪製垂直或水平分隔線。
Element spinner(int charset_index, size_t image_index)
用於表示時間和/或事件的效果。這將顯示 一個 ASCII 藝術「影片」。
Element borderRounded(Element)
在元素周圍繪製圓角邊框。
Element yflex(Element)
在 Y 軸上盡可能擴展/在需要時最小化。
Element flex_shrink(Element)
在需要時最小化。
Element focusCursorBar(Element)
與 focus 相同,但將游標形狀設置為靜止條狀。
Element focusCursorBlock(Element)
與 focus 相同,但將游標形狀設置為靜止方塊。
Element underlined(Element)
為給定元素加上底線。
Element center(Element)
水平與垂直置中一個元素。
Element focusCursorUnderline(Element)
與 focus 相同,但將游標形狀設置為靜止底線。
Element borderHeavy(Element)
在元素周圍繪製粗邊框。
Element inverted(Element)
添加一個濾鏡,它將反轉前景和背景 顏色。
Element paragraphAlignCenter(const std::string &text)
回傳一個在多行上繪製段落並置中對齊的元素。
Element gaugeUp(float progress)
繪製一個從下到上進展的高解析度進度條。
Element text(std::wstring text)
顯示一段 Unicode 文字。
Element align_right(Element)
將元素靠右對齊。
Decorator focusPosition(int x, int y)
在 frame 內部使用,這會強制視圖滾動到給定位置。該位置以單元格數表示。
Element yflex_grow(Element)
在 Y 軸上盡可能擴展。
Element hscroll_indicator(Element)
在底部顯示一個水平捲軸。 顏色與內容一致。
Element flex_grow(Element)
盡可能擴展。
Element separatorDashed()
使用 DASHED 樣式在兩個元素之間繪製垂直或水平分隔線。
Element notflex(Element)
使元素不可伸縮。
Element strikethrough(Element)
對文字應用刪除線。
Element italic(Element)
將文字套用斜體。
Element dbox(Elements)
將多個元素堆疊在一起。
Element xflex_shrink(Element)
在 X 軸上在需要時最小化。
Element gaugeLeft(float progress)
繪製一個從右到左進展的高解析度進度條。
Element separatorCharacter(std::string)
在兩個元素之間繪製垂直或水平分隔線。
Element vtext(std::wstring text)
垂直顯示一段 Unicode 文字。
Element borderLight(Element)
在元素周圍繪製細邊框。
Element focus(Element)
將 child 設置為其同級元素中被聚焦的元素。
Element paragraphAlignLeft(const std::string &text)
回傳一個在多行上繪製段落並靠左對齊的元素。
Decorator borderWith(const Pixel &)
與 border 相同,但在元素周圍使用恆定的像素。
Decorator borderStyled(BorderStyle)
與 border 相同,但具有不同的樣式。
Element separator()
在兩個元素之間繪製垂直或水平分隔線。
Element filler()
一個元素,它會按比例擴展以佔據容器中剩餘的空間。
Element dim(Element)
使用淺色字體,適用於不那麼強調的元素。
Element automerge(Element child)
啟用字符自動與附近其他字符合併。
Decorator hyperlink(std::string link)
使用超連結裝飾。 當用戶點擊時,連結將被開啟。 此功能僅在有限的終端模擬器中受支援。 List: https://github.com/Alhadis/OSC8-Adoption/
Element blink(Element)
繪製的文字在可見和隱藏之間交替。
Element vcenter(Element)
垂直置中一個元素。
Element separatorDouble()
使用 DOUBLE 樣式在兩個元素之間繪製垂直或水平分隔線。
Element focusCursorBlockBlinking(Element)
與 focus 相同,但將游標形狀設置為閃爍方塊。
Element gauge(float progress)
繪製一個高解析度進度條。
Element paragraphAlignJustify(const std::string &text)
回傳一個在多行上繪製段落並使用左右對齊的元素。
Element border(Element)
在元素周圍繪製邊框。
Element separatorHeavy()
使用 HEAVY 樣式在兩個元素之間繪製垂直或水平分隔線。
Element borderEmpty(Element)
在元素周圍繪製空邊框。
Decorator color(Color)
使用前景顏色進行裝飾。
Element yflex_shrink(Element)
在 Y 軸上在需要時最小化。
Element hcenter(Element)
水平置中一個元素。
Element vbox(Elements)
一個垂直一個接一個顯示元素的容器。
BorderStyle
BorderStyle 是一個列舉,表示可以應用於終端機 UI 元素的不同邊框樣式。
Element gaugeDown(float progress)
繪製一個從上到下進展的高解析度進度條。
FlexboxConfig 是一個配置結構,用於定義彈性盒容器的佈局屬性。
Color 是一個在終端使用者介面中表示顏色的類別。
FTXUI 的 ftxui::Dimension:: 命名空間
Dimensions Fit(Element &, bool extend_beyond_screen=false)
std::function< Element(Element)> Decorator
Element flexbox(Elements, FlexboxConfig config=FlexboxConfig())
一個容器,用於在行/列中顯示元素,並在滿時能夠換行到下一列/行。
Element separatorVSelector(float up, float down, Color unselected_color, Color selected_color)
繪製一個垂直條,其中上方/下方之間的區域以不同顏色顯示。
std::shared_ptr< Node > Element
Element xframe(Element)
與 frame 相同,但僅限於 x 軸。
Element hflow(Elements)
一個容器,用於從左到右在行中顯示元素。當填滿時,它會在下方的新行開始。
Decorator selectionStyle(std::function< void(Pixel &)> style)
設定元素被選取時的樣式。
Element separatorHSelector(float left, float right, Color unselected_color, Color selected_color)
繪製一個水平條,其中左右兩側之間的區域以不同顏色顯示。
Element hbox(Elements)
一個逐一水平顯示元素的容器。
std::vector< Element > Elements
Decorator selectionForegroundColor(Color foreground)
設定元素被選取時的前景顏色。 請注意,此樣式會應用在現有樣式之上。
Component operator|(Component component, ComponentDecorator decorator)
Decorator selectionBackgroundColor(Color foreground)
設定元素被選取時的背景顏色。 請注意,此樣式會應用在現有樣式之上。
Element separatorRounded()
Element yframe(Element)
與 frame 相同,但僅限於 y 軸。
Decorator selectionColor(Color foreground)
設定元素被選取時的顏色。
Element select(Element e)
將 child 設置為其同級元素中被聚焦的元素。
Element selectionStyleReset(Element)
重設元素的選取樣式。
Element canvas(ConstRef< Canvas >)
Decorator reflect(Box &box)
std::function< std::vector< int >(int, int)> GraphFunction
Element gridbox(std::vector< Elements > lines)
顯示元素網格的容器。
Elements paragraph(std::wstring text)
Element frame(Element)
允許元素顯示在「虛擬」區域內。其大小可以大於其容器。在這種情況下,只會顯示較小的一部分。視圖可滾動以使聚焦元素可見。
Component & operator|=(Component &component, ComponentDecorator decorator)
Element vflow(Elements)
一個容器,用於從上到下在行中顯示元素。當填滿時,它會在右側的新列開始。 filled, it starts on a new row. is full, it starts a new row.
Element graph(GraphFunction)
使用 GraphFunction 繪製圖形。