FTXUI 6.1.9
C++ functional terminal UI.
Loading...
Searching...
No Matches
examples/dom/gauge_direction.cpp
// 版權所有 2022 Arthur Sonzogni. 保留所有權利。
// 此原始碼的使用受 MIT 授權條款約束,詳情請參閱
// LICENSE 檔案。
#include <chrono> // 用於 operator""s, chrono_literals
#include <ftxui/dom/elements.hpp> // 用於 filler, operator|, separator, text, border, Element, vbox, vtext, hbox, center, gaugeDown, gaugeLeft, gaugeRight, gaugeUp
#include <ftxui/screen/screen.hpp> // 用於 Screen
#include <iostream> // 用於 cout, endl, ostream
#include <string> // 用於 allocator, operator+, operator<<, string, to_string
#include <thread> // 用於 sleep_for
#include "ftxui/dom/node.hpp" // 用於 Render
#include "ftxui/screen/color.hpp" // 用於 ftxui
int main() {
using namespace ftxui;
using namespace std::chrono_literals;
std::string reset_position;
for (float percentage = 0.0f; percentage <= 1.0f; percentage += 0.002f) {
std::string data_downloaded =
std::to_string(int(percentage * 5000)) + "/5000";
auto gauge_up = //
hbox({
vtext("gauge vertical"),
separator(),
gaugeUp(percentage),
}) |
border;
auto gauge_down = //
hbox({
vtext("gauge vertical"),
separator(),
gaugeDown(percentage),
}) |
border;
auto gauge_right = //
vbox({
text("gauge horizontal"),
separator(),
gaugeRight(percentage),
}) |
border;
auto gauge_left = //
vbox({
text("gauge horizontal"),
separator(),
gaugeLeft(percentage),
}) |
border;
auto document = hbox({
gauge_up,
filler(),
vbox({
gauge_right,
filler(),
text(data_downloaded) | border | center,
filler(),
gauge_left,
}),
filler(),
gauge_down,
});
auto screen = Screen(32, 16);
Render(screen, document);
std::cout << reset_position;
screen.Print();
reset_position = screen.ResetPosition();
std::this_thread::sleep_for(0.01s);
}
std::cout << std::endl;
}
void Render(Screen &screen, const Element &element)
在 ftxui::Screen 上顯示元素。
Definition node.cpp:82
像素的矩形網格。
Definition screen.hpp:26
FTXUI 的 ftxui:: 命名空間
Definition animation.hpp:10