mirror of
https://github.com/ArthurSonzogni/FTXUI.git
synced 2025-11-15 11:38:56 +08:00
722 lines
56 KiB
HTML
722 lines
56 KiB
HTML
<!-- HTML header for doxygen 1.8.14-->
|
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
|
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
<head>
|
|
<meta http-equiv="cache-control" content="max-age=86400"/>
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
|
|
<meta name="generator" content="Doxygen 1.12.0"/>
|
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
<title>FTXUI: examples/component/homescreen.cpp</title>
|
|
<link href="tabs.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="jquery.js"></script>
|
|
<script type="text/javascript" src="dynsections.js"></script>
|
|
<link href="navtree.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="navtreedata.js"></script>
|
|
<script type="text/javascript" src="navtree.js"></script>
|
|
<script type="text/javascript" src="resize.js"></script>
|
|
<script type="text/javascript" src="cookie.js"></script>
|
|
<link href="search/search.css" rel="stylesheet" type="text/css"/>
|
|
<script type="text/javascript" src="search/searchdata.js"></script>
|
|
<script type="text/javascript" src="search/search.js"></script>
|
|
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
|
<link href="doxygen_extra.css" rel="stylesheet" type="text/css"/>
|
|
</head>
|
|
<body>
|
|
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
|
|
<div id="titlearea">
|
|
<table cellspacing="0" cellpadding="0">
|
|
<tbody>
|
|
<tr style="height: 56px;">
|
|
<td id="projectalign" style="padding-left: 0.5em;">
|
|
<div id="projectname">FTXUI
|
|
 <span id="projectnumber">6.0.2</span>
|
|
</div>
|
|
<div id="projectbrief">C++ functional terminal UI.</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<!-- end header part -->
|
|
<!-- Generated by Doxygen 1.12.0 -->
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
var searchBox = new SearchBox("searchBox", "search/",'.html');
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
$(function() { codefold.init(0); });
|
|
/* @license-end */
|
|
</script>
|
|
<script type="text/javascript" src="menudata.js"></script>
|
|
<script type="text/javascript" src="menu.js"></script>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
$(function() {
|
|
initMenu('',true,false,'search.php','Search',true);
|
|
$(function() { init_search(); });
|
|
});
|
|
/* @license-end */
|
|
</script>
|
|
<div id="main-nav"></div>
|
|
</div><!-- top -->
|
|
<div id="side-nav" class="ui-resizable side-nav-resizable">
|
|
<div id="nav-tree">
|
|
<div id="nav-tree-contents">
|
|
<div id="nav-sync" class="sync"></div>
|
|
</div>
|
|
</div>
|
|
<div id="splitbar" style="-moz-user-select:none;"
|
|
class="ui-resizable-handle">
|
|
</div>
|
|
</div>
|
|
<script type="text/javascript">
|
|
/* @license magnet:?xt=urn:btih:d3d9a9a6595521f9666a5e94cc830dab83b65699&dn=expat.txt MIT */
|
|
$(function(){initNavTree('examples_2component_2homescreen_8cpp-example.html',''); initResizable(true); });
|
|
/* @license-end */
|
|
</script>
|
|
<div id="doc-content">
|
|
<!-- window showing the filter options -->
|
|
<div id="MSearchSelectWindow"
|
|
onmouseover="return searchBox.OnSearchSelectShow()"
|
|
onmouseout="return searchBox.OnSearchSelectHide()"
|
|
onkeydown="return searchBox.OnSearchSelectKey(event)">
|
|
</div>
|
|
|
|
<!-- iframe showing the search results (closed by default) -->
|
|
<div id="MSearchResultsWindow">
|
|
<div id="MSearchResults">
|
|
<div class="SRPage">
|
|
<div id="SRIndex">
|
|
<div id="SRResults"></div>
|
|
<div class="SRStatus" id="Loading">Loading...</div>
|
|
<div class="SRStatus" id="Searching">Searching...</div>
|
|
<div class="SRStatus" id="NoMatches">No Matches</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="header">
|
|
<div class="headertitle"><div class="title">examples/component/homescreen.cpp</div></div>
|
|
</div><!--header-->
|
|
<div class="contents">
|
|
<div class="fragment"><div class="line"><span class="comment">// Copyright 2020 Arthur Sonzogni. All rights reserved.</span></div>
|
|
<div class="line"><span class="comment">// Use of this source code is governed by the MIT license that can be found in</span></div>
|
|
<div class="line"><span class="comment">// the LICENSE file.</span></div>
|
|
<div class="line"><span class="preprocessor">#include <stddef.h></span> <span class="comment">// for size_t</span></div>
|
|
<div class="line"><span class="preprocessor">#include <array></span> <span class="comment">// for array</span></div>
|
|
<div class="line"><span class="preprocessor">#include <atomic></span> <span class="comment">// for atomic</span></div>
|
|
<div class="line"><span class="preprocessor">#include <chrono></span> <span class="comment">// for operator""s, chrono_literals</span></div>
|
|
<div class="line"><span class="preprocessor">#include <cmath></span> <span class="comment">// for sin</span></div>
|
|
<div class="line"><span class="preprocessor">#include <functional></span> <span class="comment">// for ref, reference_wrapper, function</span></div>
|
|
<div class="line"><span class="preprocessor">#include <memory></span> <span class="comment">// for allocator, shared_ptr, __shared_ptr_access</span></div>
|
|
<div class="line"><span class="preprocessor">#include <string></span> <span class="comment">// for string, basic_string, char_traits, operator+, to_string</span></div>
|
|
<div class="line"><span class="preprocessor">#include <thread></span> <span class="comment">// for sleep_for, thread</span></div>
|
|
<div class="line"><span class="preprocessor">#include <utility></span> <span class="comment">// for move</span></div>
|
|
<div class="line"><span class="preprocessor">#include <vector></span> <span class="comment">// for vector</span></div>
|
|
<div class="line"> </div>
|
|
<div class="line"><span class="preprocessor">#include "../dom/color_info_sorted_2d.ipp"</span> <span class="comment">// for ColorInfoSorted2D</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="component_8hpp.html">ftxui/component/component.hpp</a>"</span> <span class="comment">// for Checkbox, Renderer, Horizontal, Vertical, Input, Menu, Radiobox, ResizableSplitLeft, Tab</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="component__base_8hpp.html">ftxui/component/component_base.hpp</a>"</span> <span class="comment">// for ComponentBase, Component</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="component__options_8hpp.html">ftxui/component/component_options.hpp</a>"</span> <span class="comment">// for MenuOption, InputOption</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="event_8hpp.html">ftxui/component/event.hpp</a>"</span> <span class="comment">// for Event, Event::Custom</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="screen__interactive_8hpp.html">ftxui/component/screen_interactive.hpp</a>"</span> <span class="comment">// for Component, ScreenInteractive</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="elements_8hpp.html">ftxui/dom/elements.hpp</a>"</span> <span class="comment">// for text, color, operator|, bgcolor, filler, Element, vbox, size, hbox, separator, flex, window, graph, EQUAL, paragraph, WIDTH, hcenter, Elements, bold, vscroll_indicator, HEIGHT, flexbox, hflow, border, frame, flex_grow, gauge, paragraphAlignCenter, paragraphAlignJustify, paragraphAlignLeft, paragraphAlignRight, dim, spinner, LESS_THAN, center, yframe, GREATER_THAN</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="flexbox__config_8hpp.html">ftxui/dom/flexbox_config.hpp</a>"</span> <span class="comment">// for FlexboxConfig</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="color_8hpp.html">ftxui/screen/color.hpp</a>"</span> <span class="comment">// for Color, Color::BlueLight, Color::RedLight, Color::Black, Color::Blue, Color::Cyan, Color::CyanLight, Color::GrayDark, Color::GrayLight, Color::Green, Color::GreenLight, Color::Magenta, Color::MagentaLight, Color::Red, Color::White, Color::Yellow, Color::YellowLight, Color::Default, Color::Palette256, ftxui</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="color__info_8hpp.html">ftxui/screen/color_info.hpp</a>"</span> <span class="comment">// for ColorInfo</span></div>
|
|
<div class="line"><span class="preprocessor">#include "<a class="code" href="terminal_8hpp.html">ftxui/screen/terminal.hpp</a>"</span> <span class="comment">// for Size, Dimensions</span></div>
|
|
<div class="line"> </div>
|
|
<div class="line"><span class="keyword">using namespace </span><a class="code hl_namespace" href="namespaceftxui.html">ftxui</a>;</div>
|
|
<div class="line"> </div>
|
|
<div class="line"><span class="keywordtype">int</span> main() {</div>
|
|
<div class="line"> <span class="keyword">auto</span> screen = ScreenInteractive::Fullscreen();</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// HTOP</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="keywordtype">int</span> shift = 0;</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> my_graph = [&shift](<span class="keywordtype">int</span> width, <span class="keywordtype">int</span> height) {</div>
|
|
<div class="line"> std::vector<int> output(width);</div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < width; ++i) {</div>
|
|
<div class="line"> <span class="keywordtype">float</span> v = 0.5f;</div>
|
|
<div class="line"> v += 0.1f * sin((i + shift) * 0.1f);</div>
|
|
<div class="line"> v += 0.2f * sin((i + shift + 10) * 0.15f);</div>
|
|
<div class="line"> v += 0.1f * sin((i + shift) * 0.03f);</div>
|
|
<div class="line"> v *= height;</div>
|
|
<div class="line"> output[i] = (int)v;</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> <span class="keywordflow">return</span> output;</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> htop = Renderer([&] {</div>
|
|
<div class="line"> <span class="keyword">auto</span> frequency = vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"Frequency [Mhz]"</span>) | hcenter,</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"2400 "</span>),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> text(<span class="stringliteral">"1200 "</span>),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> text(<span class="stringliteral">"0 "</span>),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> graph(std::ref(my_graph)) | flex,</div>
|
|
<div class="line"> }) | flex,</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> utilization = vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"Utilization [%]"</span>) | hcenter,</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"100 "</span>),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> text(<span class="stringliteral">"50 "</span>),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> text(<span class="stringliteral">"0 "</span>),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> graph(std::ref(my_graph)) | color(Color::RedLight),</div>
|
|
<div class="line"> }) | flex,</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> ram = vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"Ram [Mo]"</span>) | hcenter,</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"8192"</span>),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> text(<span class="stringliteral">"4096 "</span>),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> text(<span class="stringliteral">"0 "</span>),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> graph(std::ref(my_graph)) | color(Color::BlueLight),</div>
|
|
<div class="line"> }) | flex,</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keywordflow">return</span> hbox({</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> frequency | flex,</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> utilization | flex,</div>
|
|
<div class="line"> }) | flex,</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> ram | flex,</div>
|
|
<div class="line"> }) |</div>
|
|
<div class="line"> flex;</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// Compiler</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">const</span> std::vector<std::string> compiler_entries = {</div>
|
|
<div class="line"> <span class="stringliteral">"gcc"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"clang"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"emcc"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"game_maker"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Ada compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"ALGOL 60 compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"ALGOL 68 compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Assemblers (Intel *86)"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Assemblers (Motorola 68*)"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Assemblers (Zilog Z80)"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Assemblers (other)"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"BASIC Compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"BASIC interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Batch compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"C compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Source-to-source compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"C++ compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"C# compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"COBOL compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Common Lisp compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"D compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"DIBOL/DBL compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"ECMAScript interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Eiffel compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Fortran compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Go compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Haskell compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Java compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Pascal compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Perl Interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"PHP compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"PL/I compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Python compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Scheme compilers and interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Smalltalk compilers"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Tcl Interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"VMS Interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"Rexx Interpreters"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"CLI compilers"</span>,</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keywordtype">int</span> compiler_selected = 0;</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#af1479ede01dbf087342534ab4ada11d3">Component</a> compiler = Radiobox(&compiler_entries, &compiler_selected);</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> std::array<std::string, 8> options_label = {</div>
|
|
<div class="line"> <span class="stringliteral">"-Wall"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-Werror"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-lpthread"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-O3"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-Wabi-tag"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-Wno-class-conversion"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-Wcomma-subscript"</span>,</div>
|
|
<div class="line"> <span class="stringliteral">"-Wno-conversion-null"</span>,</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> std::array<bool, 8> options_state = {</div>
|
|
<div class="line"> <span class="keyword">false</span>, <span class="keyword">false</span>, <span class="keyword">false</span>, <span class="keyword">false</span>, <span class="keyword">false</span>, <span class="keyword">false</span>, <span class="keyword">false</span>, <span class="keyword">false</span>,</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> std::vector<std::string> input_entries;</div>
|
|
<div class="line"> <span class="keywordtype">int</span> input_selected = 0;</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#af1479ede01dbf087342534ab4ada11d3">Component</a> input = Menu(&input_entries, &input_selected);</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> input_option = <a id="_a0" name="_a0"></a><a class="code hl_struct" href="structftxui_1_1InputOption.html">InputOption</a>();</div>
|
|
<div class="line"> std::string input_add_content;</div>
|
|
<div class="line"> input_option.on_enter = [&] {</div>
|
|
<div class="line"> input_entries.push_back(input_add_content);</div>
|
|
<div class="line"> input_add_content = <span class="stringliteral">""</span>;</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#af1479ede01dbf087342534ab4ada11d3">Component</a> input_add = Input(&input_add_content, <span class="stringliteral">"input files"</span>, input_option);</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> std::string executable_content_ = <span class="stringliteral">""</span>;</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#af1479ede01dbf087342534ab4ada11d3">Component</a> executable_ = Input(&executable_content_, <span class="stringliteral">"executable"</span>);</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#af1479ede01dbf087342534ab4ada11d3">Component</a> flags = Container::Vertical({</div>
|
|
<div class="line"> Checkbox(&options_label[0], &options_state[0]),</div>
|
|
<div class="line"> Checkbox(&options_label[1], &options_state[1]),</div>
|
|
<div class="line"> Checkbox(&options_label[2], &options_state[2]),</div>
|
|
<div class="line"> Checkbox(&options_label[3], &options_state[3]),</div>
|
|
<div class="line"> Checkbox(&options_label[4], &options_state[4]),</div>
|
|
<div class="line"> Checkbox(&options_label[5], &options_state[5]),</div>
|
|
<div class="line"> Checkbox(&options_label[6], &options_state[6]),</div>
|
|
<div class="line"> Checkbox(&options_label[7], &options_state[7]),</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> compiler_component = Container::Horizontal({</div>
|
|
<div class="line"> compiler,</div>
|
|
<div class="line"> flags,</div>
|
|
<div class="line"> Container::Vertical({</div>
|
|
<div class="line"> executable_,</div>
|
|
<div class="line"> Container::Horizontal({</div>
|
|
<div class="line"> input_add,</div>
|
|
<div class="line"> input,</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> render_command = [&] {</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> line;</div>
|
|
<div class="line"> <span class="comment">// Compiler</span></div>
|
|
<div class="line"> line.push_back(text(compiler_entries[compiler_selected]) | bold);</div>
|
|
<div class="line"> <span class="comment">// flags</span></div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < 8; ++i) {</div>
|
|
<div class="line"> <span class="keywordflow">if</span> (options_state[i]) {</div>
|
|
<div class="line"> line.push_back(text(<span class="stringliteral">" "</span>));</div>
|
|
<div class="line"> line.push_back(text(options_label[i]) | dim);</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> <span class="comment">// Executable</span></div>
|
|
<div class="line"> <span class="keywordflow">if</span> (!executable_content_.empty()) {</div>
|
|
<div class="line"> line.push_back(text(<span class="stringliteral">" -o "</span>) | bold);</div>
|
|
<div class="line"> line.push_back(text(executable_content_) | color(Color::BlueLight) |</div>
|
|
<div class="line"> bold);</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> <span class="comment">// Input</span></div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keyword">auto</span>& it : input_entries) {</div>
|
|
<div class="line"> line.push_back(text(<span class="stringliteral">" "</span> + it) | color(Color::RedLight));</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> <span class="keywordflow">return</span> line;</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> compiler_renderer = Renderer(compiler_component, [&] {</div>
|
|
<div class="line"> <span class="keyword">auto</span> compiler_win = window(text(<span class="stringliteral">"Compiler"</span>),</div>
|
|
<div class="line"> compiler->Render() | vscroll_indicator | frame);</div>
|
|
<div class="line"> <span class="keyword">auto</span> flags_win =</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Flags"</span>), flags->Render() | vscroll_indicator | frame);</div>
|
|
<div class="line"> <span class="keyword">auto</span> executable_win = window(text(<span class="stringliteral">"Executable:"</span>), executable_->Render());</div>
|
|
<div class="line"> <span class="keyword">auto</span> input_win =</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Input"</span>), hbox({</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"Add: "</span>),</div>
|
|
<div class="line"> input_add->Render(),</div>
|
|
<div class="line"> }) | size(WIDTH, EQUAL, 20) |</div>
|
|
<div class="line"> size(HEIGHT, EQUAL, 1),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> input->Render() | vscroll_indicator | frame |</div>
|
|
<div class="line"> size(HEIGHT, EQUAL, 3) | flex,</div>
|
|
<div class="line"> }));</div>
|
|
<div class="line"> <span class="keywordflow">return</span> vbox({</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> compiler_win,</div>
|
|
<div class="line"> flags_win,</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> executable_win | size(WIDTH, EQUAL, 20),</div>
|
|
<div class="line"> input_win | size(WIDTH, EQUAL, 60),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> filler(),</div>
|
|
<div class="line"> }) | size(HEIGHT, LESS_THAN, 8),</div>
|
|
<div class="line"> hflow(render_command()) | flex_grow,</div>
|
|
<div class="line"> }) |</div>
|
|
<div class="line"> flex_grow;</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// Spinner</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="keyword">auto</span> spinner_tab_renderer = Renderer([&] {</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> entries;</div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i = 0; i < 22; ++i) {</div>
|
|
<div class="line"> entries.push_back(spinner(i, shift / 2) | bold |</div>
|
|
<div class="line"> size(WIDTH, GREATER_THAN, 2) | border);</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> <span class="keywordflow">return</span> hflow(std::move(entries));</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// Colors</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="keyword">auto</span> color_tab_renderer = Renderer([] {</div>
|
|
<div class="line"> <span class="keyword">auto</span> basic_color_display =</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"16 color palette:"</span>),</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> color(Color::Default, text(<span class="stringliteral">"Default"</span>)),</div>
|
|
<div class="line"> color(Color::Black, text(<span class="stringliteral">"Black"</span>)),</div>
|
|
<div class="line"> color(Color::GrayDark, text(<span class="stringliteral">"GrayDark"</span>)),</div>
|
|
<div class="line"> color(Color::GrayLight, text(<span class="stringliteral">"GrayLight"</span>)),</div>
|
|
<div class="line"> color(Color::White, text(<span class="stringliteral">"White"</span>)),</div>
|
|
<div class="line"> color(Color::Blue, text(<span class="stringliteral">"Blue"</span>)),</div>
|
|
<div class="line"> color(Color::BlueLight, text(<span class="stringliteral">"BlueLight"</span>)),</div>
|
|
<div class="line"> color(Color::Cyan, text(<span class="stringliteral">"Cyan"</span>)),</div>
|
|
<div class="line"> color(Color::CyanLight, text(<span class="stringliteral">"CyanLight"</span>)),</div>
|
|
<div class="line"> color(Color::Green, text(<span class="stringliteral">"Green"</span>)),</div>
|
|
<div class="line"> color(Color::GreenLight, text(<span class="stringliteral">"GreenLight"</span>)),</div>
|
|
<div class="line"> color(Color::Magenta, text(<span class="stringliteral">"Magenta"</span>)),</div>
|
|
<div class="line"> color(Color::MagentaLight, text(<span class="stringliteral">"MagentaLight"</span>)),</div>
|
|
<div class="line"> color(Color::Red, text(<span class="stringliteral">"Red"</span>)),</div>
|
|
<div class="line"> color(Color::RedLight, text(<span class="stringliteral">"RedLight"</span>)),</div>
|
|
<div class="line"> color(Color::Yellow, text(<span class="stringliteral">"Yellow"</span>)),</div>
|
|
<div class="line"> color(Color::YellowLight, text(<span class="stringliteral">"YellowLight"</span>)),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> vbox({</div>
|
|
<div class="line"> bgcolor(Color::Default, text(<span class="stringliteral">"Default"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Black, text(<span class="stringliteral">"Black"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::GrayDark, text(<span class="stringliteral">"GrayDark"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::GrayLight, text(<span class="stringliteral">"GrayLight"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::White, text(<span class="stringliteral">"White"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Blue, text(<span class="stringliteral">"Blue"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::BlueLight, text(<span class="stringliteral">"BlueLight"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Cyan, text(<span class="stringliteral">"Cyan"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::CyanLight, text(<span class="stringliteral">"CyanLight"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Green, text(<span class="stringliteral">"Green"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::GreenLight, text(<span class="stringliteral">"GreenLight"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Magenta, text(<span class="stringliteral">"Magenta"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::MagentaLight, text(<span class="stringliteral">"MagentaLight"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Red, text(<span class="stringliteral">"Red"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::RedLight, text(<span class="stringliteral">"RedLight"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::Yellow, text(<span class="stringliteral">"Yellow"</span>)),</div>
|
|
<div class="line"> bgcolor(Color::YellowLight, text(<span class="stringliteral">"YellowLight"</span>)),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> }) |</div>
|
|
<div class="line"> border;</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> palette_256_color_display = text(<span class="stringliteral">"256 colors palette:"</span>);</div>
|
|
<div class="line"> {</div>
|
|
<div class="line"> std::vector<std::vector<ColorInfo>> info_columns = ColorInfoSorted2D();</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> columns;</div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keyword">auto</span>& column : info_columns) {</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> column_elements;</div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keyword">auto</span>& it : column) {</div>
|
|
<div class="line"> column_elements.push_back(</div>
|
|
<div class="line"> text(<span class="stringliteral">" "</span>) | bgcolor(<a id="_a1" name="_a1"></a><a class="code hl_class" href="classftxui_1_1Color.html">Color</a>(<a class="code hl_enumeration" href="classftxui_1_1Color.html#abd07c48f62cc507fafa2486a43130fcf">Color::Palette256</a>(it.index_256))));</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> columns.push_back(hbox(std::move(column_elements)));</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> palette_256_color_display = vbox({</div>
|
|
<div class="line"> palette_256_color_display,</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> vbox(columns),</div>
|
|
<div class="line"> }) |</div>
|
|
<div class="line"> border;</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// True color display.</span></div>
|
|
<div class="line"> <span class="keyword">auto</span> true_color_display = text(<span class="stringliteral">"TrueColors: 24bits:"</span>);</div>
|
|
<div class="line"> {</div>
|
|
<div class="line"> <span class="keywordtype">int</span> saturation = 255;</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> array;</div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keywordtype">int</span> value = 0; value < 255; value += 16) {</div>
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> line;</div>
|
|
<div class="line"> <span class="keywordflow">for</span> (<span class="keywordtype">int</span> hue = 0; hue < 255; hue += 6) {</div>
|
|
<div class="line"> line.push_back(text(<span class="stringliteral">"▀"</span>) <span class="comment">//</span></div>
|
|
<div class="line"> | color(Color::HSV(hue, saturation, value)) <span class="comment">//</span></div>
|
|
<div class="line"> | bgcolor(Color::HSV(hue, saturation, value + 8)));</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> array.push_back(hbox(std::move(line)));</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> true_color_display = vbox({</div>
|
|
<div class="line"> true_color_display,</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> vbox(std::move(array)),</div>
|
|
<div class="line"> }) |</div>
|
|
<div class="line"> border;</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keywordflow">return</span> flexbox(</div>
|
|
<div class="line"> {</div>
|
|
<div class="line"> basic_color_display,</div>
|
|
<div class="line"> palette_256_color_display,</div>
|
|
<div class="line"> true_color_display,</div>
|
|
<div class="line"> },</div>
|
|
<div class="line"> <a id="_a2" name="_a2"></a><a class="code hl_struct" href="structftxui_1_1FlexboxConfig.html">FlexboxConfig</a>().<a id="a3" name="a3"></a><a class="code hl_function" href="structftxui_1_1FlexboxConfig.html#a98d9a43033c09c7f967cdec791408bad">SetGap</a>(1, 1));</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// Gauges</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="keyword">auto</span> render_gauge = [&shift](<span class="keywordtype">int</span> delta) {</div>
|
|
<div class="line"> <span class="keywordtype">float</span> progress = (shift + delta) % 500 / 500.f;</div>
|
|
<div class="line"> <span class="keywordflow">return</span> hbox({</div>
|
|
<div class="line"> text(std::to_string(<span class="keywordtype">int</span>(progress * 100)) + <span class="stringliteral">"% "</span>) |</div>
|
|
<div class="line"> size(WIDTH, EQUAL, 5),</div>
|
|
<div class="line"> gauge(progress),</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> gauge_component = Renderer([render_gauge] {</div>
|
|
<div class="line"> <span class="keywordflow">return</span> vbox({</div>
|
|
<div class="line"> render_gauge(0) | color(Color::Black),</div>
|
|
<div class="line"> render_gauge(100) | color(Color::GrayDark),</div>
|
|
<div class="line"> render_gauge(50) | color(Color::GrayLight),</div>
|
|
<div class="line"> render_gauge(6894) | color(Color::White),</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> render_gauge(6841) | color(Color::Blue),</div>
|
|
<div class="line"> render_gauge(9813) | color(Color::BlueLight),</div>
|
|
<div class="line"> render_gauge(98765) | color(Color::Cyan),</div>
|
|
<div class="line"> render_gauge(98) | color(Color::CyanLight),</div>
|
|
<div class="line"> render_gauge(9846) | color(Color::Green),</div>
|
|
<div class="line"> render_gauge(1122) | color(Color::GreenLight),</div>
|
|
<div class="line"> render_gauge(84) | color(Color::Magenta),</div>
|
|
<div class="line"> render_gauge(645) | color(Color::MagentaLight),</div>
|
|
<div class="line"> render_gauge(568) | color(Color::Red),</div>
|
|
<div class="line"> render_gauge(2222) | color(Color::RedLight),</div>
|
|
<div class="line"> render_gauge(220) | color(Color::Yellow),</div>
|
|
<div class="line"> render_gauge(348) | color(Color::YellowLight),</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// Paragraph</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="keyword">auto</span> make_box = [](<span class="keywordtype">size_t</span> dimx, <span class="keywordtype">size_t</span> dimy) {</div>
|
|
<div class="line"> std::string title = std::to_string(dimx) + <span class="stringliteral">"x"</span> + std::to_string(dimy);</div>
|
|
<div class="line"> <span class="keywordflow">return</span> window(text(title) | hcenter | bold,</div>
|
|
<div class="line"> text(<span class="stringliteral">"content"</span>) | hcenter | dim) |</div>
|
|
<div class="line"> size(WIDTH, EQUAL, dimx) | size(HEIGHT, EQUAL, dimy);</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> paragraph_renderer_left = Renderer([&] {</div>
|
|
<div class="line"> std::string str =</div>
|
|
<div class="line"> <span class="stringliteral">"Lorem Ipsum is simply dummy text of the printing and typesetting "</span></div>
|
|
<div class="line"> <span class="stringliteral">"industry.\nLorem Ipsum has been the industry's standard dummy text "</span></div>
|
|
<div class="line"> <span class="stringliteral">"ever since the 1500s, when an unknown printer took a galley of type "</span></div>
|
|
<div class="line"> <span class="stringliteral">"and scrambled it to make a type specimen book."</span>;</div>
|
|
<div class="line"> <span class="keywordflow">return</span> vbox({</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Align left:"</span>), paragraphAlignLeft(str)),</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Align center:"</span>), paragraphAlignCenter(str)),</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Align right:"</span>), paragraphAlignRight(str)),</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Align justify:"</span>), paragraphAlignJustify(str)),</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Side by side"</span>), hbox({</div>
|
|
<div class="line"> paragraph(str),</div>
|
|
<div class="line"> separator(),</div>
|
|
<div class="line"> paragraph(str),</div>
|
|
<div class="line"> })),</div>
|
|
<div class="line"> window(text(<span class="stringliteral">"Elements with different size:"</span>),</div>
|
|
<div class="line"> flexbox({</div>
|
|
<div class="line"> make_box(10, 5),</div>
|
|
<div class="line"> make_box(9, 4),</div>
|
|
<div class="line"> make_box(8, 4),</div>
|
|
<div class="line"> make_box(6, 3),</div>
|
|
<div class="line"> make_box(10, 5),</div>
|
|
<div class="line"> make_box(9, 4),</div>
|
|
<div class="line"> make_box(8, 4),</div>
|
|
<div class="line"> make_box(6, 3),</div>
|
|
<div class="line"> make_box(10, 5),</div>
|
|
<div class="line"> make_box(9, 4),</div>
|
|
<div class="line"> make_box(8, 4),</div>
|
|
<div class="line"> make_box(6, 3),</div>
|
|
<div class="line"> })),</div>
|
|
<div class="line"> }) |</div>
|
|
<div class="line"> vscroll_indicator | yframe | flex;</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> paragraph_renderer_right = Renderer([] {</div>
|
|
<div class="line"> <span class="keywordflow">return</span> paragraph(<span class="stringliteral">"<--- This vertical bar is resizable using the mouse"</span>) |</div>
|
|
<div class="line"> center;</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keywordtype">int</span> paragraph_renderer_split_position = Terminal::Size().dimx / 2;</div>
|
|
<div class="line"> <span class="keyword">auto</span> paragraph_renderer_group =</div>
|
|
<div class="line"> ResizableSplitLeft(paragraph_renderer_left, paragraph_renderer_right,</div>
|
|
<div class="line"> &paragraph_renderer_split_position);</div>
|
|
<div class="line"> <span class="keyword">auto</span> paragraph_renderer_group_renderer =</div>
|
|
<div class="line"> Renderer(paragraph_renderer_group,</div>
|
|
<div class="line"> [&] { <span class="keywordflow">return</span> paragraph_renderer_group->Render(); });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> <span class="comment">// Tabs</span></div>
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------</span></div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keywordtype">int</span> tab_index = 0;</div>
|
|
<div class="line"> std::vector<std::string> tab_entries = {</div>
|
|
<div class="line"> <span class="stringliteral">"htop"</span>, <span class="stringliteral">"color"</span>, <span class="stringliteral">"spinner"</span>, <span class="stringliteral">"gauge"</span>, <span class="stringliteral">"compiler"</span>, <span class="stringliteral">"paragraph"</span>,</div>
|
|
<div class="line"> };</div>
|
|
<div class="line"> <span class="keyword">auto</span> tab_selection =</div>
|
|
<div class="line"> Menu(&tab_entries, &tab_index, MenuOption::HorizontalAnimated());</div>
|
|
<div class="line"> <span class="keyword">auto</span> tab_content = Container::Tab(</div>
|
|
<div class="line"> {</div>
|
|
<div class="line"> htop,</div>
|
|
<div class="line"> color_tab_renderer,</div>
|
|
<div class="line"> spinner_tab_renderer,</div>
|
|
<div class="line"> gauge_component,</div>
|
|
<div class="line"> compiler_renderer,</div>
|
|
<div class="line"> paragraph_renderer_group_renderer,</div>
|
|
<div class="line"> },</div>
|
|
<div class="line"> &tab_index);</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> exit_button =</div>
|
|
<div class="line"> Button(<span class="stringliteral">"Exit"</span>, [&] { screen.Exit(); }, ButtonOption::Animated());</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> main_container = Container::Vertical({</div>
|
|
<div class="line"> Container::Horizontal({</div>
|
|
<div class="line"> tab_selection,</div>
|
|
<div class="line"> exit_button,</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> tab_content,</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keyword">auto</span> main_renderer = Renderer(main_container, [&] {</div>
|
|
<div class="line"> <span class="keywordflow">return</span> vbox({</div>
|
|
<div class="line"> text(<span class="stringliteral">"FTXUI Demo"</span>) | bold | hcenter,</div>
|
|
<div class="line"> hbox({</div>
|
|
<div class="line"> tab_selection->Render() | flex,</div>
|
|
<div class="line"> exit_button->Render(),</div>
|
|
<div class="line"> }),</div>
|
|
<div class="line"> tab_content->Render() | flex,</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> std::atomic<bool> refresh_ui_continue = <span class="keyword">true</span>;</div>
|
|
<div class="line"> std::thread refresh_ui([&] {</div>
|
|
<div class="line"> <span class="keywordflow">while</span> (refresh_ui_continue) {</div>
|
|
<div class="line"> <span class="keyword">using namespace </span>std::chrono_literals;</div>
|
|
<div class="line"> std::this_thread::sleep_for(0.05s);</div>
|
|
<div class="line"> <span class="comment">// The |shift| variable belong to the main thread. `screen.Post(task)`</span></div>
|
|
<div class="line"> <span class="comment">// will execute the update on the thread where |screen| lives (e.g. the</span></div>
|
|
<div class="line"> <span class="comment">// main thread). Using `screen.Post(task)` is threadsafe.</span></div>
|
|
<div class="line"> screen.Post([&] { shift++; });</div>
|
|
<div class="line"> <span class="comment">// After updating the state, request a new frame to be drawn. This is done</span></div>
|
|
<div class="line"> <span class="comment">// by simulating a new "custom" event to be handled.</span></div>
|
|
<div class="line"> screen.Post(Event::Custom);</div>
|
|
<div class="line"> }</div>
|
|
<div class="line"> });</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> screen.Loop(main_renderer);</div>
|
|
<div class="line"> refresh_ui_continue = <span class="keyword">false</span>;</div>
|
|
<div class="line"> refresh_ui.join();</div>
|
|
<div class="line"> </div>
|
|
<div class="line"> <span class="keywordflow">return</span> 0;</div>
|
|
<div class="line">}</div>
|
|
<div class="ttc" id="aclassftxui_1_1Color_html"><div class="ttname"><a href="classftxui_1_1Color.html">ftxui::Color</a></div><div class="ttdoc">A class representing terminal colors.</div><div class="ttdef"><b>Definition</b> <a href="color_8hpp_source.html#l00020">color.hpp:20</a></div></div>
|
|
<div class="ttc" id="aclassftxui_1_1Color_html_abd07c48f62cc507fafa2486a43130fcf"><div class="ttname"><a href="classftxui_1_1Color.html#abd07c48f62cc507fafa2486a43130fcf">ftxui::Color::Palette256</a></div><div class="ttdeci">Palette256</div><div class="ttdef"><b>Definition</b> <a href="color_8hpp_source.html#l00070">color.hpp:70</a></div></div>
|
|
<div class="ttc" id="acolor_8hpp_html"><div class="ttname"><a href="color_8hpp.html">color.hpp</a></div></div>
|
|
<div class="ttc" id="acolor__info_8hpp_html"><div class="ttname"><a href="color__info_8hpp.html">color_info.hpp</a></div></div>
|
|
<div class="ttc" id="acomponent_8hpp_html"><div class="ttname"><a href="component_8hpp.html">component.hpp</a></div></div>
|
|
<div class="ttc" id="acomponent__base_8hpp_html"><div class="ttname"><a href="component__base_8hpp.html">component_base.hpp</a></div></div>
|
|
<div class="ttc" id="acomponent__options_8hpp_html"><div class="ttname"><a href="component__options_8hpp.html">component_options.hpp</a></div></div>
|
|
<div class="ttc" id="aelements_8hpp_html"><div class="ttname"><a href="elements_8hpp.html">elements.hpp</a></div></div>
|
|
<div class="ttc" id="aevent_8hpp_html"><div class="ttname"><a href="event_8hpp.html">event.hpp</a></div></div>
|
|
<div class="ttc" id="aflexbox__config_8hpp_html"><div class="ttname"><a href="flexbox__config_8hpp.html">flexbox_config.hpp</a></div></div>
|
|
<div class="ttc" id="anamespaceftxui_html"><div class="ttname"><a href="namespaceftxui.html">ftxui</a></div><div class="ttdef"><b>Definition</b> <a href="animation_8hpp_source.html#l00010">animation.hpp:10</a></div></div>
|
|
<div class="ttc" id="anamespaceftxui_html_a5d4aa06ca6cc6a72e981bd5386f93f0a"><div class="ttname"><a href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">ftxui::Elements</a></div><div class="ttdeci">std::vector< Element > Elements</div><div class="ttdef"><b>Definition</b> <a href="elements_8hpp_source.html#l00023">elements.hpp:23</a></div></div>
|
|
<div class="ttc" id="anamespaceftxui_html_af1479ede01dbf087342534ab4ada11d3"><div class="ttname"><a href="namespaceftxui.html#af1479ede01dbf087342534ab4ada11d3">ftxui::Component</a></div><div class="ttdeci">std::shared_ptr< ComponentBase > Component</div><div class="ttdef"><b>Definition</b> <a href="component__base_8hpp_source.html#l00024">component_base.hpp:24</a></div></div>
|
|
<div class="ttc" id="ascreen__interactive_8hpp_html"><div class="ttname"><a href="screen__interactive_8hpp.html">screen_interactive.hpp</a></div></div>
|
|
<div class="ttc" id="astructftxui_1_1FlexboxConfig_html"><div class="ttname"><a href="structftxui_1_1FlexboxConfig.html">ftxui::FlexboxConfig</a></div><div class="ttdef"><b>Definition</b> <a href="flexbox__config_8hpp_source.html#l00015">flexbox_config.hpp:15</a></div></div>
|
|
<div class="ttc" id="astructftxui_1_1FlexboxConfig_html_a98d9a43033c09c7f967cdec791408bad"><div class="ttname"><a href="structftxui_1_1FlexboxConfig.html#a98d9a43033c09c7f967cdec791408bad">ftxui::FlexboxConfig::SetGap</a></div><div class="ttdeci">FlexboxConfig & SetGap(int gap_x, int gap_y)</div><div class="ttdoc">Set the flexbox flex direction.</div><div class="ttdef"><b>Definition</b> <a href="flexbox__config_8cpp_source.html#l00045">flexbox_config.cpp:45</a></div></div>
|
|
<div class="ttc" id="astructftxui_1_1InputOption_html"><div class="ttname"><a href="structftxui_1_1InputOption.html">ftxui::InputOption</a></div><div class="ttdoc">Option for the Input component.</div><div class="ttdef"><b>Definition</b> <a href="component__options_8hpp_source.html#l00162">component_options.hpp:162</a></div></div>
|
|
<div class="ttc" id="aterminal_8hpp_html"><div class="ttname"><a href="terminal_8hpp.html">terminal.hpp</a></div></div>
|
|
</div><!-- fragment --> </div><!-- contents -->
|
|
</div><!-- doc-content -->
|
|
<!-- HTML footer for doxygen 1.8.14-->
|
|
<!-- start footer part -->
|
|
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
|
|
</div>
|
|
<script>
|
|
document.addEventListener('DOMContentLoaded', function() {
|
|
const projectNumber = document.getElementById('projectnumber');
|
|
if (!projectNumber) {
|
|
console.warn('Doxygen element with ID "projectnumber" not found. Cannot add version switcher.');
|
|
return;
|
|
}
|
|
|
|
const versions = ["main", "v6.1.9", "v6.1.8", "v6.1.7", "v6.1.6", "v6.1.5", "v6.1.4", "v6.1.3", "v6.1.2", "v6.1.1", "v6.1.0", "v6.0.2", "v6.0.1", "v6.0.0", "v5.0.0", "v4.1.1", "v4.1.0", "v4.0.0", "v3.0.0", "v2.0.0", "v0.9", "v0.11", "v0.10"];
|
|
const version_paths = {"main": "../../index.html", "v6.1.9": "../v6.1.9/index.html", "v6.1.8": "../v6.1.8/index.html", "v6.1.7": "../v6.1.7/index.html", "v6.1.6": "../v6.1.6/index.html", "v6.1.5": "../v6.1.5/index.html", "v6.1.4": "../v6.1.4/index.html", "v6.1.3": "../v6.1.3/index.html", "v6.1.2": "../v6.1.2/index.html", "v6.1.1": "../v6.1.1/index.html", "v6.1.0": "../v6.1.0/index.html", "v6.0.2": "index.html", "v6.0.1": "../v6.0.1/index.html", "v6.0.0": "../v6.0.0/index.html", "v5.0.0": "../v5.0.0/index.html", "v4.1.1": "../v4.1.1/index.html", "v4.1.0": "../v4.1.0/index.html", "v4.0.0": "../v4.0.0/index.html", "v3.0.0": "../v3.0.0/index.html", "v2.0.0": "../v2.0.0/index.html", "v0.9": "../v0.9/index.html", "v0.11": "../v0.11/index.html", "v0.10": "../v0.10/index.html"};
|
|
const currentVersion = "v6.0.2";
|
|
|
|
// Sort versions: 'main' first, then others numerically descending.
|
|
versions.sort((a, b) => {
|
|
if (a === 'main') return -1;
|
|
if (b === 'main') return 1;
|
|
return b.localeCompare(a, undefined, { numeric: true, sensitivity: 'base' });
|
|
});
|
|
|
|
const select = document.createElement('select');
|
|
select.onchange = function() {
|
|
const selectedVersion = this.value;
|
|
// Navigate directly to the pre-calculated relative path.
|
|
if (selectedVersion !== currentVersion) {
|
|
window.location.href = version_paths[selectedVersion];
|
|
}
|
|
};
|
|
|
|
versions.forEach(v => {
|
|
const option = document.createElement('option');
|
|
option.value = v;
|
|
option.textContent = v;
|
|
if (v === currentVersion) {
|
|
option.selected = true;
|
|
}
|
|
select.appendChild(option);
|
|
});
|
|
|
|
// Replace the Doxygen project number element with our dropdown.
|
|
projectNumber.replaceWith(select);
|
|
|
|
// Apply some styling to make it look good.
|
|
Object.assign(select.style, {
|
|
backgroundColor: 'rgba(0, 0, 0, 0.8)',
|
|
color: 'white',
|
|
border: '1px solid rgba(255, 255, 255, 0.2)',
|
|
padding: '5px',
|
|
borderRadius: '5px',
|
|
fontSize: '14px',
|
|
fontFamily: 'inherit',
|
|
marginLeft: '10px',
|
|
cursor: 'pointer'
|
|
});
|
|
});
|
|
</script>
|
|
</body>
|
|
</html>
|