FTXUI 6.1.9
C++ functional terminal UI.
载入中...
搜索中...
未找到
html_like.cpp
浏览该文件的文档.
1// Copyright 2020 Arthur Sonzogni. 保留所有权利。
2// 本源代码的使用受 MIT 许可协议的约束,该协议可在 LICENSE 文件中找到。
3#include <chrono> // for operator""s, chrono_literals
4#include <ftxui/screen/screen.hpp> // for Screen
5#include <iostream> // for cout, ostream
6#include <string> // for allocator, operator<<, string
7#include <thread> // for sleep_for
8
9#include "ftxui/dom/elements.hpp" // for paragraph, text, operator|, Element, border, Fit, color, hflow, spinner, vbox, bold, dim, underlined
10#include "ftxui/dom/node.hpp" // for Render
11#include "ftxui/screen/box.hpp" // for ftxui
12#include "ftxui/screen/color.hpp" // for Color, Color::Red
13
14int main() {
15 using namespace ftxui;
16 using namespace std::chrono_literals;
17
18 auto img1 = []() { return text("img") | border; };
19 auto img2 = []() { return vbox({text("big"), text("image")}) | border; };
20
21 std::string reset_position;
22 for (int i = 0;; ++i) {
23 auto document = //
24 hflow(
25 paragraph("Hello world! Here is an image:"), img1(),
26 paragraph(" Here is a text "), text("underlined ") | underlined,
27 paragraph(" Here is a text "), text("bold ") | bold,
28 paragraph("Hello world! Here is an image:"), img2(),
29 paragraph(
30 "Le Lorem Ipsum est simplement du faux texte employé dans la "
31 "composition et la mise en page avant impression. Le Lorem "
32 "Ipsum est le faux texte standard de l'imprimerie depuis les "
33 "années 1500, quand un imprimeur anonyme assembla ensemble "
34 "des morceaux de texte pour réaliser un livre spécimen de "
35 "polices de texte. Il n'a pas fait que survivre cinq siècles, "
36 "mais s'est aussi adapté à la bureautique informatique, sans "
37 "que son contenu n'en soit modifié. Il a été popularisé dans "
38 "les années 1960 grâce à la vente de feuilles Letraset "
39 "contenant des passages du Lorem Ipsum, et, plus récemment, "
40 "par son inclusion dans des applications de mise en page de "
41 "texte, comme Aldus PageMaker."),
42 paragraph(" Here is a text "), text("dim ") | dim,
43 paragraph("Hello world! Here is an image:"), img1(),
44 paragraph(" Here is a text "), text("red ") | color(Color::Red),
45 paragraph(" A spinner "), spinner(6, i / 10)) |
46 border;
47
48 auto screen = Screen::Create(Dimension::Fit(document));
49 Render(screen, document);
50 std::cout << reset_position;
51 screen.Print();
52 reset_position = screen.ResetPosition();
53
54 std::this_thread::sleep_for(0.01s);
55 }
56
57 return 0;
58}
Element color(const LinearGradient &gradient, Element child)
使用线性渐变效果设置元素的前景色。
Element border(Element child)
在元素周围绘制边框。
int main()
#include "ftxui/component/component_base.hpp" // 用于 ComponentBase