smoothen chatroom change
diff --git a/chatdialog.cpp b/chatdialog.cpp
index e118969..031189e 100644
--- a/chatdialog.cpp
+++ b/chatdialog.cpp
@@ -14,7 +14,7 @@
static const int HELLO_INTERVAL = 90; // seconds
ChatDialog::ChatDialog(QWidget *parent)
- : QDialog(parent), m_sock(NULL), m_lastMsgTime(0)
+ : QDialog(parent), m_sock(NULL), m_lastMsgTime(0), m_sendJoin(true)
{
// have to register this, otherwise
// the signal-slot system won't recognize this type
@@ -473,11 +473,12 @@
{
time_t now = time(NULL);
int elapsed = now - m_lastMsgTime;
- if (elapsed >= m_randomizedInterval / 1000)
+ if (elapsed >= m_randomizedInterval / 1000 || m_sendJoin)
{
SyncDemo::ChatMessage msg;
formHelloMessage(msg);
sendMsg(msg);
+ m_sendJoin = false;
QTimer::singleShot(m_randomizedInterval, this, SLOT(sendHello()));
}
else
@@ -526,6 +527,9 @@
m_scene->clearAll();
m_scene->plot("Empty");
}
+
+ textEdit->clear();
+
// TODO: perhaps need to do a lot. e.g. use a new SyncAppSokcet
if (m_sock != NULL)
{
@@ -538,6 +542,7 @@
try
{
m_sock = new Sync::SyncAppSocket(syncPrefix, bind(&ChatDialog::processTreeUpdateWrapper, this, _1, _2), bind(&ChatDialog::processRemoveWrapper, this, _1));
+ m_sendJoin = true;
sendHello();
m_timer->start(FRESHNESS * 2000);
}
diff --git a/chatdialog.h b/chatdialog.h
index 902316f..7428667 100644
--- a/chatdialog.h
+++ b/chatdialog.h
@@ -86,6 +86,7 @@
int m_randomizedInterval;
QTimer *m_timer;
QStringListModel *m_rosterModel;
+ bool m_sendJoin;
// icon related
QAction *minimizeAction;