// Render job roles
const int ParametersRole = Qt::UserRole + 1;
const int TimeRole = Qt::UserRole + 2;
+const int ProgressRole = Qt::UserRole + 3;
+const int ExtraInfoRole = Qt::UserRole + 5;
const int ScriptType = QTreeWidgetItem::UserType;
RenderJobItem::RenderJobItem(QTreeWidget * parent, const QStringList & strings, int type) : QTreeWidgetItem(parent, strings, type),
m_status(-1)
{
- setSizeHint(1, QSize(parent->columnWidth(1), parent->fontMetrics().height() * 2));
+ setSizeHint(1, QSize(parent->columnWidth(1), parent->fontMetrics().height() * 3));
setStatus(WAITINGJOB);
}
case FINISHEDJOB:
setData(1, Qt::UserRole, i18n("Rendering finished"));
setIcon(0, KIcon("dialog-ok"));
- setData(2, Qt::UserRole, 100);
+ setData(1, ProgressRole, 100);
break;
case FAILEDJOB:
setData(1, Qt::UserRole, i18n("Rendering crashed"));
setIcon(0, KIcon("dialog-close"));
- setData(2, Qt::UserRole, 100);
+ setData(1, ProgressRole, 100);
break;
case ABORTEDJOB:
setData(1, Qt::UserRole, i18n("Rendering aborted"));
setIcon(0, KIcon("dialog-cancel"));
- setData(2, Qt::UserRole, 100);
+ setData(1, ProgressRole, 100);
default:
break;
m_view.out_file->setMode(KFile::File);
- m_view.running_jobs->setHeaderLabels(QStringList() << QString() << i18n("File") << i18n("Progress"));
+ m_view.running_jobs->setHeaderLabels(QStringList() << QString() << i18n("File"));
m_jobsDelegate = new RenderViewDelegate(this);
m_view.running_jobs->setItemDelegate(m_jobsDelegate);
header->setResizeMode(0, QHeaderView::Fixed);
header->resizeSection(0, 30);
header->setResizeMode(1, QHeaderView::Interactive);
- header->setResizeMode(2, QHeaderView::Fixed);
- header->resizeSection(1, width() * 2 / 3 - 15);
- header->setResizeMode(2, QHeaderView::Interactive);
- //header->setResizeMode(1, QHeaderView::Fixed);
-
m_view.scripts_list->setHeaderLabels(QStringList() << QString() << i18n("Script Files"));
m_scriptsDelegate = new RenderViewDelegate(this);
KMessageBox::information(this, i18n("There is already a job writing file:<br /><b>%1</b><br />Abort the job if you want to overwrite it...", dest), i18n("Already running"));
return;
}
- renderItem->setData(2, Qt::UserRole, 0);
+ renderItem->setData(1, ProgressRole, 0);
renderItem->setStatus(WAITINGJOB);
} else {
- renderItem = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << dest << QString());
+ renderItem = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << dest);
}
renderItem->setData(1, TimeRole, QTime::currentTime());
}
}
renderItem->setData(1, ParametersRole, render_process_args);
- if (exportAudio == false) renderItem->setData(1, Qt::UserRole + 5, i18n("Video without audio track"));
- else renderItem->setData(1, Qt::UserRole + 5, QString());
+ if (exportAudio == false) renderItem->setData(1, ExtraInfoRole, i18n("Video without audio track"));
+ else renderItem->setData(1, ExtraInfoRole, QString());
m_view.running_jobs->setCurrentItem(renderItem);
m_view.tabWidget->setCurrentIndex(1);
checkRenderStatus();
QList<QTreeWidgetItem *> existing = m_view.running_jobs->findItems(dest, Qt::MatchExactly, 1);
if (!existing.isEmpty()) item = static_cast<RenderJobItem*> (existing.at(0));
else {
- item = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << dest << QString());
+ item = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << dest);
if (progress == 0) {
item->setStatus(WAITINGJOB);
}
}
- item->setData(2, Qt::UserRole, progress);
+ item->setData(1, ProgressRole, progress);
item->setStatus(RUNNINGJOB);
if (progress == 0) {
item->setIcon(0, KIcon("system-run"));
QList<QTreeWidgetItem *> existing = m_view.running_jobs->findItems(dest, Qt::MatchExactly, 1);
if (!existing.isEmpty()) item = static_cast<RenderJobItem*> (existing.at(0));
else {
- item = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << dest << QString());
- item->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 2));
+ item = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << dest);
}
if (status == -1) {
// Job finished successfully
activate = true;
}
m_view.abort_job->setEnabled(activate);
+ /*
for (int i = 0; i < m_view.running_jobs->topLevelItemCount(); i++) {
current = static_cast<RenderJobItem*>(m_view.running_jobs->topLevelItem(i));
if (current == static_cast<RenderJobItem*> (m_view.running_jobs->currentItem())) {
current->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 3));
} else current->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 2));
- }
+ }*/
}
void RenderWidget::slotCLeanUpJobs()
KMessageBox::information(this, i18n("There is already a job writing file:<br /><b>%1</b><br />Abort the job if you want to overwrite it...", destination), i18n("Already running"));
return;
}
- } else renderItem = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << destination << QString(), ScriptType);
- renderItem->setData(2, Qt::UserRole, 0);
+ } else renderItem = new RenderJobItem(m_view.running_jobs, QStringList() << QString() << destination, ScriptType);
+ renderItem->setData(1, ProgressRole, 0);
renderItem->setStatus(WAITINGJOB);
renderItem->setIcon(0, KIcon("media-playback-pause"));
renderItem->setData(1, Qt::UserRole, i18n("Waiting..."));
- renderItem->setSizeHint(1, QSize(m_view.running_jobs->columnWidth(1), fontMetrics().height() * 2));
renderItem->setData(1, TimeRole, QTime::currentTime());
renderItem->setData(1, ParametersRole, path);
checkRenderStatus();
const QModelIndex &index) const {
if (index.column() == 1) {
painter->save();
- int factor = 2;
QStyleOptionViewItemV4 opt(option);
QStyle *style = opt.widget ? opt.widget->style() : QApplication::style();
const int textMargin = style->pixelMetric(QStyle::PM_FocusFrameHMargin) + 1;
style->drawPrimitive(QStyle::PE_PanelItemViewItem, &opt, painter, opt.widget);
- if (option.state & QStyle::State_Selected) {
- painter->setPen(option.palette.highlightedText().color());
- factor = 3;
- }// else painter->setPen(option.palette.color(QPalette::Text));
QFont font = painter->font();
font.setBold(true);
painter->setFont(font);
QRect r1 = option.rect;
r1.adjust(0, textMargin, 0, - textMargin);
- int mid = (int)((r1.height() / factor));
+ int mid = (int)((r1.height() / 2));
r1.setBottom(r1.y() + mid);
- painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data().toString());
- r1.setBottom(r1.bottom() + mid);
- r1.setTop(r1.bottom() - mid);
+ QRect bounding;
+ painter->drawText(r1, Qt::AlignLeft | Qt::AlignTop ,index.data().toString(), &bounding);
+ r1.moveTop(r1.bottom() - textMargin);
font.setBold(false);
painter->setFont(font);
- painter->drawText(r1, Qt::AlignLeft | Qt::AlignVCenter , index.data(Qt::UserRole).toString());
- if (factor > 2) {
- r1.setBottom(r1.bottom() + mid);
+ painter->drawText(r1, Qt::AlignLeft | Qt::AlignTop , index.data(Qt::UserRole).toString());
+ int progress = index.data(Qt::UserRole + 3).toInt();
+ if (progress > 0 && progress < 100) {
+ QColor color = option.palette.alternateBase().color();
+ QColor fgColor = option.palette.text().color();
+ color.setAlpha(150);
+ fgColor.setAlpha(150);
+ painter->setBrush(QBrush(color));
+ painter->setPen(QPen(fgColor));
+ int width = qMin(200, r1.width() - 4);
+ QRect bgrect(r1.left() + 2, option.rect.bottom() - 6 - textMargin, width, 6);
+ painter->drawRect(bgrect);
+ painter->setBrush(QBrush(fgColor));
+ bgrect.adjust(2, 2, 0, -1);
+ painter->setPen(Qt::NoPen);
+ bgrect.setWidth((width - 2) * progress / 100);
+ painter->drawRect(bgrect);
+ } else {
+ r1.setBottom(opt.rect.bottom());
r1.setTop(r1.bottom() - mid);
- painter->drawText(r1, Qt::AlignLeft | Qt::AlignVCenter , index.data(Qt::UserRole + 5).toString());
+ painter->drawText(r1, Qt::AlignLeft | Qt::AlignBottom , index.data(Qt::UserRole + 5).toString());
}
painter->restore();
} else if (index.column() == 2) {