summaryrefslogtreecommitdiffstats
path: root/src/client/gui/main.cpp
diff options
context:
space:
mode:
authorJoursoir <chat@joursoir.net>2020-12-12 12:41:39 +0000
committerJoursoir <chat@joursoir.net>2020-12-12 12:41:39 +0000
commit9f6cdb671ca3c045085bd8eed623e0a797894e1f (patch)
treece220ee696c1e8f902c9a12cdda1f71ba7248d45 /src/client/gui/main.cpp
parent845c0262f4ab243748b085c2608c0e3e28799a0a (diff)
downloadwant-chat-9f6cdb671ca3c045085bd8eed623e0a797894e1f.tar.gz
want-chat-9f6cdb671ca3c045085bd8eed623e0a797894e1f.tar.bz2
want-chat-9f6cdb671ca3c045085bd8eed623e0a797894e1f.zip
GUI feature: handle players and online info from server, show it; fix: close app;
Diffstat (limited to 'src/client/gui/main.cpp')
-rw-r--r--src/client/gui/main.cpp95
1 files changed, 64 insertions, 31 deletions
diff --git a/src/client/gui/main.cpp b/src/client/gui/main.cpp
index 211e020..50aa02f 100644
--- a/src/client/gui/main.cpp
+++ b/src/client/gui/main.cpp
@@ -3,8 +3,9 @@
#include <FL/fl_ask.H>
#include <FL/Fl_Window.H>
-#include "OO_FLTK.hpp"
#include "../../config.hpp"
+#include "../dimensions_client.hpp"
+#include "OO_FLTK.hpp"
#include "Client.hpp"
const int spacing = 20;
@@ -13,66 +14,98 @@ const int indent = 5;
const int chat_w = 695;
const int chat_h = 440;
-const int chat_line_h = 440 / lines_in_chat;
-const int player_w = 225;
-const int player_h = chat_h;
-const int input_w = chat_w + border + spacing + border + player_w;
-const int input_h = 40; // 55
+const int chat_line_h = chat_h / CHAT_LINES;
+
+const int players_w = 225;
+const int players_h = chat_line_h*PLAYERS_LINES+8;
+
+const int tips_w = players_w;
+const int tips_h = chat_line_h*TIPS_LINES+8;
+
+const int input_w = chat_w + border + spacing + border + players_w;
+const int input_h = 40;
const int win_w = spacing + border + (input_w) + border + spacing;
const int win_h = spacing + border + chat_h + border +
spacing + border + input_h + border + spacing;
-
int main(int argc, char **argv)
{
Fl_Window *win = new Fl_Window(win_w, win_h, "WantChat");
win->color(FL_BLACK);
- //
-
+ // Draw chat:
BoxBackground ol_chat(spacing, spacing,
- chat_w+border*2, chat_h+border*2);
- BoxBackground ol_black(spacing+border, spacing+border,
+ chat_w + border*2, chat_h + border*2);
+ BoxBackground ol_chat_black(spacing + border, spacing + border,
chat_w, chat_h, 0, FL_BLACK);
- ChatBaseOutput **chat = new ChatBaseOutput*[18];
- int y = 0;
- for(int i = 0 ; i < 18; i++) {
- chat[i] = new ChatBaseOutput(spacing+border+indent,
- spacing+border+y, chat_w-indent, chat_line_h);
- y += chat_line_h;
+ ChatBaseOutput **chat = new ChatBaseOutput*[CHAT_LINES];
+ for(int i = 0, y = 0; i < CHAT_LINES; i++, y += chat_line_h) {
+ chat[i] = new ChatBaseOutput(spacing + border + indent,
+ spacing + border + y, chat_w - indent, chat_line_h);
}
+ // End draw chat
- //
-
+ // Draw players:
int start_players_x = spacing + border + chat_w + border + spacing;
- BoxBackground ol_players(start_players_x, spacing, player_w+border*2, player_h+border*2);
- ChatBaseOutput *players = new ChatBaseOutput(
- start_players_x + border, spacing+border, player_w, player_h);
-
- //
+ BoxBackground ol_players(start_players_x, spacing,
+ players_w + border*2, players_h + border*2);
+ BoxBackground ol_players_black(start_players_x + border,
+ spacing + border, players_w, players_h, 0, FL_BLACK);
+
+ ChatBaseOutput **players = new ChatBaseOutput*[PLAYERS_LINES];
+ for(int i = 0, y = 0; i < PLAYERS_LINES; i++, y+= chat_line_h) {
+ players[i] = new ChatBaseOutput(start_players_x + border + indent,
+ spacing + border + y, players_w - indent, chat_line_h);
+ }
+ players[PLAYERS_LINES-1]->value("<- /prev /next ->");
+ // End draw players
+
+ // Draw tips:
+ int start_tips_y = spacing + border + players_h + border + spacing + 16; // please, don't ask where i took 16
+ BoxBackground ol_tips(start_players_x, start_tips_y,
+ tips_w + border*2, tips_h + border*2);
+ BoxBackground ol_tips_black(start_players_x + border,
+ start_tips_y + border, tips_w, tips_h, 0, FL_BLACK);
+
+ ChatBaseOutput **tips = new ChatBaseOutput*[TIPS_LINES];
+ for(int i = 0, y = 0; i < TIPS_LINES; i++, y += chat_line_h) {
+ tips[i] = new ChatBaseOutput(start_players_x + border + indent,
+ start_tips_y + border + y, tips_w - indent, chat_line_h);
+ }
+ tips[TIPS_LINES-6]->value(" Tips");
+ tips[TIPS_LINE_GONLINE-1]->value("Online: ");
+ tips[TIPS_LINE_RONLINE-1]->value("Online room: ");
+ tips[TIPS_LINES-3]->value("");
+ tips[TIPS_LINES-2]->value("ESC - exit");
+ tips[TIPS_LINES-1]->value("ENTER - send msg");
+ // End draw tips
- Client *user = new Client(SERVER_IP, SERVER_PORT, chat);
+ Client *user = new Client(SERVER_IP, SERVER_PORT, chat, players, tips);
+ // Draw input:
int start_input_y = spacing + border + chat_h + border + spacing;
- BoxBackground ol_input(spacing, start_input_y, input_w+border*2, input_h+border*2);
- ChatInput input(spacing+border, start_input_y+border, input_w, input_h, 0, user);
-
- //
+ BoxBackground ol_input(spacing, start_input_y,
+ input_w + border*2, input_h + border*2);
+ ChatInput input(spacing + border, start_input_y + border,
+ input_w, input_h, 0, user);
+ // End draw input
win->end();
win->show();
if(user->ConstuctorError()) {
- fl_choice("Server error", "Exit", 0, 0);
+ fl_choice("Application cannot connect to WantChat server\n\
+ Sorry, try later :(", "Exit", 0, 0);
win->hide();
}
while(user->Run())
{
Fl::wait(0);
+ if(!win->visible_r())
+ break;
}
-
return 0;
} \ No newline at end of file