FTXUI 6.1.9
C++ functional terminal UI.
Loading...
Searching...
No Matches
color_gallery.cpp
Go to the documentation of this file.
1// Copyright 2020 Arthur Sonzogni. All rights reserved.
2// このソースコードの使用は、LICENSEファイルにあるMITライセンスによって管理されています。
3#include <ftxui/screen/color_info.hpp> // for ColorInfo
4#include <ftxui/screen/screen.hpp> // for Full, Screen
5#include <ftxui/screen/terminal.hpp> // for ColorSupport, Color, Palette16, Palette256, TrueColor
6#include <memory> // for allocator, shared_ptr
7#include <utility> // for move
8#include <vector> // for vector
9
10#include "ftxui/dom/elements.hpp" // for text, bgcolor, color, vbox, hbox, separator, operator|, Elements, Element, Fit, border
11#include "ftxui/dom/node.hpp" // for Render
12#include "ftxui/screen/color.hpp" // for Color, Color::Black, Color::Blue, Color::BlueLight, Color::Cyan, Color::CyanLight, Color::Default, Color::GrayDark, Color::GrayLight, Color::Green, Color::GreenLight, Color::Magenta, Color::MagentaLight, Color::Red, Color::RedLight, Color::White, Color::Yellow, Color::YellowLight, Color::Palette256, ftxui
13
14using namespace ftxui;
15#include "./color_info_sorted_2d.ipp" // for ColorInfoSorted2D
16
17int main() {
18 // clang-format off
19 auto basic_color_display =
20 vbox(
21 text("16色パレット:"),
22 separator(),
23 hbox(
24 vbox(
25 color(Color::Default, text("デフォルト")),
26 color(Color::Black, text("黒")),
27 color(Color::GrayDark, text("濃い灰色")),
28 color(Color::GrayLight, text("薄い灰色")),
29 color(Color::White, text("白")),
30 color(Color::Blue, text("青")),
31 color(Color::BlueLight, text("水色")),
32 color(Color::Cyan, text("シアン")),
33 color(Color::CyanLight, text("明るいシアン")),
34 color(Color::Green, text("緑")),
35 color(Color::GreenLight, text("明るい緑")),
36 color(Color::Magenta, text("マゼンタ")),
37 color(Color::MagentaLight, text("明るいマゼンタ")),
38 color(Color::Red, text("赤")),
39 color(Color::RedLight, text("明るい赤")),
40 color(Color::Yellow, text("黄")),
41 color(Color::YellowLight, text("明るい黄"))
42 ),
43 vbox(
44 bgcolor(Color::Default, text("デフォルト")),
45 bgcolor(Color::Black, text("黒")),
46 bgcolor(Color::GrayDark, text("濃い灰色")),
47 bgcolor(Color::GrayLight, text("薄い灰色")),
48 bgcolor(Color::White, text("白")),
49 bgcolor(Color::Blue, text("青")),
50 bgcolor(Color::BlueLight, text("水色")),
51 bgcolor(Color::Cyan, text("シアン")),
52 bgcolor(Color::CyanLight, text("明るいシアン")),
53 bgcolor(Color::Green, text("緑")),
54 bgcolor(Color::GreenLight, text("明るい緑")),
55 bgcolor(Color::Magenta, text("マゼンタ")),
56 bgcolor(Color::MagentaLight, text("明るいマゼンタ")),
57 bgcolor(Color::Red, text("赤")),
58 bgcolor(Color::RedLight, text("明るい赤")),
59 bgcolor(Color::Yellow, text("黄")),
60 bgcolor(Color::YellowLight, text("明るい黄"))
61 )
62 )
63 );
64
65 // clang-format on
66 auto palette_256_color_display = text("256色パレット:");
67 {
68 std::vector<std::vector<ColorInfo>> info_columns = ColorInfoSorted2D();
69 Elements columns;
70 for (auto& column : info_columns) {
71 Elements column_elements;
72 for (auto& it : column) {
73 column_elements.push_back(
74 text(" ") | bgcolor(Color(Color::Palette256(it.index_256))));
75 }
76 columns.push_back(hbox(std::move(column_elements)));
77 }
78 palette_256_color_display = vbox({
79 palette_256_color_display,
80 separator(),
81 vbox(columns),
82 });
83 }
84
85 // トゥルーカラー表示。
86 auto true_color_display = text("トゥルーカラー: 24ビット:");
87 {
88 const int max_value = 255;
89 const int value_increment = 8;
90 const int hue_increment = 6;
91 int saturation = max_value;
92 Elements array;
93 for (int value = 0; value < max_value; value += 2 * value_increment) {
94 Elements line;
95 for (int hue = 0; hue < max_value; hue += hue_increment) {
96 line.push_back(
97 text("▀") //
98 | color(Color::HSV(hue, saturation, value)) //
99 | bgcolor(Color::HSV(hue, saturation, value + value_increment)));
100 }
101 array.push_back(hbox(std::move(line)));
102 }
103 true_color_display = vbox({
104 true_color_display,
105 separator(),
106 vbox(std::move(array)),
107 });
108 }
109
110 auto terminal_info =
111 vbox({
112 Terminal::ColorSupport() >= Terminal::Color::Palette16
113 ? text(" 16色パレット対応: はい")
114 : text(" 16色パレット対応: いいえ"),
115 Terminal::ColorSupport() >= Terminal::Color::Palette256
116 ? text("256色パレット対応: はい")
117 : text("256色パレット対応: いいえ"),
118 Terminal::ColorSupport() >= Terminal::Color::TrueColor
119 ? text(" トゥルーカラー対応: はい")
120 : text(" トゥルーカラー対応: いいえ"),
121 }) |
122 border;
123
124 auto document = vbox({hbox({
125 basic_color_display,
126 text(" "),
127 palette_256_color_display,
128 text(" "),
129 true_color_display,
130 }),
131 terminal_info});
132 // clang-format on
133
134 auto screen = Screen::Create(Dimension::Full(), Dimension::Fit(document));
135 Render(screen, document);
136
137 screen.Print();
138
139 return 0;
140}
std::vector< std::vector< ftxui::ColorInfo > > ColorInfoSorted2D()
Decorator bgcolor(Color)
背景色を使用して装飾します。
Element text(std::wstring text)
ユニコードテキストを表示します。
Definition text.cpp:160
void Render(Screen &screen, const Element &element)
要素をftxui::Screenに表示します。
Definition node.cpp:84
Decorator color(Color)
前景色を使用して装飾します。
Element vbox(Elements)
要素を縦に一つずつ表示するコンテナ。
Definition vbox.cpp:94
static Color HSV(uint8_t hue, uint8_t saturation, uint8_t value)
HSV表現から色を構築します。 https://en.wikipedia.org/wiki/HSL_and_HSV.
static Screen Create(Dimensions dimension)
指定された次元を持つスクリーンを作成します。
Definition screen.cpp:394
Colorは、ターミナルユーザーインターフェースにおける色を表すクラスです。
Definition color.hpp:25
FTXUI ftxui:: 名前空間
Definition animation.hpp:9
Element hbox(Elements)
要素を水平方向に1つずつ表示するコンテナ。
Definition hbox.cpp:93
std::vector< Element > Elements
Definition elements.hpp:22
Element separator()