Optimized channel loading and layout.

git-svn-id: http://svn.code.sf.net/p/retroshare/code/trunk@5118 b45a01b8-16f6-495d-af2f-9b41ad6348cc
This commit is contained in:
thunder2 2012-04-24 15:34:22 +00:00
parent 3678766a93
commit 3dca71330c
4 changed files with 47 additions and 52 deletions

View File

@ -51,6 +51,8 @@
* #define CHAN_DEBUG * #define CHAN_DEBUG
***/ ***/
#define USE_THREAD
/** Constructor */ /** Constructor */
ChannelFeed::ChannelFeed(QWidget *parent) ChannelFeed::ChannelFeed(QWidget *parent)
: RsAutoUpdatePage(1000,parent) : RsAutoUpdatePage(1000,parent)
@ -528,6 +530,7 @@ void ChannelFeed::updateChannelMsgs()
actionEnable_Auto_Download->setEnabled(false); actionEnable_Auto_Download->setEnabled(false);
} }
#ifdef USE_THREAD
progressLabel->show(); progressLabel->show();
progressBar->reset(); progressBar->reset();
progressBar->show(); progressBar->show();
@ -537,21 +540,33 @@ void ChannelFeed::updateChannelMsgs()
// connect thread // connect thread
connect(fillThread, SIGNAL(finished()), this, SLOT(fillThreadFinished()), Qt::BlockingQueuedConnection); connect(fillThread, SIGNAL(finished()), this, SLOT(fillThreadFinished()), Qt::BlockingQueuedConnection);
connect(fillThread, SIGNAL(progress(int,int)), this, SLOT(fillThreadProgress(int,int))); connect(fillThread, SIGNAL(addMsg(QString,QString,int,int)), this, SLOT(fillThreadAddMsg(QString,QString,int,int)), Qt::BlockingQueuedConnection);
connect(fillThread, SIGNAL(addMsg(QString,QString)), this, SLOT(fillThreadAddMsg(QString,QString)), Qt::BlockingQueuedConnection);
#ifdef DEBUG_FORUMS #ifdef CHAN_DEBUG
std::cerr << "ChannelFeed::updateChannelMsgs() Start fill thread" << std::endl; std::cerr << "ChannelFeed::updateChannelMsgs() Start fill thread" << std::endl;
#endif #endif
// start thread // start thread
fillThread->start(); fillThread->start();
#else
std::list<ChannelMsgSummary> msgs;
std::list<ChannelMsgSummary>::iterator it;
rsChannels->getChannelMsgList(mChannelId, msgs);
msgs.sort(sortChannelMsgSummary);
for (it = msgs.begin(); it != msgs.end(); it++) {
ChanMsgItem *cmi = new ChanMsgItem(this, 0, mChannelId, it->msgId, true);
mChanMsgItems.push_back(cmi);
verticalLayout_2->addWidget(cmi);
}
#endif
} }
void ChannelFeed::fillThreadFinished() void ChannelFeed::fillThreadFinished()
{ {
#ifdef DEBUG_FORUMS #ifdef CHAN_DEBUG
std::cerr << "ChannelFeed::fillThreadFinished" << std::endl; std::cerr << "ChannelFeed::fillThreadFinished()" << std::endl;
#endif #endif
// thread has finished // thread has finished
@ -564,40 +579,37 @@ void ChannelFeed::fillThreadFinished()
fillThread = NULL; fillThread = NULL;
} }
#ifdef CHAN_DEBUG
if (thread->wasStopped()) { if (thread->wasStopped()) {
// thread was stopped // thread was stopped
#ifdef DEBUG_FORUMS std::cerr << "ChannelFeed::fillThreadFinished() Thread was stopped" << std::endl;
std::cerr << "ChannelFeed::fillThreadFinished Thread was stopped" << std::endl;
#endif
} }
#endif
#ifdef DEBUG_FORUMS #ifdef CHAN_DEBUG
std::cerr << "ChannelFeed::fillThreadFinished Delete thread" << std::endl; std::cerr << "ChannelFeed::fillThreadFinished() Delete thread" << std::endl;
#endif #endif
thread->deleteLater(); thread->deleteLater();
thread = NULL; thread = NULL;
} }
#ifdef DEBUG_FORUMS #ifdef CHAN_DEBUG
std::cerr << "ChannelFeed::fillThreadFinished done" << std::endl; std::cerr << "ChannelFeed::fillThreadFinished done()" << std::endl;
#endif #endif
} }
void ChannelFeed::fillThreadProgress(int current, int count) void ChannelFeed::fillThreadAddMsg(const QString &channelId, const QString &channelMsgId, int current, int count)
{ {
if (sender() == fillThread) {
// show fill progress // show fill progress
if (count) { if (count) {
progressBar->setValue(current * progressBar->maximum() / count); progressBar->setValue(current * progressBar->maximum() / count);
} }
}
void ChannelFeed::fillThreadAddMsg(const QString &channelId, const QString &channelMsgId)
{
if (sender() == fillThread) {
ChanMsgItem *cmi = new ChanMsgItem(this, 0, channelId.toStdString(), channelMsgId.toStdString(), true); ChanMsgItem *cmi = new ChanMsgItem(this, 0, channelId.toStdString(), channelMsgId.toStdString(), true);
mChanMsgItems.push_back(cmi); mChanMsgItems.push_back(cmi);
verticalLayout_2->addWidget(cmi); verticalLayout->addWidget(cmi);
} }
} }
@ -808,8 +820,7 @@ void ChannelFillThread::run()
break; break;
} }
emit addMsg(QString::fromStdString(channelId), QString::fromStdString(it->msgId)); emit addMsg(QString::fromStdString(channelId), QString::fromStdString(it->msgId), ++pos, count);
emit progress(++pos, count);
} }
#ifdef CHAN_DEBUG #ifdef CHAN_DEBUG

View File

@ -80,8 +80,7 @@ private slots:
void generateMassData(); void generateMassData();
void fillThreadFinished(); void fillThreadFinished();
void fillThreadProgress(int current, int count); void fillThreadAddMsg(const QString &channelId, const QString &channelMsgId, int current, int count);
void fillThreadAddMsg(const QString &channelId, const QString &channelMsgId);
private: private:
void updateChannelList(); void updateChannelList();
@ -121,8 +120,7 @@ public:
bool wasStopped() { return stopped; } bool wasStopped() { return stopped; }
signals: signals:
void progress(int current, int count); void addMsg(const QString &channelId, const QString &channelMsgId, int current, int count);
void addMsg(const QString &channelId, const QString &channelMsgId);
public: public:
std::string channelId; std::string channelId;

View File

@ -513,18 +513,21 @@ border-image: url(:/images/btn_26_pressed.png) 4;
<property name="widgetResizable"> <property name="widgetResizable">
<bool>true</bool> <bool>true</bool>
</property> </property>
<property name="alignment">
<set>Qt::AlignBottom|Qt::AlignLeading|Qt::AlignLeft</set>
</property>
<widget class="QWidget" name="scrollAreaWidgetContents"> <widget class="QWidget" name="scrollAreaWidgetContents">
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>0</x> <x>0</x>
<y>0</y> <y>0</y>
<width>400</width> <width>400</width>
<height>304</height> <height>16</height>
</rect> </rect>
</property> </property>
<property name="sizePolicy">
<sizepolicy hsizetype="Preferred" vsizetype="Fixed">
<horstretch>0</horstretch>
<verstretch>0</verstretch>
</sizepolicy>
</property>
<property name="styleSheet"> <property name="styleSheet">
<string notr="true">QWidget#scrollAreaWidgetContents{border: none;}</string> <string notr="true">QWidget#scrollAreaWidgetContents{border: none;}</string>
</property> </property>
@ -535,25 +538,6 @@ border-image: url(:/images/btn_26_pressed.png) 4;
<property name="margin"> <property name="margin">
<number>0</number> <number>0</number>
</property> </property>
<item>
<layout class="QVBoxLayout" name="verticalLayout_2"/>
</item>
<item>
<spacer name="verticalSpacer">
<property name="orientation">
<enum>Qt::Vertical</enum>
</property>
<property name="sizeType">
<enum>QSizePolicy::MinimumExpanding</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>0</width>
<height>0</height>
</size>
</property>
</spacer>
</item>
</layout> </layout>
</widget> </widget>
</widget> </widget>

View File

@ -182,7 +182,9 @@ QString formatText(const QString &text, unsigned int flag)
if (flag & RSHTML_FORMATTEXT_REMOVE_COLOR) { if (flag & RSHTML_FORMATTEXT_REMOVE_COLOR) {
optimizeFlag |= RSHTML_OPTIMIZEHTML_REMOVE_COLOR; optimizeFlag |= RSHTML_OPTIMIZEHTML_REMOVE_COLOR;
} }
if (optimizeFlag) {
optimizeHtml(formattedText, optimizeFlag); optimizeHtml(formattedText, optimizeFlag);
}
return formattedText; return formattedText;
} }