2021-08-09 06:27:37 +08:00
|
|
|
#include <chrono> // for operator""s, chrono_literals
|
|
|
|
#include <ftxui/dom/elements.hpp> // for text, gauge, operator|, flex, hbox, Element
|
2021-08-09 05:25:20 +08:00
|
|
|
#include <ftxui/screen/screen.hpp> // for Screen
|
|
|
|
#include <iostream> // for cout, endl, ostream
|
2021-08-09 06:27:37 +08:00
|
|
|
#include <string> // for allocator, operator+, char_traits, operator<<, string, to_string, basic_string
|
2021-08-09 05:25:20 +08:00
|
|
|
#include <thread> // for sleep_for
|
2018-09-22 15:49:43 +08:00
|
|
|
|
2021-12-12 00:58:25 +08:00
|
|
|
#include "ftxui/dom/flexbox_config.hpp" // for ftxui
|
|
|
|
#include "ftxui/dom/node.hpp" // for Render
|
2021-05-02 02:40:35 +08:00
|
|
|
|
2020-03-23 05:32:44 +08:00
|
|
|
int main(int argc, const char* argv[]) {
|
2019-01-12 22:00:08 +08:00
|
|
|
using namespace ftxui;
|
2019-01-07 00:10:35 +08:00
|
|
|
using namespace std::chrono_literals;
|
|
|
|
|
|
|
|
std::string reset_position;
|
2020-03-23 00:33:38 +08:00
|
|
|
for (float percentage = 0.0f; percentage <= 1.0f; percentage += 0.002f) {
|
2021-08-09 06:27:37 +08:00
|
|
|
std::string data_downloaded =
|
|
|
|
std::to_string(int(percentage * 5000)) + "/5000";
|
2020-05-21 02:36:47 +08:00
|
|
|
auto document = hbox({
|
2021-08-09 06:27:37 +08:00
|
|
|
text("downloading:"),
|
2020-05-21 02:36:47 +08:00
|
|
|
gauge(percentage) | flex,
|
2021-08-09 06:27:37 +08:00
|
|
|
text(" " + data_downloaded),
|
2020-05-21 02:36:47 +08:00
|
|
|
});
|
2019-01-07 00:10:35 +08:00
|
|
|
auto screen = Screen(100, 1);
|
2020-05-21 03:23:59 +08:00
|
|
|
Render(screen, document);
|
2021-03-22 05:54:39 +08:00
|
|
|
std::cout << reset_position;
|
|
|
|
screen.Print();
|
2019-01-07 00:10:35 +08:00
|
|
|
reset_position = screen.ResetPosition();
|
2018-09-20 03:52:25 +08:00
|
|
|
|
2018-09-22 15:49:43 +08:00
|
|
|
std::this_thread::sleep_for(0.01s);
|
|
|
|
}
|
|
|
|
std::cout << std::endl;
|
2018-09-20 03:52:25 +08:00
|
|
|
}
|
2020-09-06 19:46:56 +08:00
|
|
|
|
|
|
|
// Copyright 2020 Arthur Sonzogni. All rights reserved.
|
|
|
|
// Use of this source code is governed by the MIT license that can be found in
|
|
|
|
// the LICENSE file.
|