fixed lots of bugs, tweaked objections and added demonserver workaround for disconnecting

This commit is contained in:
OmniTroid 2017-03-22 20:13:16 +01:00
parent 63caae75ea
commit 7af0cbfd1c
7 changed files with 43 additions and 15 deletions

View File

@ -55,6 +55,8 @@ public:
//player number, it's hardly used but might be needed for some old servers
int s_pv = 0;
QString server_software = "";
int char_list_size = 0;
int loaded_chars = 0;
int evidence_list_size = 0;
@ -113,6 +115,7 @@ public:
QString get_char_side(QString p_char);
QString get_showname(QString p_char);
QString get_chat(QString p_char);
QString get_char_shouts(QString p_char);
int get_preanim_duration(QString p_char, QString p_emote);
int get_ao2_preanim_duration(QString p_char, QString p_emote);
int get_text_delay(QString p_char, QString p_emote);

View File

@ -20,13 +20,19 @@ void AOMovie::set_play_once(bool p_play_once)
play_once = p_play_once;
}
void AOMovie::play(QString p_gif, QString p_char)
void AOMovie::play(QString p_gif, QString p_char, QString p_custom_theme)
{
m_movie->stop();
QString gif_path;
QString custom_path = ao_app->get_character_path(p_char) + p_gif + ".gif";
QString custom_path;
if (p_gif == "custom")
custom_path = ao_app->get_character_path(p_char) + p_gif + ".gif";
else
custom_path = ao_app->get_character_path(p_char) + p_gif + "_bubble.gif";
QString custom_theme_path = ao_app->get_base_path() + "themes/" + p_custom_theme + "/" + p_gif + ".gif";
QString theme_path = ao_app->get_theme_path() + p_gif + ".gif";
QString default_theme_path = ao_app->get_default_theme_path() + p_gif + ".gif";
QString placeholder_path = ao_app->get_theme_path() + "placeholder.gif";
@ -34,6 +40,8 @@ void AOMovie::play(QString p_gif, QString p_char)
if (file_exists(custom_path))
gif_path = custom_path;
else if (file_exists(custom_theme_path))
gif_path = custom_theme_path;
else if (file_exists(theme_path))
gif_path = theme_path;
else if (file_exists(default_theme_path))

View File

@ -15,7 +15,7 @@ public:
AOMovie(QWidget *p_parent, AOApplication *p_ao_app);
void set_play_once(bool p_play_once);
void play(QString p_gif, QString p_char = "");
void play(QString p_gif, QString p_char = "", QString p_custom_theme = "");
void combo_resize(int w, int h);
void stop();

View File

@ -596,6 +596,8 @@ void Courtroom::done_received()
void Courtroom::set_background(QString p_background)
{
testimony_in_progress = false;
current_background = p_background;
QString bg_path = get_background_path();
@ -940,7 +942,7 @@ void Courtroom::handle_chatmessage(QStringList *p_contents)
chatmessage_is_empty = m_chatmessage[MESSAGE] == " " || m_chatmessage[MESSAGE] == "";
if (m_chatmessage[MESSAGE] == ui_ic_chat_message->text())
if (m_chatmessage[MESSAGE] == ui_ic_chat_message->text() && m_chatmessage[CHAR_ID].toInt() == m_cid)
{
ui_ic_chat_message->clear();
objection_state = 0;
@ -958,6 +960,8 @@ void Courtroom::handle_chatmessage(QStringList *p_contents)
previous_ic_message = f_message;
int objection_mod = m_chatmessage[OBJECTION_MOD].toInt();
QString f_char = m_chatmessage[CHAR_NAME];
QString f_custom_theme = ao_app->get_char_shouts(f_char);
//if an objection is used
if (objection_mod <= 4 && objection_mod >= 1)
@ -965,21 +969,21 @@ void Courtroom::handle_chatmessage(QStringList *p_contents)
switch (objection_mod)
{
case 1:
ui_vp_objection->play("holdit");
objection_player->play("holdit.wav", m_chatmessage[CHAR_NAME]);
ui_vp_objection->play("holdit", f_char, f_custom_theme);
objection_player->play("holdit.wav", f_char);
break;
case 2:
ui_vp_objection->play("objection");
objection_player->play("objection.wav", m_chatmessage[CHAR_NAME]);
ui_vp_objection->play("objection", f_char, f_custom_theme);
objection_player->play("objection.wav", f_char);
break;
case 3:
ui_vp_objection->play("takethat");
objection_player->play("takethat.wav", m_chatmessage[CHAR_NAME]);
ui_vp_objection->play("takethat", f_char, f_custom_theme);
objection_player->play("takethat.wav", f_char);
break;
//case 4 is AO2 only
case 4:
ui_vp_objection->play("custom", m_chatmessage[CHAR_NAME]);
objection_player->play("custom.wav", m_chatmessage[CHAR_NAME]);
ui_vp_objection->play("custom", f_char, f_custom_theme);
objection_player->play("custom.wav", f_char);
break;
default:
qDebug() << "W: Logic error in objection switch statement!";
@ -1933,6 +1937,10 @@ void Courtroom::check_connection_received()
void Courtroom::connection_timeout()
{
//cheap hack because demonsoftware refuses to conform to standards
if (ao_app->server_software.startsWith("AODemon"))
return;
call_notice("Disconnected from server.");
ao_app->construct_lobby();
ao_app->destruct_courtroom();

View File

@ -26,6 +26,7 @@ Lobby::Lobby(AOApplication *p_ao_app) : QMainWindow()
ui_player_count = new QLabel(this);
ui_description = new QPlainTextEdit(this);
ui_chatbox = new QTextBrowser(this);
ui_chatbox->setOpenExternalLinks(true);
ui_chatname = new QLineEdit(this);
ui_chatname->setPlaceholderText("Name");
ui_chatmessage = new QLineEdit(this);

View File

@ -146,6 +146,7 @@ void AOApplication::server_packet_received(AOPacket *p_packet)
goto end;
s_pv = f_contents.at(0).toInt();
server_software = f_contents.at(1);
QString server_software = f_contents.at(1);

View File

@ -19,7 +19,7 @@ QString AOApplication::read_config(QString searchline)
while(!in.atEnd())
{
QString f_line = in.readLine();
QString f_line = in.readLine().trimmed();
if (!f_line.startsWith(searchline))
continue;
@ -163,7 +163,7 @@ QString AOApplication::read_design_ini(QString p_identifier, QString p_design_pa
while (!in.atEnd())
{
QString f_line = in.readLine();
QString f_line = in.readLine().trimmed();
if (!f_line.startsWith(p_identifier))
continue;
@ -362,6 +362,13 @@ QString AOApplication::get_chat(QString p_char)
return f_result.toLower();
}
QString AOApplication::get_char_shouts(QString p_char)
{
QString f_result = read_char_ini(p_char, "shouts", "[Options]", "[Time]");
return f_result.toLower();
}
int AOApplication::get_preanim_duration(QString p_char, QString p_emote)
{
QString f_result = read_char_ini(p_char, p_emote, "[Time]", "[Emotions]");