Designer is working great now, and this fixes a bunch of things about the mouse.
This commit is contained in:
		
							parent
							
								
									f05f652c26
								
							
						
					
					
						commit
						ffc787df64
					
				
					 10 changed files with 4958 additions and 91 deletions
				
			
		
							
								
								
									
										100
									
								
								ansi_parser.cpp
									
										
									
									
									
								
							
							
						
						
									
										100
									
								
								ansi_parser.cpp
									
										
									
									
									
								
							|  | @ -20,85 +20,87 @@ static const char _ansi_parser_actions[] = { | ||||||
| 	5, 1, 6, 1, 7, 1, 8, 1,  | 	5, 1, 6, 1, 7, 1, 8, 1,  | ||||||
| 	9, 1, 10, 1, 11, 1, 15, 1,  | 	9, 1, 10, 1, 11, 1, 15, 1,  | ||||||
| 	16, 2, 1, 12, 2, 1, 13, 2,  | 	16, 2, 1, 12, 2, 1, 13, 2,  | ||||||
| 	16, 5, 3, 1, 14, 2 | 	6, 7, 2, 16, 5, 3, 1, 14,  | ||||||
|  | 	2 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_key_offsets[] = { | static const char _ansi_parser_key_offsets[] = { | ||||||
| 	0, 0, 1, 2, 10, 11, 13, 16,  | 	0, 0, 1, 2, 11, 12, 14, 17,  | ||||||
| 	20, 21, 25, 26, 27, 28, 29, 31,  | 	18, 22, 23, 27, 28, 29, 30, 31,  | ||||||
| 	34, 36, 39, 41, 44, 45, 48, 49,  | 	33, 36, 38, 41, 43, 46, 47, 50,  | ||||||
| 	50, 51, 52, 53 | 	51, 52, 53, 54, 55 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const int _ansi_parser_trans_keys[] = { | static const int _ansi_parser_trans_keys[] = { | ||||||
| 	27, 91, 49, 50, 51, 52, 55, 57,  | 	27, 91, 48, 49, 50, 51, 52, 55,  | ||||||
| 	48, 54, 109, 48, 109, 34, 48, 55,  | 	57, 53, 54, 109, 48, 109, 34, 48,  | ||||||
| 	50, 52, 55, 109, 109, 49, 56, 57,  | 	55, 109, 50, 52, 55, 109, 109, 49,  | ||||||
| 	109, 109, 59, 50, 59, 48, 57, 59,  | 	56, 57, 109, 109, 59, 50, 59, 48,  | ||||||
| 	48, 57, 48, 57, 59, 48, 57, 48,  | 	57, 59, 48, 57, 48, 57, 59, 48,  | ||||||
| 	57, 109, 48, 57, 109, 56, 57, 109,  | 	57, 48, 57, 109, 48, 57, 109, 56,  | ||||||
| 	59, 50, 109, 109, 27, 27, 0 | 	57, 109, 59, 50, 109, 109, 27, 27,  | ||||||
|  | 	0 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_single_lengths[] = { | static const char _ansi_parser_single_lengths[] = { | ||||||
| 	0, 1, 1, 6, 1, 2, 3, 4,  | 	0, 1, 1, 7, 1, 2, 3, 1,  | ||||||
| 	1, 4, 1, 1, 1, 1, 0, 1,  | 	4, 1, 4, 1, 1, 1, 1, 0,  | ||||||
| 	0, 1, 0, 1, 1, 3, 1, 1,  | 	1, 0, 1, 0, 1, 1, 3, 1,  | ||||||
| 	1, 1, 1, 1 | 	1, 1, 1, 1, 1 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_range_lengths[] = { | static const char _ansi_parser_range_lengths[] = { | ||||||
| 	0, 0, 0, 1, 0, 0, 0, 0,  | 	0, 0, 0, 1, 0, 0, 0, 0,  | ||||||
| 	0, 0, 0, 0, 0, 0, 1, 1,  | 	0, 0, 0, 0, 0, 0, 0, 1,  | ||||||
| 	1, 1, 1, 1, 0, 0, 0, 0,  | 	1, 1, 1, 1, 1, 0, 0, 0,  | ||||||
| 	0, 0, 0, 0 | 	0, 0, 0, 0, 0 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_index_offsets[] = { | static const char _ansi_parser_index_offsets[] = { | ||||||
| 	0, 0, 2, 4, 12, 14, 17, 21,  | 	0, 0, 2, 4, 13, 15, 18, 22,  | ||||||
| 	26, 28, 33, 35, 37, 39, 41, 43,  | 	24, 29, 31, 36, 38, 40, 42, 44,  | ||||||
| 	46, 48, 51, 53, 56, 58, 62, 64,  | 	46, 49, 51, 54, 56, 59, 61, 65,  | ||||||
| 	66, 68, 70, 72 | 	67, 69, 71, 73, 75 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_trans_targs[] = { | static const char _ansi_parser_trans_targs[] = { | ||||||
| 	2, 1, 3, 0, 5, 7, 9, 21,  | 	2, 1, 3, 0, 4, 5, 8, 10,  | ||||||
| 	25, 6, 4, 0, 27, 0, 6, 27,  | 	22, 26, 6, 7, 0, 28, 0, 6,  | ||||||
| 	0, 4, 4, 4, 0, 4, 4, 8,  | 	28, 0, 7, 7, 7, 0, 28, 0,  | ||||||
| 	27, 0, 27, 0, 10, 11, 20, 27,  | 	7, 7, 9, 28, 0, 28, 0, 11,  | ||||||
| 	0, 27, 0, 12, 0, 13, 0, 14,  | 	12, 21, 28, 0, 28, 0, 13, 0,  | ||||||
| 	0, 15, 0, 16, 15, 0, 17, 0,  | 	14, 0, 15, 0, 16, 0, 17, 16,  | ||||||
| 	18, 17, 0, 19, 0, 27, 19, 0,  | 	0, 18, 0, 19, 18, 0, 20, 0,  | ||||||
| 	27, 0, 22, 24, 27, 0, 23, 0,  | 	28, 20, 0, 28, 0, 23, 25, 28,  | ||||||
| 	13, 0, 27, 0, 27, 0, 2, 1,  | 	0, 24, 0, 14, 0, 28, 0, 28,  | ||||||
| 	2, 1, 0 | 	0, 2, 1, 2, 1, 0 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_trans_actions[] = { | static const char _ansi_parser_trans_actions[] = { | ||||||
| 	0, 7, 0, 0, 21, 21, 21, 21,  | 	0, 7, 0, 0, 21, 21, 21, 21,  | ||||||
| 	21, 21, 21, 0, 0, 0, 0, 0,  | 	21, 21, 21, 21, 0, 31, 0, 0,  | ||||||
| 	0, 0, 0, 0, 0, 0, 0, 0,  | 	0, 0, 0, 0, 0, 0, 0, 0,  | ||||||
| 	17, 0, 15, 0, 0, 0, 0, 0,  | 	0, 0, 0, 17, 0, 15, 0, 0,  | ||||||
| 	0, 19, 0, 0, 0, 3, 0, 0,  | 	0, 0, 0, 0, 19, 0, 0, 0,  | ||||||
| 	0, 1, 0, 25, 0, 0, 1, 0,  | 	3, 0, 0, 0, 1, 0, 25, 0,  | ||||||
| 	28, 0, 0, 1, 0, 34, 0, 0,  | 	0, 1, 0, 28, 0, 0, 1, 0,  | ||||||
| 	9, 0, 0, 0, 0, 0, 0, 0,  | 	37, 0, 0, 9, 0, 0, 0, 0,  | ||||||
| 	5, 0, 11, 0, 13, 0, 0, 7,  | 	0, 0, 0, 5, 0, 11, 0, 13,  | ||||||
| 	23, 31, 0 | 	0, 0, 7, 23, 34, 0 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const char _ansi_parser_eof_actions[] = { | static const char _ansi_parser_eof_actions[] = { | ||||||
| 	0, 0, 0, 0, 0, 0, 0, 0,  | 	0, 0, 0, 0, 0, 0, 0, 0,  | ||||||
| 	0, 0, 0, 0, 0, 0, 0, 0,  | 	0, 0, 0, 0, 0, 0, 0, 0,  | ||||||
| 	0, 0, 0, 0, 0, 0, 0, 0,  | 	0, 0, 0, 0, 0, 0, 0, 0,  | ||||||
| 	0, 0, 0, 23 | 	0, 0, 0, 0, 23 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| static const int ansi_parser_start = 26; | static const int ansi_parser_start = 27; | ||||||
| static const int ansi_parser_first_final = 26; | static const int ansi_parser_first_final = 27; | ||||||
| static const int ansi_parser_error = 0; | static const int ansi_parser_error = 0; | ||||||
| 
 | 
 | ||||||
| static const int ansi_parser_en_main = 26; | static const int ansi_parser_en_main = 27; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| #line 125 "ansi_parser.rl" | #line 125 "ansi_parser.rl" | ||||||
|  | @ -123,14 +125,14 @@ bool ANSIParser::parse(std::wstring_view codes, ColorCB color_cb, WriteCB write_ | ||||||
|   sf::Color* target = &color; |   sf::Color* target = &color; | ||||||
| 
 | 
 | ||||||
|    |    | ||||||
| #line 118 "ansi_parser.cpp" | #line 120 "ansi_parser.cpp" | ||||||
| 	{ | 	{ | ||||||
| 	cs = ansi_parser_start; | 	cs = ansi_parser_start; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| #line 146 "ansi_parser.rl" | #line 146 "ansi_parser.rl" | ||||||
|    |    | ||||||
| #line 121 "ansi_parser.cpp" | #line 123 "ansi_parser.cpp" | ||||||
| 	{ | 	{ | ||||||
| 	int _klen; | 	int _klen; | ||||||
| 	unsigned int _trans; | 	unsigned int _trans; | ||||||
|  | @ -321,7 +323,7 @@ _match: | ||||||
| #line 85 "ansi_parser.rl" | #line 85 "ansi_parser.rl" | ||||||
| 	{} | 	{} | ||||||
| 	break; | 	break; | ||||||
| #line 294 "ansi_parser.cpp" | #line 296 "ansi_parser.cpp" | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -341,7 +343,7 @@ _again: | ||||||
| #line 85 "ansi_parser.rl" | #line 85 "ansi_parser.rl" | ||||||
| 	{} | 	{} | ||||||
| 	break; | 	break; | ||||||
| #line 312 "ansi_parser.cpp" | #line 314 "ansi_parser.cpp" | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -98,7 +98,7 @@ using namespace fmt; | ||||||
|       start %start |       start %start | ||||||
|       ( |       ( | ||||||
|         reset | |         reset | | ||||||
|         "0"  | |         "0" %reset_fg %reset_bg | | ||||||
|         "1"  | |         "1"  | | ||||||
|         "2" %half_bright | |         "2" %half_bright | | ||||||
|         "3"  | |         "3"  | | ||||||
|  |  | ||||||
							
								
								
									
										4830
									
								
								assets/fontlist.json
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										4830
									
								
								assets/fontlist.json
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										12
									
								
								gui.cpp
									
										
									
									
									
								
							
							
						
						
									
										12
									
								
								gui.cpp
									
										
									
									
									
								
							|  | @ -178,6 +178,7 @@ bool GUI::handle_ui_events() { | ||||||
|   auto player = $world.get_the<Player>(); |   auto player = $world.get_the<Player>(); | ||||||
|   int map_font_size = $renderer.font_size(); |   int map_font_size = $renderer.font_size(); | ||||||
|   auto& player_motion = $world.get<Motion>(player.entity); |   auto& player_motion = $world.get<Motion>(player.entity); | ||||||
|  |   Point pos; | ||||||
| 
 | 
 | ||||||
|   while($renderer.poll_event(event)) { |   while($renderer.poll_event(event)) { | ||||||
|     if(event.type == sf::Event::Closed) { |     if(event.type == sf::Event::Closed) { | ||||||
|  | @ -203,15 +204,16 @@ bool GUI::handle_ui_events() { | ||||||
|       } else if(KB::isKeyPressed(KB::S)) { |       } else if(KB::isKeyPressed(KB::S)) { | ||||||
|         save_world(); |         save_world(); | ||||||
|       } else if(KB::isKeyPressed(KB::Tab)) { |       } else if(KB::isKeyPressed(KB::Tab)) { | ||||||
|         $status_ui.$component->OnEvent(Event::Tab); |         $status_ui.key_press(Event::Tab); | ||||||
|       } else if(KB::isKeyPressed(KB::Enter)) { |       } else if(KB::isKeyPressed(KB::Enter)) { | ||||||
|         $status_ui.$component->OnEvent(Event::Return); |         $status_ui.key_press(Event::Return); | ||||||
|       } |       } | ||||||
|     } else if(MOUSE::isButtonPressed(MOUSE::Left)) { |     } else if($renderer.mouse_position($status_ui, pos)) { | ||||||
|       Point pos; |       if(MOUSE::isButtonPressed(MOUSE::Left)) { | ||||||
|       if($renderer.mouse_position($status_ui, pos)) { |  | ||||||
|         $status_ui.mouse_click(Mouse::Button::Left, pos); |         $status_ui.mouse_click(Mouse::Button::Left, pos); | ||||||
|         event_happened = true; |         event_happened = true; | ||||||
|  |       } else { | ||||||
|  |         $status_ui.mouse_release(Mouse::Button::Left, pos); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
							
								
								
									
										16
									
								
								panel.cpp
									
										
									
									
									
								
							
							
						
						
									
										16
									
								
								panel.cpp
									
										
									
									
									
								
							|  | @ -38,13 +38,27 @@ const std::wstring& Panel::to_string() { | ||||||
| void Panel::mouse_click(ftxui::Mouse::Button btn, Point pos) { | void Panel::mouse_click(ftxui::Mouse::Button btn, Point pos) { | ||||||
|   ftxui::Mouse mev{ |   ftxui::Mouse mev{ | ||||||
|     .button=btn, |     .button=btn, | ||||||
|  |     .motion=ftxui::Mouse::Motion::Pressed, | ||||||
|     .x=int(pos.x), .y=int(pos.y) |     .x=int(pos.x), .y=int(pos.y) | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   $component->OnEvent(ftxui::Event::Mouse("", mev)); |   $component->OnEvent(ftxui::Event::Mouse("", mev)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | void Panel::mouse_release(ftxui::Mouse::Button btn, Point pos) { | ||||||
|  |   ftxui::Mouse mev{ | ||||||
|  |     .button=btn, | ||||||
|  |     .motion=ftxui::Mouse::Motion::Released, | ||||||
|  |     .x=int(pos.x), .y=int(pos.y) | ||||||
|  |   }; | ||||||
| 
 | 
 | ||||||
| const Screen &Panel::screen() { |   $component->OnEvent(ftxui::Event::Mouse("", mev)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const Screen& Panel::screen() { | ||||||
|   return $screen; |   return $screen; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | void Panel::key_press(ftxui::Event event) { | ||||||
|  |   $component->OnEvent(event); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -52,6 +52,8 @@ struct Panel { | ||||||
|   void add(Component child); |   void add(Component child); | ||||||
|   void render(); |   void render(); | ||||||
|   void mouse_click(ftxui::Mouse::Button btn, Point pos); |   void mouse_click(ftxui::Mouse::Button btn, Point pos); | ||||||
|  |   void mouse_release(ftxui::Mouse::Button btn, Point pos); | ||||||
|  |   void key_press(ftxui::Event event); | ||||||
|   const std::wstring &to_string(); |   const std::wstring &to_string(); | ||||||
|   const Screen &screen(); |   const Screen &screen(); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -239,9 +239,6 @@ bool SFMLRender::mouse_position(Panel &panel, Point &out) { | ||||||
| 
 | 
 | ||||||
|   auto bounds = panel.grid ? $grid_bounds : $text_bounds; |   auto bounds = panel.grid ? $grid_bounds : $text_bounds; | ||||||
| 
 | 
 | ||||||
|   println("mouse position pos={},{} panel.pos={},{} panel.size={},{}", |  | ||||||
|       pos.x, pos.y, panel.x, panel.y, panel.width, panel.height); |  | ||||||
| 
 |  | ||||||
|   if(pos.x >= panel.x && pos.y >= panel.y |   if(pos.x >= panel.x && pos.y >= panel.y | ||||||
|       && pos.x <= (panel.x + panel.width * bounds.width) |       && pos.x <= (panel.x + panel.width * bounds.width) | ||||||
|       && pos.y <= (panel.y + panel.height * bounds.height)) |       && pos.y <= (panel.y + panel.height * bounds.height)) | ||||||
|  |  | ||||||
|  | @ -1,11 +1,13 @@ | ||||||
| TODAY'S GOAL: | TODAY'S GOAL: | ||||||
| 
 | 
 | ||||||
| 0. \ua3fd causes the character immediately after to vanish. | -1. Learn std::initializer_list by using it. | ||||||
|  | 0. \ua3fd causes the character immediately after to vanish. Make a test and solve it. | ||||||
| 1. Why do Sliders only have to be kept around forever and can't go in containers like everything else? | 1. Why do Sliders only have to be kept around forever and can't go in containers like everything else? | ||||||
| 2. Why are sliders not selected when I click on them? Is it a hover? | 2. Why are sliders not selected when I click on them? Is it a hover? | ||||||
| 3. Why do fonts render blank? Also when I scroll they slowly disappear until there's a column. | 3. Why do fonts render blank? Also when I scroll they slowly disappear until there's a column. | ||||||
| * \u2738 is missing on the row when in grid but works when clicked. | * \u2738 is missing on the row when in grid but works when clicked. | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| * A designer tool to help find characters for foreground, background, and figure out their colors. | * A designer tool to help find characters for foreground, background, and figure out their colors. | ||||||
| 
 | 
 | ||||||
| * renderer's mouse coordinates are totally wrong. Need to put glyph bounds into the panel and then you can ask if a mouse click is on a panel, and what the _panel's_ coordinates are. | * renderer's mouse coordinates are totally wrong. Need to put glyph bounds into the panel and then you can ask if a mouse click is on a panel, and what the _panel's_ coordinates are. | ||||||
|  | @ -14,7 +16,9 @@ TODAY'S GOAL: | ||||||
| 
 | 
 | ||||||
| TODO: | TODO: | ||||||
| 
 | 
 | ||||||
| * Make a unicode helper. | * Refine the event handling to pass most of them to the gui panels and then I can intercept them. | ||||||
|  | 
 | ||||||
|  | * Resolve fmt::format vs std::format. | ||||||
| 
 | 
 | ||||||
| * Fix " room should always be found" | * Fix " room should always be found" | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -17,6 +17,7 @@ | ||||||
| #include <vector> | #include <vector> | ||||||
| #include <nlohmann/json.hpp> | #include <nlohmann/json.hpp> | ||||||
| #include <algorithm> | #include <algorithm> | ||||||
|  | #include <exception> | ||||||
| 
 | 
 | ||||||
| using namespace nlohmann; | using namespace nlohmann; | ||||||
| using namespace fmt; | using namespace fmt; | ||||||
|  | @ -39,19 +40,23 @@ struct FontGrid { | ||||||
|   size_t width; |   size_t width; | ||||||
|   size_t height; |   size_t height; | ||||||
|   vector<vector<FontGridCell>> $grid; |   vector<vector<FontGridCell>> $grid; | ||||||
|  |   string $font_list; | ||||||
|   std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> $converter; |   std::wstring_convert<std::codecvt_utf8_utf16<wchar_t>> $converter; | ||||||
|   vector<wstring> $wcharmap; |   vector<wstring> $wcharmap; | ||||||
|   vector<string> $charmap; |   vector<string> $charmap; | ||||||
| 
 | 
 | ||||||
|   FontGrid(size_t width, size_t height) : |   FontGrid(string font_list, size_t width, size_t height) : | ||||||
|     width(width), height(height), |     width(width), height(height), | ||||||
|     $grid(height, vector<FontGridCell>(width, {0, "", L""})) |     $grid(height, vector<FontGridCell>(width, {0, "", L""})), | ||||||
|  |     $font_list(font_list) | ||||||
|   { |   { | ||||||
|     configure_font(); |     configure_font(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   void configure_font() { |   void configure_font() { | ||||||
|     std::ifstream in_file("./fontlist.json"); |     dbc::check(fs::exists($font_list), format("font listing {} does not exist", $font_list)); | ||||||
|  | 
 | ||||||
|  |     std::ifstream in_file($font_list); | ||||||
|     json input = json::parse(in_file); |     json input = json::parse(in_file); | ||||||
| 
 | 
 | ||||||
|     for(auto inchar : input) { |     for(auto inchar : input) { | ||||||
|  | @ -120,7 +125,6 @@ struct WhatTheColor { | ||||||
| 
 | 
 | ||||||
| class GUI { | class GUI { | ||||||
|   public: |   public: | ||||||
|   DinkyECS::World& $world; |  | ||||||
|   Panel $font_view; |   Panel $font_view; | ||||||
|   Panel $status_ui; |   Panel $status_ui; | ||||||
|   Canvas $canvas; |   Canvas $canvas; | ||||||
|  | @ -133,11 +137,10 @@ class GUI { | ||||||
|   Component $fg_settings; |   Component $fg_settings; | ||||||
|   Component $bg_settings; |   Component $bg_settings; | ||||||
| 
 | 
 | ||||||
|   GUI(DinkyECS::World &world) : |   GUI(string font_list) : | ||||||
|     $world(world), |  | ||||||
|     $font_view(GAME_MAP_POS, 0, GRID_SIZE.x, GRID_SIZE.y, true), |     $font_view(GAME_MAP_POS, 0, GRID_SIZE.x, GRID_SIZE.y, true), | ||||||
|     $status_ui(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT), |     $status_ui(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT), | ||||||
|     $font_grid(GRID_SIZE.x, GRID_SIZE.y), |     $font_grid(font_list, GRID_SIZE.x, GRID_SIZE.y), | ||||||
|     $fg_color{.h=20, .s=50, .v=20}, |     $fg_color{.h=20, .s=50, .v=20}, | ||||||
|     $bg_color{.h=100, .s=100, .v=100} |     $bg_color{.h=100, .s=100, .v=100} | ||||||
|   { |   { | ||||||
|  | @ -157,12 +160,11 @@ class GUI { | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   void draw_font_grid() { |   void draw_font_grid() { | ||||||
|     int flip_it = 0; |  | ||||||
|     for(size_t y = 0; y < $font_grid.height; y++) { |     for(size_t y = 0; y < $font_grid.height; y++) { | ||||||
|       for(size_t x = 0; x < $font_grid.width; x++, flip_it++) { |       for(size_t x = 0; x < $font_grid.width; x++) { | ||||||
|         $canvas.DrawText(x * 2, y * 4, $font_grid.as_string(x, y), [&](auto &pixel) { |         $canvas.DrawText(x * 2, y * 4, $font_grid.as_string(x, y), [&](auto &pixel) { | ||||||
|           pixel.foreground_color = Color::HSV($fg_color.h, $fg_color.s, $fg_color.v / (flip_it % 2 + 1)); |           pixel.foreground_color = Color::HSV($fg_color.h, $fg_color.s, $fg_color.v); | ||||||
|           pixel.background_color = Color::HSV($bg_color.h, $bg_color.s, $bg_color.v / (flip_it % 2 + 1)); |           pixel.background_color = Color::HSV($bg_color.h, $bg_color.s, $bg_color.v); | ||||||
|         }); |         }); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  | @ -238,6 +240,7 @@ class GUI { | ||||||
|     bool event_happened; |     bool event_happened; | ||||||
|     using KB = sf::Keyboard; |     using KB = sf::Keyboard; | ||||||
|     sf::Event event; |     sf::Event event; | ||||||
|  |     Point pos; | ||||||
|     int font_size = $renderer.font_size(); |     int font_size = $renderer.font_size(); | ||||||
|     int page_size = $font_grid.page_size(); |     int page_size = $font_grid.page_size(); | ||||||
| 
 | 
 | ||||||
|  | @ -255,22 +258,29 @@ class GUI { | ||||||
|           $start_char = std::min($font_grid.max_chars() - page_size, $start_char + page_size); |           $start_char = std::min($font_grid.max_chars() - page_size, $start_char + page_size); | ||||||
|           render_grid($start_char, false); |           render_grid($start_char, false); | ||||||
|           $renderer.clear_cache(); |           $renderer.clear_cache(); | ||||||
|  |         } else if(KB::isKeyPressed(KB::Tab)) { | ||||||
|  |           $status_ui.key_press(Event::Tab); | ||||||
|  |         } else if(KB::isKeyPressed(KB::Tab)) { | ||||||
|  |           $status_ui.key_press(Event::Return); | ||||||
|         } else if(KB::isKeyPressed(KB::Equal)) { |         } else if(KB::isKeyPressed(KB::Equal)) { | ||||||
|           resize_fonts(font_size + 10); |           resize_fonts(font_size + 10); | ||||||
|         } else if(KB::isKeyPressed(KB::Hyphen)) { |         } else if(KB::isKeyPressed(KB::Hyphen)) { | ||||||
|           resize_fonts(font_size - 10); |           resize_fonts(font_size - 10); | ||||||
|           event_happened = true; |           event_happened = true; | ||||||
|         } |         } | ||||||
|       } else if(sf::Mouse::isButtonPressed(sf::Mouse::Left)) { |       } else if($renderer.mouse_position($font_view, pos)) { | ||||||
|         Point pos; |         if(sf::Mouse::isButtonPressed(sf::Mouse::Left)) { | ||||||
|         if($renderer.mouse_position($font_view, pos)) { |  | ||||||
|           select_cell(pos); |           select_cell(pos); | ||||||
|           event_happened = true; |           event_happened = true; | ||||||
|         } else if($renderer.mouse_position($status_ui, pos)) { |         } else if(sf::Mouse::isButtonPressed(sf::Mouse::Right)) { | ||||||
|           $status_ui.mouse_click(Mouse::Button::Left, pos); |           deselect_cell(); | ||||||
|  |         } | ||||||
|  |       } else if($renderer.mouse_position($status_ui, pos)) { | ||||||
|  |         if(sf::Mouse::isButtonPressed(sf::Mouse::Left)) { | ||||||
|  |           $status_ui.mouse_click(Mouse::Button::Left, pos); | ||||||
|  |         } else if(event.type == sf::Event::MouseMoved) { | ||||||
|  |           $status_ui.mouse_release(Mouse::Button::Left, pos); | ||||||
|         } |         } | ||||||
|       } else if(sf::Mouse::isButtonPressed(sf::Mouse::Right)) { |  | ||||||
|         deselect_cell(); |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -291,20 +301,26 @@ class GUI { | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| int main(int argc, char *argv[]) { | int main(int argc, char *argv[]) { | ||||||
|   DinkyECS::World world; |   try { | ||||||
|  |     dbc::check(argc == 2, "USAGE: designer fontlist.json"); | ||||||
| 
 | 
 | ||||||
|   GUI gui(world); |     string font_list{argv[1]}; | ||||||
| 
 | 
 | ||||||
|   gui.create_renderer(); |     GUI gui(font_list); | ||||||
| 
 | 
 | ||||||
|   do { |     gui.create_renderer(); | ||||||
|     gui.render_scene(); |  | ||||||
| 
 | 
 | ||||||
|     if(gui.handle_ui_events()) { |     do { | ||||||
|     } |       gui.render_scene(); | ||||||
| 
 | 
 | ||||||
|     std::this_thread::sleep_for(10ms); |       if(gui.handle_ui_events()) { | ||||||
|   } while(gui.$renderer.is_open()); |       } | ||||||
| 
 | 
 | ||||||
|   return 0; |       std::this_thread::sleep_for(10ms); | ||||||
|  |     } while(gui.$renderer.is_open()); | ||||||
|  | 
 | ||||||
|  |     return 0; | ||||||
|  |   } catch(const dbc::Error &e) { | ||||||
|  |     println("ERROR: {}", e.message); | ||||||
|  |   } | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -2,10 +2,8 @@ | ||||||
| #include <iostream> | #include <iostream> | ||||||
| #include <chrono>                   // for operator""s, chrono_literals
 | #include <chrono>                   // for operator""s, chrono_literals
 | ||||||
| #include <thread>                   // for sleep_for
 | #include <thread>                   // for sleep_for
 | ||||||
| #include "dbc.hpp" |  | ||||||
| #include <filesystem> | #include <filesystem> | ||||||
| #include <fcntl.h> | #include <fcntl.h> | ||||||
| #include "constants.hpp" |  | ||||||
| #include <fmt/core.h> | #include <fmt/core.h> | ||||||
| #include <locale> | #include <locale> | ||||||
| #include <codecvt> | #include <codecvt> | ||||||
|  | @ -16,6 +14,8 @@ | ||||||
| #include FT_FREETYPE_H | #include FT_FREETYPE_H | ||||||
| #include FT_TRUETYPE_TABLES_H | #include FT_TRUETYPE_TABLES_H | ||||||
| #include FT_TRUETYPE_IDS_H | #include FT_TRUETYPE_IDS_H | ||||||
|  | #include "dbc.hpp" | ||||||
|  | #include "constants.hpp" | ||||||
| 
 | 
 | ||||||
| using namespace nlohmann; | using namespace nlohmann; | ||||||
| using namespace fmt; | using namespace fmt; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Zed A. Shaw
						Zed A. Shaw