mirror of
https://github.com/ArthurSonzogni/FTXUI.git
synced 2025-12-16 01:48:56 +08:00
902 lines
85 KiB
HTML
902 lines
85 KiB
HTML
|
|
<!-- HTML header for doxygen 1.9.8-->
|
||
|
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||
|
|
<html xmlns="http://www.w3.org/1999/xhtml" lang="en-US">
|
||
|
|
<head>
|
||
|
|
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
|
||
|
|
<meta http-equiv="X-UA-Compatible" content="IE=11"/>
|
||
|
|
<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>
|
||
|
|
<script type="text/javascript" src="doxygen-awesome-fragment-copy-button.js"></script>
|
||
|
|
<script type="text/javascript" src="doxygen-awesome-paragraph-link.js"></script>
|
||
|
|
<script type="text/javascript" src="doxygen-awesome-interactive-toc.js"></script>
|
||
|
|
<script type="text/javascript" src="doxygen-awesome-tabs.js"></script>
|
||
|
|
<script type="module">
|
||
|
|
DoxygenAwesomeFragmentCopyButton.init()
|
||
|
|
DoxygenAwesomeParagraphLink.init()
|
||
|
|
DoxygenAwesomeInteractiveToc.init()
|
||
|
|
DoxygenAwesomeTabs.init()
|
||
|
|
await new Promise(r => window.addEventListener('DOMContentLoaded', r));
|
||
|
|
// Remove title when a img[alt='title-img'] is present.
|
||
|
|
// Find an image with the alt "img-title".
|
||
|
|
const img = document.querySelector("img[alt='title-img']");
|
||
|
|
const header = document.querySelector(".headertitle");
|
||
|
|
if (img && header) {
|
||
|
|
// Hide the header title progressively.
|
||
|
|
header.style.display = "none";
|
||
|
|
// Show progressively the image.
|
||
|
|
img.style.maxHeight = "40vh";
|
||
|
|
img.style.maxWidth = "100%";
|
||
|
|
img.style.objectFit = "contain";
|
||
|
|
}
|
||
|
|
// In the "examples.html" page. Turn every link with text
|
||
|
|
// "examples/<...>
|
||
|
|
//
|
||
|
|
// Add a "demo" link toward.
|
||
|
|
// https://arthursonzogni.github.io/FTXUI/examples/?file=<...>
|
||
|
|
const examples = document.querySelectorAll("a")
|
||
|
|
examples.forEach((example) => {
|
||
|
|
if (!example.textContent.startsWith("examples/")) {
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
// Remove the ".cpp" extension from the example name.
|
||
|
|
const exampleName = example.textContent.replace("examples/", "").replace(".cpp", "");
|
||
|
|
const a = document.createElement("a");
|
||
|
|
a.textContent = "[demo]";
|
||
|
|
a.href = "https://arthursonzogni.github.io/FTXUI/examples/?file=" + exampleName;
|
||
|
|
a.style.marginRight= "1em";
|
||
|
|
a.style.fontWeight = "bold";
|
||
|
|
example.parentElement.insertBefore(a, example)
|
||
|
|
});
|
||
|
|
// If the current URL ends with -example.html, we can add a link to the demo
|
||
|
|
// as well using the div.title textContent.
|
||
|
|
const url = new URL(window.location.href);
|
||
|
|
if (url.pathname.endsWith("-example.html")) {
|
||
|
|
// Get the title text.
|
||
|
|
const title = document.querySelector("div.title").textContent;
|
||
|
|
const example = title.replace("examples/", "").replace(".cpp", "");
|
||
|
|
// Create a link to the demo.
|
||
|
|
const a = document.createElement("a");
|
||
|
|
a.textContent = "[demo]";
|
||
|
|
a.href = "https://arthursonzogni.github.io/FTXUI/examples/?file=" + example;
|
||
|
|
a.style.marginLeft = "1em";
|
||
|
|
a.style.fontWeight = "bold";
|
||
|
|
a.style.display = "inline-block";
|
||
|
|
// Insert the link after the title.
|
||
|
|
const titleDiv = document.querySelector("div.title");
|
||
|
|
if (titleDiv) {
|
||
|
|
titleDiv.insertBefore(a, titleDiv.nextSibling);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</script>
|
||
|
|
<script type="module">
|
||
|
|
// Ignore non english pages and/or the main page.
|
||
|
|
const excluded_lang = [
|
||
|
|
"/de",
|
||
|
|
"/es",
|
||
|
|
"/fr",
|
||
|
|
"/it",
|
||
|
|
"/ja",
|
||
|
|
"/ja",
|
||
|
|
"/ko"
|
||
|
|
"/ru",
|
||
|
|
"/zh-CH",
|
||
|
|
"/zh-TW",
|
||
|
|
]
|
||
|
|
if (excluded_lang.some(lang => window.location.pathname.startsWith(lang)) ||
|
||
|
|
window.location.pathname.endsWith("index.html")) {
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
// Click on the navtree, except for the main page where this is already done
|
||
|
|
// automatically.
|
||
|
|
let delay = 0;
|
||
|
|
while(true) {
|
||
|
|
const navtree = document.querySelector("div.item.selected");
|
||
|
|
if (!navtree) {
|
||
|
|
delay *= 2;
|
||
|
|
delay += 1;
|
||
|
|
await new Promise(resolve => setTimeout(resolve, delay));
|
||
|
|
continue;
|
||
|
|
}
|
||
|
|
// Include only selected navtree items.
|
||
|
|
console.log("navtree.textContent", navtree.textContent);
|
||
|
|
if (!navtree.textContent.includes("Getting Started") &&
|
||
|
|
!navtree.textContent.includes("Installation") &&
|
||
|
|
!navtree.textContent.includes("ftxui / screen") &&
|
||
|
|
!navtree.textContent.includes("ftxui / dom") &&
|
||
|
|
!navtree.textContent.includes("ftxui / component") &&
|
||
|
|
!navtree.textContent.includes("Reference")) {
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
// Find the first link inside the navtree.
|
||
|
|
const link = navtree.querySelector("a");
|
||
|
|
if (link) {
|
||
|
|
// Simulate a click on the link.
|
||
|
|
link.click();
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
</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-awesome.css" rel="stylesheet" type="text/css"/>
|
||
|
|
<link href="stylesheet.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 id="projectrow">
|
||
|
|
<td id="projectalign">
|
||
|
|
<div id="projectname">FTXUI<span id="projectnumber"> 6.1.9</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. Todos los derechos reservados.</span></div>
|
||
|
|
<div class="line"><span class="comment">// El uso de este código fuente se rige por la licencia MIT que se puede encontrar en</span></div>
|
||
|
|
<div class="line"><span class="comment">// el archivo LICENSE.</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 <<a class="code" href="loop_8hpp.html">ftxui/component/loop.hpp</a>></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> <a id="a0" name="a0"></a><a class="code hl_function" href="examples_2component_2button_8cpp.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a>() {</div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a1" name="a1"></a><a class="code hl_variable" href="composition_8cpp.html#af714c99ec9f8e04253d194a65f0e9ed8">screen</a> = ScreenInteractive::Fullscreen();</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n // HTOP</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n int shift = 0;</span></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 = <a id="a2" name="a2"></a><a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"Frequency [Mhz]"</span>) | hcenter,</div>
|
||
|
|
<div class="line"> <a id="a3" name="a3"></a><a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</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 = <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"Utilization [%]"</span>) | hcenter,</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</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 = <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"Ram [Mo]"</span>) | hcenter,</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</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> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</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">// ---------------------------------------------------------------------------\n // Compilador</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n</span></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">"Compiladores de Ada"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores de ALGOL 60"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores de ALGOL 68"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Ensambladores (Intel *86)"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Ensambladores (Motorola 68*)"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Ensambladores (Zilog Z80)"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Ensambladores (otros)"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores BASIC"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Intérpretes BASIC"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores por lotes"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores C"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores de fuente a fuente"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores C++"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores C#"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores COBOL"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Common Lisp"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores D"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores DIBOL/DBL"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Intérpretes ECMAScript"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Eiffel"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Fortran"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Go"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Haskell"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Java"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Pascal"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Intérpretes Perl"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores PHP"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores PL/I"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Python"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores e intérpretes Scheme"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores Smalltalk"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Intérpretes Tcl"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Intérpretes VMS"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Intérpretes Rexx"</span>,</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Compiladores CLI"</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="_a4" name="_a4"></a><a class="code hl_struct" href="group__component.html#structftxui_1_1InputOption">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">"archivos de entrada"</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">"ejecutable"</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">// Compilador</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">// Ejecutable</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">// Entrada</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 = <a id="a5" name="a5"></a><a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Compilador"</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"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Banderas"</span>), flags->Render() | vscroll_indicator | frame);</div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> executable_win = <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Ejecutable:"</span>), executable_->Render());</div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> input_win =</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Entrada"</span>), <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"Añadir: "</span>),</div>
|
||
|
|
<div class="line"> input_add->Render(),</div>
|
||
|
|
<div class="line"> }) | <a id="a6" name="a6"></a><a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(WIDTH, <a id="a7" name="a7"></a><a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, 20) |</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(HEIGHT, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, 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"> <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(HEIGHT, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, 3) | flex,</div>
|
||
|
|
<div class="line"> }));</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> compiler_win,</div>
|
||
|
|
<div class="line"> flags_win,</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> executable_win | <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(WIDTH, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, 20),</div>
|
||
|
|
<div class="line"> input_win | <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(WIDTH, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, 60),</div>
|
||
|
|
<div class="line"> }),</div>
|
||
|
|
<div class="line"> filler(),</div>
|
||
|
|
<div class="line"> }) | <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(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">// ---------------------------------------------------------------------------\n // Spinner</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n auto spinner_tab_renderer = Renderer([&] {</span></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 / 5) | bold |</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(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">// ---------------------------------------------------------------------------\n // Colores</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n auto color_tab_renderer = Renderer([] {</span></div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a8" name="a8"></a><a class="code hl_variable" href="homescreen_8cpp.html#aadac5850b3b9d0856054810b16163414">basic_color_display</a> =</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"Paleta de 16 colores:"</span>),</div>
|
||
|
|
<div class="line"> separator(),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> color(Color::Default, text(<span class="stringliteral">"Predeterminado"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::Black, text(<span class="stringliteral">"Negro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::GrayDark, text(<span class="stringliteral">"GrisOscuro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::GrayLight, text(<span class="stringliteral">"GrisClaro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::White, text(<span class="stringliteral">"Blanco"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::Blue, text(<span class="stringliteral">"Azul"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::BlueLight, text(<span class="stringliteral">"AzulClaro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::Cyan, text(<span class="stringliteral">"Cian"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::CyanLight, text(<span class="stringliteral">"CianClaro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::Green, text(<span class="stringliteral">"Verde"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::GreenLight, text(<span class="stringliteral">"VerdeClaro"</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">"MagentaClaro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::Red, text(<span class="stringliteral">"Rojo"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::RedLight, text(<span class="stringliteral">"RojoClaro"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::Yellow, text(<span class="stringliteral">"Amarillo"</span>)),</div>
|
||
|
|
<div class="line"> color(Color::YellowLight, text(<span class="stringliteral">"AmarilloClaro"</span>)),</div>
|
||
|
|
<div class="line"> }),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> bgcolor(Color::Default, text(<span class="stringliteral">"Predeterminado"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::Black, text(<span class="stringliteral">"Negro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::GrayDark, text(<span class="stringliteral">"GrisOscuro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::GrayLight, text(<span class="stringliteral">"GrisClaro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::White, text(<span class="stringliteral">"Blanco"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::Blue, text(<span class="stringliteral">"Azul"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::BlueLight, text(<span class="stringliteral">"AzulClaro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::Cyan, text(<span class="stringliteral">"Cian"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::CyanLight, text(<span class="stringliteral">"CianClaro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::Green, text(<span class="stringliteral">"Verde"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::GreenLight, text(<span class="stringliteral">"VerdeClaro"</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">"MagentaClaro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::Red, text(<span class="stringliteral">"Rojo"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::RedLight, text(<span class="stringliteral">"RojoClaro"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::Yellow, text(<span class="stringliteral">"Amarillo"</span>)),</div>
|
||
|
|
<div class="line"> bgcolor(Color::YellowLight, text(<span class="stringliteral">"AmarilloClaro"</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> <a id="a9" name="a9"></a><a class="code hl_variable" href="homescreen_8cpp.html#a391f44f7de3d24ec6b1cfe48bb1210cd">palette_256_color_display</a> = text(<span class="stringliteral">"Paleta de 256 colores:"</span>);</div>
|
||
|
|
<div class="line"> {</div>
|
||
|
|
<div class="line"> std::vector<std::vector<ColorInfo>> info_columns = <a id="a10" name="a10"></a><a class="code hl_function" href="color__info__sorted__2d_8ipp.html#a0f08918d6064cd2a0e56cb9ec74033ca">ColorInfoSorted2D</a>();</div>
|
||
|
|
<div class="line"> <a class="code hl_typedef" href="namespaceftxui.html#a5d4aa06ca6cc6a72e981bd5386f93f0a">Elements</a> <a id="a11" name="a11"></a><a class="code hl_variable" href="homescreen_8cpp.html#a9ebe6335e84289128edc5d470399260e">columns</a>;</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="_a12" name="_a12"></a><a class="code hl_class" href="group__screen.html#classftxui_1_1Color">Color</a>(<a class="code hl_enumeration" href="group__screen.html#abd07c48f62cc507fafa2486a43130fcf">Color::Palette256</a>(it.index_256))));</div>
|
||
|
|
<div class="line"> }</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a9ebe6335e84289128edc5d470399260e">columns</a>.push_back(<a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>(std::move(column_elements)));</div>
|
||
|
|
<div class="line"> }</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a391f44f7de3d24ec6b1cfe48bb1210cd">palette_256_color_display</a> = <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a391f44f7de3d24ec6b1cfe48bb1210cd">palette_256_color_display</a>,</div>
|
||
|
|
<div class="line"> separator(),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>(<a class="code hl_variable" href="homescreen_8cpp.html#a9ebe6335e84289128edc5d470399260e">columns</a>),</div>
|
||
|
|
<div class="line"> }) |</div>
|
||
|
|
<div class="line"> border;</div>
|
||
|
|
<div class="line"> }</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// Visualización de color verdadero.</span></div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a13" name="a13"></a><a class="code hl_variable" href="homescreen_8cpp.html#a220688cc22ac1597c07f12bdd081bff9">true_color_display</a> = text(<span class="stringliteral">"Colores verdaderos: 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> <a id="a14" name="a14"></a><a class="code hl_variable" href="homescreen_8cpp.html#a220e860b9cd3e6e1a911c1fb81a81ac4">array</a>;</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"> <a class="code hl_variable" href="homescreen_8cpp.html#a220e860b9cd3e6e1a911c1fb81a81ac4">array</a>.push_back(<a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>(std::move(line)));</div>
|
||
|
|
<div class="line"> }</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a220688cc22ac1597c07f12bdd081bff9">true_color_display</a> = <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a220688cc22ac1597c07f12bdd081bff9">true_color_display</a>,</div>
|
||
|
|
<div class="line"> separator(),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>(std::move(<a class="code hl_variable" href="homescreen_8cpp.html#a220e860b9cd3e6e1a911c1fb81a81ac4">array</a>)),</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> <a id="a15" name="a15"></a><a class="code hl_function" href="homescreen_8cpp.html#adf1552a080ef0a9889340056057d0ca2">flexbox</a>(</div>
|
||
|
|
<div class="line"> {</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#aadac5850b3b9d0856054810b16163414">basic_color_display</a>,</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a391f44f7de3d24ec6b1cfe48bb1210cd">palette_256_color_display</a>,</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a220688cc22ac1597c07f12bdd081bff9">true_color_display</a>,</div>
|
||
|
|
<div class="line"> },</div>
|
||
|
|
<div class="line"> <a id="_a16" name="_a16"></a><a class="code hl_struct" href="group__dom.html#structftxui_1_1FlexboxConfig">FlexboxConfig</a>().<a id="a17" name="a17"></a><a class="code hl_function" href="group__dom.html#a98d9a43033c09c7f967cdec791408bad">SetGap</a>(1, 1));</div>
|
||
|
|
<div class="line"> });</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n // Medidores</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n auto render_gauge = [&shift](int delta) {</span></div>
|
||
|
|
<div class="line"> <span class="keywordtype">float</span> <a id="a18" name="a18"></a><a class="code hl_variable" href="homescreen_8cpp.html#ac7abb4766cd3f65c31f56279d7decff8">progress</a> = (shift + delta) % 500 / 500.f;</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> text(std::to_string(<span class="keywordtype">int</span>(<a class="code hl_variable" href="homescreen_8cpp.html#ac7abb4766cd3f65c31f56279d7decff8">progress</a> * 100)) + <span class="stringliteral">"% "</span>) |</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(WIDTH, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, 5),</div>
|
||
|
|
<div class="line"> gauge(<a class="code hl_variable" href="homescreen_8cpp.html#ac7abb4766cd3f65c31f56279d7decff8">progress</a>),</div>
|
||
|
|
<div class="line"> });</div>
|
||
|
|
<div class="line"> };</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a19" name="a19"></a><a class="code hl_variable" href="homescreen_8cpp.html#a7883bcbd7c4289b627d5ddb8024170f9">gauge_component</a> = Renderer([render_gauge] {</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</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">// ---------------------------------------------------------------------------\n // Párrafo</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n auto make_box = [](size_t dimx, size_t dimy) {</span></div>
|
||
|
|
<div class="line"> std::string <a id="a20" name="a20"></a><a class="code hl_variable" href="homescreen_8cpp.html#ac30fed21fe991cc8475ce543929f8b72">title</a> = std::to_string(dimx) + <span class="stringliteral">"x"</span> + std::to_string(dimy);</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<a class="code hl_variable" href="homescreen_8cpp.html#ac30fed21fe991cc8475ce543929f8b72">title</a>) | hcenter | bold,</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"contenido"</span>) | hcenter | dim) |</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(WIDTH, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, dimx) | <a class="code hl_function" href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a>(HEIGHT, <a class="code hl_variable" href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a>, dimy);</div>
|
||
|
|
<div class="line"> };</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a21" name="a21"></a><a class="code hl_variable" href="homescreen_8cpp.html#aa646efa8a872f03dbd2b03b52bf2a127">paragraph_renderer_left</a> = Renderer([&] {</div>
|
||
|
|
<div class="line"> std::string str =</div>
|
||
|
|
<div class="line"> <span class="stringliteral">"Lorem Ipsum es simplemente un texto ficticio de la industria de la "</span></div>
|
||
|
|
<div class="line"> <span class="stringliteral">"impresión y la tipografía.\nLorem Ipsum ha sido el texto ficticio "</span></div>
|
||
|
|
<div class="line"> <span class="stringliteral">"estándar de la industria desde el siglo XVI, cuando una impresora "</span></div>
|
||
|
|
<div class="line"> <span class="stringliteral">"desconocida tomó una galera de tipos y la mezcló para hacer un libro "</span></div>
|
||
|
|
<div class="line"> <span class="stringliteral">"de muestras de tipos."</span>;</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Alinear izquierda:"</span>), paragraphAlignLeft(str)),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Alinear centro:"</span>), paragraphAlignCenter(str)),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Alinear derecha:"</span>), paragraphAlignRight(str)),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Alinear justificar:"</span>), paragraphAlignJustify(str)),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Lado a lado"</span>), <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</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"> <a class="code hl_function" href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a>(text(<span class="stringliteral">"Elementos con diferente tamaño:"</span>),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#adf1552a080ef0a9889340056057d0ca2">flexbox</a>({</div>
|
||
|
|
<div class="line"> <a id="a22" name="a22"></a><a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(10, 5),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(9, 4),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(8, 4),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(6, 3),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(10, 5),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(9, 4),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(8, 4),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(6, 3),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(10, 5),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(9, 4),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(8, 4),</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a>(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> <a id="a23" name="a23"></a><a class="code hl_variable" href="homescreen_8cpp.html#a49cdc60f6728a8eaa19bbf8490c3fd86">paragraph_renderer_right</a> = Renderer([] {</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> paragraph(<span class="stringliteral">"<--- Esta barra vertical es redimensionable usando el ratón"</span>) |</div>
|
||
|
|
<div class="line"> center;</div>
|
||
|
|
<div class="line"> });</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keywordtype">int</span> <a id="a24" name="a24"></a><a class="code hl_variable" href="homescreen_8cpp.html#a24413d596cf94f25e07d4c3ab876065b">paragraph_renderer_split_position</a> = Terminal::Size().dimx / 2;</div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a25" name="a25"></a><a class="code hl_variable" href="homescreen_8cpp.html#aea311d105f61e5e5fbff222fb0de8abe">paragraph_renderer_group</a> =</div>
|
||
|
|
<div class="line"> ResizableSplitLeft(<a class="code hl_variable" href="homescreen_8cpp.html#aa646efa8a872f03dbd2b03b52bf2a127">paragraph_renderer_left</a>, <a class="code hl_variable" href="homescreen_8cpp.html#a49cdc60f6728a8eaa19bbf8490c3fd86">paragraph_renderer_right</a>,</div>
|
||
|
|
<div class="line"> &<a class="code hl_variable" href="homescreen_8cpp.html#a24413d596cf94f25e07d4c3ab876065b">paragraph_renderer_split_position</a>);</div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a26" name="a26"></a><a class="code hl_variable" href="homescreen_8cpp.html#a3e5afc4f5840709c4498e028afdae008">paragraph_renderer_group_renderer</a> =</div>
|
||
|
|
<div class="line"> Renderer(<a class="code hl_variable" href="homescreen_8cpp.html#aea311d105f61e5e5fbff222fb0de8abe">paragraph_renderer_group</a>,</div>
|
||
|
|
<div class="line"> [&] { <span class="keywordflow">return</span> <a class="code hl_variable" href="homescreen_8cpp.html#aea311d105f61e5e5fbff222fb0de8abe">paragraph_renderer_group</a>->Render(); });</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n // Pestañas</span></div>
|
||
|
|
<div class="line"> <span class="comment">// ---------------------------------------------------------------------------\n</span></div>
|
||
|
|
<div class="line"> <span class="keywordtype">int</span> <a id="a27" name="a27"></a><a class="code hl_variable" href="homescreen_8cpp.html#ac7114c41f8794383c0f870e16b4e4dfa">tab_index</a> = 0;</div>
|
||
|
|
<div class="line"> std::vector<std::string> <a id="a28" name="a28"></a><a class="code hl_variable" href="homescreen_8cpp.html#a084bcdbf83ea1fb1096178386621ec7b">tab_entries</a> = {</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> <a id="a29" name="a29"></a><a class="code hl_variable" href="homescreen_8cpp.html#afc6b9e7173d155888ef3b52201375254">tab_selection</a> =</div>
|
||
|
|
<div class="line"> Menu(&<a class="code hl_variable" href="homescreen_8cpp.html#a084bcdbf83ea1fb1096178386621ec7b">tab_entries</a>, &<a class="code hl_variable" href="homescreen_8cpp.html#ac7114c41f8794383c0f870e16b4e4dfa">tab_index</a>, MenuOption::HorizontalAnimated());</div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a30" name="a30"></a><a class="code hl_variable" href="homescreen_8cpp.html#ae0e78b985a19760ef86282657396f621">tab_content</a> = 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"> <a class="code hl_variable" href="homescreen_8cpp.html#a7883bcbd7c4289b627d5ddb8024170f9">gauge_component</a>,</div>
|
||
|
|
<div class="line"> compiler_renderer,</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#a3e5afc4f5840709c4498e028afdae008">paragraph_renderer_group_renderer</a>,</div>
|
||
|
|
<div class="line"> },</div>
|
||
|
|
<div class="line"> &<a class="code hl_variable" href="homescreen_8cpp.html#ac7114c41f8794383c0f870e16b4e4dfa">tab_index</a>);</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a31" name="a31"></a><a class="code hl_variable" href="homescreen_8cpp.html#ad350a89c4d9681436b4cf9e3682bc579">exit_button</a> =</div>
|
||
|
|
<div class="line"> Button(<span class="stringliteral">"Salir"</span>, [&] { <a class="code hl_variable" href="composition_8cpp.html#af714c99ec9f8e04253d194a65f0e9ed8">screen</a>.Exit(); }, ButtonOption::Animated());</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a32" name="a32"></a><a class="code hl_variable" href="homescreen_8cpp.html#a2bff956732f25fb8971a9ea89bbe3f3a">main_container</a> = Container::Vertical({</div>
|
||
|
|
<div class="line"> Container::Horizontal({</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#afc6b9e7173d155888ef3b52201375254">tab_selection</a>,</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#ad350a89c4d9681436b4cf9e3682bc579">exit_button</a>,</div>
|
||
|
|
<div class="line"> }),</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#ae0e78b985a19760ef86282657396f621">tab_content</a>,</div>
|
||
|
|
<div class="line"> });</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keyword">auto</span> <a id="a33" name="a33"></a><a class="code hl_variable" href="homescreen_8cpp.html#a22853e6a0e98dcdf618d5280f118fee5">main_renderer</a> = Renderer(<a class="code hl_variable" href="homescreen_8cpp.html#a2bff956732f25fb8971a9ea89bbe3f3a">main_container</a>, [&] {</div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> <a class="code hl_function" href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a>({</div>
|
||
|
|
<div class="line"> text(<span class="stringliteral">"Demostración de FTXUI"</span>) | bold | hcenter,</div>
|
||
|
|
<div class="line"> <a class="code hl_function" href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a>({</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#afc6b9e7173d155888ef3b52201375254">tab_selection</a>->Render() | flex,</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#ad350a89c4d9681436b4cf9e3682bc579">exit_button</a>->Render(),</div>
|
||
|
|
<div class="line"> }),</div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="homescreen_8cpp.html#ae0e78b985a19760ef86282657396f621">tab_content</a>->Render() | flex,</div>
|
||
|
|
<div class="line"> });</div>
|
||
|
|
<div class="line"> });</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <a id="_a34" name="_a34"></a><a class="code hl_class" href="group__component.html#classftxui_1_1Loop">Loop</a> loop(&<a class="code hl_variable" href="composition_8cpp.html#af714c99ec9f8e04253d194a65f0e9ed8">screen</a>, <a class="code hl_variable" href="homescreen_8cpp.html#a22853e6a0e98dcdf618d5280f118fee5">main_renderer</a>);</div>
|
||
|
|
<div class="line"> <span class="keywordflow">while</span> (!loop.HasQuitted()) {</div>
|
||
|
|
<div class="line"> <span class="comment">// Actualizar el estado de la aplicación.</span></div>
|
||
|
|
<div class="line"> shift++;</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// Solicitar que se dibuje un nuevo fotograma.</span></div>
|
||
|
|
<div class="line"> <a class="code hl_variable" href="composition_8cpp.html#af714c99ec9f8e04253d194a65f0e9ed8">screen</a>.RequestAnimationFrame();</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// Ejecutar eventos y dibujar el siguiente fotograma.</span></div>
|
||
|
|
<div class="line"> loop.RunOnce();</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="comment">// Esperar una corta duración para controlar la velocidad de fotogramas (60 FPS).</span></div>
|
||
|
|
<div class="line"> std::this_thread::sleep_for(std::chrono::milliseconds(1000 / 60));</div>
|
||
|
|
<div class="line"> }</div>
|
||
|
|
<div class="line"> </div>
|
||
|
|
<div class="line"> <span class="keywordflow">return</span> 0;</div>
|
||
|
|
<div class="line">}</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="acolor__info__sorted__2d_8ipp_html_a0f08918d6064cd2a0e56cb9ec74033ca"><div class="ttname"><a href="color__info__sorted__2d_8ipp.html#a0f08918d6064cd2a0e56cb9ec74033ca">ColorInfoSorted2D</a></div><div class="ttdeci">std::vector< std::vector< ftxui::ColorInfo > > ColorInfoSorted2D()</div><div class="ttdef"><b>Definition</b> <a href="color__info__sorted__2d_8ipp_source.html#l00005">color_info_sorted_2d.ipp:5</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="acomposition_8cpp_html_af714c99ec9f8e04253d194a65f0e9ed8"><div class="ttname"><a href="composition_8cpp.html#af714c99ec9f8e04253d194a65f0e9ed8">screen</a></div><div class="ttdeci">auto screen</div><div class="ttdef"><b>Definition</b> <a href="composition_8cpp_source.html#l00056">composition.cpp:56</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="aexamples_2component_2button_8cpp_html_ae66f6b31b5ad750f1fe042a706a4e3d4"><div class="ttname"><a href="examples_2component_2button_8cpp.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main</a></div><div class="ttdeci">int main()</div><div class="ttdef"><b>Definition</b> <a href="examples_2component_2button_8cpp_source.html#l00033">examples/component/button.cpp:33</a></div></div>
|
||
|
|
<div class="ttc" id="aexamples_2component_2focus_8cpp_html_a9ffb8a33ec5d0133f63f791d526df1c7"><div class="ttname"><a href="examples_2component_2focus_8cpp.html#a9ffb8a33ec5d0133f63f791d526df1c7">make_box</a></div><div class="ttdeci">Element make_box(int x, int y)</div><div class="ttdef"><b>Definition</b> <a href="examples_2component_2focus_8cpp_source.html#l00017">examples/component/focus.cpp:17</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="agroup__component_html_classftxui_1_1Loop"><div class="ttname"><a href="group__component.html#classftxui_1_1Loop">ftxui::Loop</a></div><div class="ttdoc">Loop es una clase que gestiona el bucle de eventos de un componente.</div><div class="ttdef"><b>Definition</b> <a href="loop_8hpp_source.html#l00056">loop.hpp:56</a></div></div>
|
||
|
|
<div class="ttc" id="agroup__component_html_structftxui_1_1InputOption"><div class="ttname"><a href="group__component.html#structftxui_1_1InputOption">ftxui::InputOption</a></div><div class="ttdoc">Opción para el componente Input.</div><div class="ttdef"><b>Definition</b> <a href="component__options_8hpp_source.html#l00165">component_options.hpp:165</a></div></div>
|
||
|
|
<div class="ttc" id="agroup__dom_html_a98d9a43033c09c7f967cdec791408bad"><div class="ttname"><a href="group__dom.html#a98d9a43033c09c7f967cdec791408bad">ftxui::FlexboxConfig::SetGap</a></div><div class="ttdeci">FlexboxConfig & SetGap(int gap_x, int gap_y)</div><div class="ttdoc">Establece el espacio (gap) del flexbox.</div><div class="ttdef"><b>Definition</b> <a href="flexbox__config_8cpp_source.html#l00039">flexbox_config.cpp:39</a></div></div>
|
||
|
|
<div class="ttc" id="agroup__dom_html_gafd28058f0ccbbdf34691a85a7cc9b2e3"><div class="ttname"><a href="group__dom.html#gafd28058f0ccbbdf34691a85a7cc9b2e3">vbox</a></div><div class="ttdeci">Element vbox(Elements children)</div><div class="ttdoc">Un contenedor que muestra elementos verticalmente uno por uno.</div><div class="ttdef"><b>Definition</b> <a href="vbox_8cpp_source.html#l00095">vbox.cpp:95</a></div></div>
|
||
|
|
<div class="ttc" id="agroup__dom_html_structftxui_1_1FlexboxConfig"><div class="ttname"><a href="group__dom.html#structftxui_1_1FlexboxConfig">ftxui::FlexboxConfig</a></div><div class="ttdoc">FlexboxConfig es una estructura de configuración que define las propiedades de diseño para un contene...</div><div class="ttdef"><b>Definition</b> <a href="flexbox__config_8hpp_source.html#l00027">flexbox_config.hpp:27</a></div></div>
|
||
|
|
<div class="ttc" id="agroup__screen_html_abd07c48f62cc507fafa2486a43130fcf"><div class="ttname"><a href="group__screen.html#abd07c48f62cc507fafa2486a43130fcf">ftxui::Color::Palette256</a></div><div class="ttdeci">Palette256</div><div class="ttdef"><b>Definition</b> <a href="color_8hpp_source.html#l00071">color.hpp:71</a></div></div>
|
||
|
|
<div class="ttc" id="agroup__screen_html_classftxui_1_1Color"><div class="ttname"><a href="group__screen.html#classftxui_1_1Color">ftxui::Color</a></div><div class="ttdoc">Color es una clase que representa un color en la interfaz de usuario de la terminal.</div><div class="ttdef"><b>Definition</b> <a href="color_8hpp_source.html#l00021">color.hpp:21</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a084bcdbf83ea1fb1096178386621ec7b"><div class="ttname"><a href="homescreen_8cpp.html#a084bcdbf83ea1fb1096178386621ec7b">tab_entries</a></div><div class="ttdeci">std::vector< std::string > tab_entries</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00465">homescreen.cpp:465</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a220688cc22ac1597c07f12bdd081bff9"><div class="ttname"><a href="homescreen_8cpp.html#a220688cc22ac1597c07f12bdd081bff9">true_color_display</a></div><div class="ttdeci">auto true_color_display</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00343">homescreen.cpp:343</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a220e860b9cd3e6e1a911c1fb81a81ac4"><div class="ttname"><a href="homescreen_8cpp.html#a220e860b9cd3e6e1a911c1fb81a81ac4">array</a></div><div class="ttdeci">Elements array</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00346">homescreen.cpp:346</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a22853e6a0e98dcdf618d5280f118fee5"><div class="ttname"><a href="homescreen_8cpp.html#a22853e6a0e98dcdf618d5280f118fee5">main_renderer</a></div><div class="ttdeci">auto main_renderer</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00492">homescreen.cpp:492</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a24413d596cf94f25e07d4c3ab876065b"><div class="ttname"><a href="homescreen_8cpp.html#a24413d596cf94f25e07d4c3ab876065b">paragraph_renderer_split_position</a></div><div class="ttdeci">int paragraph_renderer_split_position</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00454">homescreen.cpp:454</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a2bff956732f25fb8971a9ea89bbe3f3a"><div class="ttname"><a href="homescreen_8cpp.html#a2bff956732f25fb8971a9ea89bbe3f3a">main_container</a></div><div class="ttdeci">auto main_container</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00484">homescreen.cpp:484</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a391f44f7de3d24ec6b1cfe48bb1210cd"><div class="ttname"><a href="homescreen_8cpp.html#a391f44f7de3d24ec6b1cfe48bb1210cd">palette_256_color_display</a></div><div class="ttdeci">auto palette_256_color_display</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00322">homescreen.cpp:322</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a3e5afc4f5840709c4498e028afdae008"><div class="ttname"><a href="homescreen_8cpp.html#a3e5afc4f5840709c4498e028afdae008">paragraph_renderer_group_renderer</a></div><div class="ttdeci">auto paragraph_renderer_group_renderer</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00458">homescreen.cpp:458</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a49cdc60f6728a8eaa19bbf8490c3fd86"><div class="ttname"><a href="homescreen_8cpp.html#a49cdc60f6728a8eaa19bbf8490c3fd86">paragraph_renderer_right</a></div><div class="ttdeci">auto paragraph_renderer_right</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00449">homescreen.cpp:449</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a597817b41a8dd2568e26e733a9d74e21"><div class="ttname"><a href="homescreen_8cpp.html#a597817b41a8dd2568e26e733a9d74e21">size</a></div><div class="ttdeci">return dimx size(HEIGHT, EQUAL, dimy)</div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a7883bcbd7c4289b627d5ddb8024170f9"><div class="ttname"><a href="homescreen_8cpp.html#a7883bcbd7c4289b627d5ddb8024170f9">gauge_component</a></div><div class="ttdeci">auto gauge_component</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00383">homescreen.cpp:383</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_a9ebe6335e84289128edc5d470399260e"><div class="ttname"><a href="homescreen_8cpp.html#a9ebe6335e84289128edc5d470399260e">columns</a></div><div class="ttdeci">Elements columns</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00325">homescreen.cpp:325</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_aa646efa8a872f03dbd2b03b52bf2a127"><div class="ttname"><a href="homescreen_8cpp.html#aa646efa8a872f03dbd2b03b52bf2a127">paragraph_renderer_left</a></div><div class="ttdeci">auto paragraph_renderer_left</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00413">homescreen.cpp:413</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_aadac5850b3b9d0856054810b16163414"><div class="ttname"><a href="homescreen_8cpp.html#aadac5850b3b9d0856054810b16163414">basic_color_display</a></div><div class="ttdeci">auto basic_color_display</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00275">homescreen.cpp:275</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ac30fed21fe991cc8475ce543929f8b72"><div class="ttname"><a href="homescreen_8cpp.html#ac30fed21fe991cc8475ce543929f8b72">title</a></div><div class="ttdeci">std::string title</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00407">homescreen.cpp:407</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ac7114c41f8794383c0f870e16b4e4dfa"><div class="ttname"><a href="homescreen_8cpp.html#ac7114c41f8794383c0f870e16b4e4dfa">tab_index</a></div><div class="ttdeci">int tab_index</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00464">homescreen.cpp:464</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ac7abb4766cd3f65c31f56279d7decff8"><div class="ttname"><a href="homescreen_8cpp.html#ac7abb4766cd3f65c31f56279d7decff8">progress</a></div><div class="ttdeci">float progress</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00375">homescreen.cpp:375</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ad28a0f8acf7ec71346d0ac30efc30d07"><div class="ttname"><a href="homescreen_8cpp.html#ad28a0f8acf7ec71346d0ac30efc30d07">EQUAL</a></div><div class="ttdeci">return EQUAL</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00410">homescreen.cpp:410</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ad350a89c4d9681436b4cf9e3682bc579"><div class="ttname"><a href="homescreen_8cpp.html#ad350a89c4d9681436b4cf9e3682bc579">exit_button</a></div><div class="ttdeci">auto exit_button</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00481">homescreen.cpp:481</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_add852e8162dbf08b43c18f42e7431fa2"><div class="ttname"><a href="homescreen_8cpp.html#add852e8162dbf08b43c18f42e7431fa2">window</a></div><div class="ttdeci">return window(text(title)|hcenter|bold, text("contenido")|hcenter|dim)|size(WIDTH</div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_adf1552a080ef0a9889340056057d0ca2"><div class="ttname"><a href="homescreen_8cpp.html#adf1552a080ef0a9889340056057d0ca2">flexbox</a></div><div class="ttdeci">return flexbox({ basic_color_display, palette_256_color_display, true_color_display, }, FlexboxConfig().SetGap(1, 1))</div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ae0e78b985a19760ef86282657396f621"><div class="ttname"><a href="homescreen_8cpp.html#ae0e78b985a19760ef86282657396f621">tab_content</a></div><div class="ttdeci">auto tab_content</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00470">homescreen.cpp:470</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_ae5579bc51e6b713d975798ba1f06d2e8"><div class="ttname"><a href="homescreen_8cpp.html#ae5579bc51e6b713d975798ba1f06d2e8">hbox</a></div><div class="ttdeci">return hbox({ text(std::to_string(int(progress *100))+"% ")|size(WIDTH, EQUAL, 5), gauge(progress), })</div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_aea311d105f61e5e5fbff222fb0de8abe"><div class="ttname"><a href="homescreen_8cpp.html#aea311d105f61e5e5fbff222fb0de8abe">paragraph_renderer_group</a></div><div class="ttdeci">auto paragraph_renderer_group</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00455">homescreen.cpp:455</a></div></div>
|
||
|
|
<div class="ttc" id="ahomescreen_8cpp_html_afc6b9e7173d155888ef3b52201375254"><div class="ttname"><a href="homescreen_8cpp.html#afc6b9e7173d155888ef3b52201375254">tab_selection</a></div><div class="ttdeci">auto tab_selection</div><div class="ttdef"><b>Definition</b> <a href="homescreen_8cpp_source.html#l00468">homescreen.cpp:468</a></div></div>
|
||
|
|
<div class="ttc" id="aloop_8hpp_html"><div class="ttname"><a href="loop_8hpp.html">loop.hpp</a></div></div>
|
||
|
|
<div class="ttc" id="anamespaceftxui_html"><div class="ttname"><a href="namespaceftxui.html">ftxui</a></div><div class="ttdoc">El espacio de nombres ftxui:: de FTXUI.</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="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.9.8-->
|
||
|
|
<!-- 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('projectname');
|
||
|
|
|
||
|
|
if (!projectNumber) {
|
||
|
|
console.warn('Doxygen element with ID "projectnumber" not found. Cannot add version switcher.');
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
|
||
|
|
const langs = ["en", "es", "fr", "ja", "zh-CH", "zh-TW"];
|
||
|
|
const lang_paths = {"en": "../index.html", "es": "index.html", "fr": "../fr/index.html", "ja": "../ja/index.html", "zh-CH": "../zh-CH/index.html", "zh-TW": "../zh-TW/index.html"};
|
||
|
|
const lang_display = {"en": "English", "es": "Espa\u00f1ol", "fr": "Fran\u00e7ais", "ja": "\u65e5\u672c\u8a9e", "zh-CH": "\u4e2d\u6587 (\u7b80\u4f53)", "zh-TW": "\u4e2d\u6587 (\u7e41\u9ad4)"};
|
||
|
|
const versions = ["main"];
|
||
|
|
const version_paths = {"main": "index.html"};
|
||
|
|
const currentLang = "es";
|
||
|
|
const currentVersion = "main";
|
||
|
|
|
||
|
|
// Helper function to create a styled select element
|
||
|
|
const createSelect = (options, current, paths, label, displayMap = null) => {
|
||
|
|
const select = document.createElement('select');
|
||
|
|
select.title = label;
|
||
|
|
select.onchange = function() {
|
||
|
|
const selectedValue = this.value;
|
||
|
|
if (selectedValue in paths) {
|
||
|
|
window.location.href = paths[selectedValue];
|
||
|
|
}
|
||
|
|
};
|
||
|
|
|
||
|
|
// Sort versions: 'main' first, then others numerically descending.
|
||
|
|
options.sort((a, b) => {
|
||
|
|
if (a === 'main') return -1;
|
||
|
|
if (b === 'main') return 1;
|
||
|
|
return b.localeCompare(a, undefined, { numeric: true, sensitivity: 'base' });
|
||
|
|
});
|
||
|
|
|
||
|
|
options.forEach(v => {
|
||
|
|
const option = document.createElement('option');
|
||
|
|
option.value = v;
|
||
|
|
// Use the displayMap if provided, otherwise default to the value (v)
|
||
|
|
option.textContent = displayMap ? displayMap[v] : v;
|
||
|
|
if (v === current) {
|
||
|
|
option.selected = true;
|
||
|
|
}
|
||
|
|
select.appendChild(option);
|
||
|
|
});
|
||
|
|
|
||
|
|
// 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',
|
||
|
|
margin: '0 5px 0 0',
|
||
|
|
cursor: 'pointer'
|
||
|
|
});
|
||
|
|
return select;
|
||
|
|
};
|
||
|
|
|
||
|
|
// 1. Create Language Switcher, passing the language display names map
|
||
|
|
const langSelect = createSelect(langs, currentLang, lang_paths, 'Select Language', lang_display);
|
||
|
|
|
||
|
|
// 2. Create Version Switcher
|
||
|
|
const versionSelect = createSelect(versions, currentVersion, version_paths, 'Select Version');
|
||
|
|
|
||
|
|
// 3. Create FTXUI title.
|
||
|
|
const ftxuiTitle = document.createElement('span');
|
||
|
|
ftxuiTitle.textContent = 'FTXUI: ';
|
||
|
|
Object.assign(ftxuiTitle.style, {
|
||
|
|
color: 'white',
|
||
|
|
fontSize: '20px',
|
||
|
|
fontWeight: 'bold',
|
||
|
|
marginRight: '10px'
|
||
|
|
});
|
||
|
|
|
||
|
|
// 3. Create a container to hold both selectors
|
||
|
|
const container = document.createElement('div');
|
||
|
|
container.id = 'version-lang-switchers';
|
||
|
|
Object.assign(container.style, {
|
||
|
|
display: 'flex',
|
||
|
|
alignItems: 'center',
|
||
|
|
justifyContent: 'flex-end',
|
||
|
|
width: 'auto'
|
||
|
|
});
|
||
|
|
container.appendChild(ftxuiTitle);
|
||
|
|
container.appendChild(langSelect);
|
||
|
|
container.appendChild(versionSelect);
|
||
|
|
|
||
|
|
Object.assign(container.style, {
|
||
|
|
backgroundColor: 'rgba(0, 0, 0, 0.5)',
|
||
|
|
padding: '5px 10px',
|
||
|
|
borderRadius: '8px'
|
||
|
|
});
|
||
|
|
|
||
|
|
|
||
|
|
// Replace the Doxygen project number element with our container.
|
||
|
|
projectNumber.replaceWith(container);
|
||
|
|
|
||
|
|
// Clean up the original Doxygen project number text if it still exists nearby
|
||
|
|
const parent = container.parentElement;
|
||
|
|
if (parent) {
|
||
|
|
const textNode = Array.from(parent.childNodes).find(n => n.nodeType === 3 && n.textContent.trim() !== '');
|
||
|
|
if (textNode) {
|
||
|
|
textNode.remove();
|
||
|
|
}
|
||
|
|
}
|
||
|
|
});
|
||
|
|
</script>
|
||
|
|
</body>
|
||
|
|
</html>
|