This commit is contained in:
Gangphon 2023-05-09 15:08:39 +08:00
parent dc2a505a35
commit c1b21b55af
8 changed files with 99 additions and 110 deletions

View File

@ -1,5 +1,4 @@
#include "emultiwin.h" #include "emultiwin.h"
#include "cfg.h"
#include "tools.h" #include "tools.h"
#include "base/extendedgroupbox.h" #include "base/extendedgroupbox.h"
#include "ebase.h" #include "ebase.h"
@ -39,7 +38,7 @@ EMultiWin::EMultiWin(const QJsonObject &json, PageListItem *pageItem) : mPageIte
else if(type=="Temp") inner = new EEnviron(element.toObject(), this); else if(type=="Temp") inner = new EEnviron(element.toObject(), this);
else if(type=="Web") inner = new EWeb(element.toObject(), this); else if(type=="Web") inner = new EWeb(element.toObject(), this);
else if(type=="Timer") inner = new ETimer(element.toObject(), this); else if(type=="Timer") inner = new ETimer(element.toObject(), this);
if(inner==nullptr) continue; if(inner==0) continue;
inner->setPos(0, 0); inner->setPos(0, 0);
inner->setFlag(QGraphicsItem::ItemStacksBehindParent); inner->setFlag(QGraphicsItem::ItemStacksBehindParent);
if(index != inners.size()) inner->freeFiles(); if(index != inners.size()) inner->freeFiles();
@ -133,22 +132,22 @@ QWidget* EMultiWin::attrWgt() {
menu->addAction(QIcon(":/res/program/DClock.png"), tr("DClock"))->setData(EBase::DClock); menu->addAction(QIcon(":/res/program/DClock.png"), tr("DClock"))->setData(EBase::DClock);
menu->addAction(QIcon(":/res/program/AClock.png"), tr("AClock"))->setData(EBase::AClock); menu->addAction(QIcon(":/res/program/AClock.png"), tr("AClock"))->setData(EBase::AClock);
auto listWgt = new MListWidget(); auto listWgt = new MListWidget();
connect(menu, &QMenu::triggered, this, [this, listWgt](QAction *act) { connect(menu, &QMenu::triggered, this, [=](QAction *act) {
int type = act->data().toInt(); int type = act->data().toInt();
int order = listWgt->count(); int order = listWgt->count();
EBase *ele = nullptr; EBase *ele = 0;
QListWidgetItem *item = nullptr; QListWidgetItem *item = 0;
if(type==EBase::Photo) { if(type==EBase::Photo) {
auto files = QFileDialog::getOpenFileNames(gMainWin, tr("Select File"), gFileHome, EPhoto::filters()); auto files = QFileDialog::getOpenFileNames(gMainWin, tr("Select File"), gFileHome, EPhoto::filters());
for(int i=0; i<files.count(); i++) { for(int i=0; i<files.count(); i++) {
auto ePhoto = EPhoto::create(files[i], mPageItem, this); auto ePhoto = EPhoto::create(files[i], mPageItem, this);
if(ePhoto==nullptr) continue; if(ePhoto==0) continue;
ePhoto->setSize(mWidth, mHeight); ePhoto->setSize(mWidth, mHeight);
ePhoto->setZValue(order++); ePhoto->setZValue(order++);
ePhoto->setFlag(QGraphicsItem::ItemStacksBehindParent); ePhoto->setFlag(QGraphicsItem::ItemStacksBehindParent);
inners.append(ePhoto); inners.append(ePhoto);
auto item = new QListWidgetItem(QIcon(":/res/program/Photo.png"), tr("Photo")+" "+ePhoto->mName); auto item = new QListWidgetItem(QIcon(":/res/program/Photo.png"), tr("Photo")+" "+ePhoto->mName);
item->setData(Qt::UserRole, QVariant::fromValue(static_cast<void*>(ePhoto))); item->setData(Qt::UserRole, QVariant::fromValue((void*) ePhoto));
listWgt->addItem(item); listWgt->addItem(item);
if(i==files.count()-1) { if(i==files.count()-1) {
listWgt->setCurrentItem(item); listWgt->setCurrentItem(item);
@ -159,13 +158,13 @@ QWidget* EMultiWin::attrWgt() {
auto files = QFileDialog::getOpenFileNames(gMainWin, tr("Select File"), gFileHome, EGif::filters()); auto files = QFileDialog::getOpenFileNames(gMainWin, tr("Select File"), gFileHome, EGif::filters());
for(int i=0; i<files.count(); i++) { for(int i=0; i<files.count(); i++) {
auto eGif = EGif::create(files[i], mPageItem, this); auto eGif = EGif::create(files[i], mPageItem, this);
if(eGif==nullptr) continue; if(eGif==0) continue;
eGif->setSize(mWidth, mHeight); eGif->setSize(mWidth, mHeight);
eGif->setZValue(order++); eGif->setZValue(order++);
eGif->setFlag(QGraphicsItem::ItemStacksBehindParent); eGif->setFlag(QGraphicsItem::ItemStacksBehindParent);
inners.append(eGif); inners.append(eGif);
auto item = new QListWidgetItem(QIcon(":/res/program/Gif.png"), tr("Gif")+" "+eGif->mName); auto item = new QListWidgetItem(QIcon(":/res/program/Gif.png"), tr("Gif")+" "+eGif->mName);
item->setData(Qt::UserRole, QVariant::fromValue(static_cast<void*>(eGif))); item->setData(Qt::UserRole, QVariant::fromValue((void*) eGif));
listWgt->addItem(item); listWgt->addItem(item);
if(i == files.count()-1) { if(i == files.count()-1) {
listWgt->setCurrentItem(item); listWgt->setCurrentItem(item);
@ -176,7 +175,7 @@ QWidget* EMultiWin::attrWgt() {
auto file = QFileDialog::getOpenFileName(gMainWin, tr("Select File"), gFileHome, EVideo::filters()); auto file = QFileDialog::getOpenFileName(gMainWin, tr("Select File"), gFileHome, EVideo::filters());
if(! file.isEmpty()) { if(! file.isEmpty()) {
auto eVideo = EVideo::create(file, mPageItem, this); auto eVideo = EVideo::create(file, mPageItem, this);
if(eVideo==nullptr) return; if(eVideo==0) return;
item = new QListWidgetItem(QIcon(":/res/program/Movie.png"), tr("Video")+" "+eVideo->mRawName); item = new QListWidgetItem(QIcon(":/res/program/Movie.png"), tr("Video")+" "+eVideo->mRawName);
gFileHome = eVideo->mRawDir; gFileHome = eVideo->mRawDir;
ele = eVideo; ele = eVideo;
@ -197,12 +196,12 @@ QWidget* EMultiWin::attrWgt() {
ele = new ETimer(this); ele = new ETimer(this);
item = new QListWidgetItem(QIcon(":/res/program/Timer.png"), tr("Timer")); item = new QListWidgetItem(QIcon(":/res/program/Timer.png"), tr("Timer"));
} }
if(ele != nullptr) { if(ele) {
ele->setSize(mWidth, mHeight); ele->setSize(mWidth, mHeight);
ele->setZValue(order); ele->setZValue(order);
ele->setFlag(QGraphicsItem::ItemStacksBehindParent); ele->setFlag(QGraphicsItem::ItemStacksBehindParent);
inners.append(ele); inners.append(ele);
item->setData(Qt::UserRole, QVariant::fromValue(static_cast<void*>(ele))); item->setData(Qt::UserRole, QVariant::fromValue((void*)ele));
listWgt->addItem(item); listWgt->addItem(item);
listWgt->setCurrentItem(item); listWgt->setCurrentItem(item);
} }
@ -270,7 +269,7 @@ QWidget* EMultiWin::attrWgt() {
listWgt->setMinimumHeight(120); listWgt->setMinimumHeight(120);
listWgt->setIconSize(QSize(20, 20)); listWgt->setIconSize(QSize(20, 20));
foreach(auto inner, inners) { foreach(auto inner, inners) {
QListWidgetItem *item = nullptr; QListWidgetItem *item = 0;
int type = inner->type(); int type = inner->type();
if(type==EBase::Text) item = new QListWidgetItem(QIcon(":/res/program/Text.png"), tr("Text")); if(type==EBase::Text) item = new QListWidgetItem(QIcon(":/res/program/Text.png"), tr("Text"));
else if(type==EBase::Photo) item = new QListWidgetItem(QIcon(":/res/program/Photo.png"), tr("Photo")+" "+static_cast<EPhoto*>(inner)->mName); else if(type==EBase::Photo) item = new QListWidgetItem(QIcon(":/res/program/Photo.png"), tr("Photo")+" "+static_cast<EPhoto*>(inner)->mName);
@ -281,33 +280,33 @@ QWidget* EMultiWin::attrWgt() {
else if(type==EBase::Environ) item = new QListWidgetItem(QIcon(":/res/program/Temp.png"), tr("Environment")); else if(type==EBase::Environ) item = new QListWidgetItem(QIcon(":/res/program/Temp.png"), tr("Environment"));
else if(type==EBase::Timer) item = new QListWidgetItem(QIcon(":/res/program/Timer.png"), tr("Timer")); else if(type==EBase::Timer) item = new QListWidgetItem(QIcon(":/res/program/Timer.png"), tr("Timer"));
if(item != nullptr) { if(item != nullptr) {
item->setData(Qt::UserRole, QVariant::fromValue(static_cast<void*>(inner))); item->setData(Qt::UserRole, QVariant::fromValue((void*) inner));
listWgt->addItem(item); listWgt->addItem(item);
} }
} }
connect(listWgt, &QListWidget::currentItemChanged, this, [this, vBox, listWgt, groupBox](QListWidgetItem *current, QListWidgetItem *previous) { connect(listWgt, &QListWidget::currentItemChanged, this, [=](QListWidgetItem *current, QListWidgetItem *previous) {
if(previous != nullptr) { if(previous) {
auto eLast = static_cast<EBase*>(previous->data(Qt::UserRole).value<void*>()); auto eLast = static_cast<EBase*>(previous->data(Qt::UserRole).value<void*>());
if(eLast != nullptr) { if(eLast) {
if(scene() != nullptr) scene()->removeItem(eLast); if(scene()) scene()->removeItem(eLast);
disconnect(this, &EMultiWin::sizeChanged, eLast, 0); disconnect(this, &EMultiWin::sizeChanged, eLast, 0);
eLast->freeFiles(); eLast->freeFiles();
} }
auto itemLast = vBox->itemAt(vBox->count()-1); auto itemLast = vBox->itemAt(vBox->count()-1);
if(itemLast != nullptr && itemLast->widget() != groupBox) { if(itemLast && itemLast->widget() != groupBox) {
vBox->takeAt(vBox->count()-1); vBox->takeAt(vBox->count()-1);
if(itemLast->widget() != nullptr) delete itemLast->widget(); if(itemLast->widget()) delete itemLast->widget();
delete itemLast; delete itemLast;
} }
} }
EBase *eCur = nullptr; EBase *eCur = 0;
if(current != nullptr) { if(current) {
eCur = static_cast<EBase*>(current->data(Qt::UserRole).value<void*>()); eCur = (EBase*) current->data(Qt::UserRole).value<void*>();
auto attr = eCur->attrWgt(); auto attr = eCur->attrWgt();
if(attr != nullptr) vBox->addWidget(attr); if(attr) vBox->addWidget(attr);
} }
index = listWgt->currentRow(); index = listWgt->currentRow();
if(eCur != nullptr) setCur(eCur); if(eCur) setCur(eCur);
}); });
vBoxGroup->addWidget(listWgt); vBoxGroup->addWidget(listWgt);

View File

@ -230,6 +230,9 @@ bool EVideo::save(const QString &pageDir) {
QFile(oldFile).copy(saveFile); QFile(oldFile).copy(saveFile);
mDir = pageDir; mDir = pageDir;
if(gProgItem->mMaxWidth) { if(gProgItem->mMaxWidth) {
QWidget *paren;
QObject obj;
scene()->parent();
auto waitingDlg = new WaitingDlg(gProgEditorWin, "正在转码视频 ..."); auto waitingDlg = new WaitingDlg(gProgEditorWin, "正在转码视频 ...");
auto thread = new VideoSplitThread(mWidth, mHeight, gProgItem->mMaxWidth, gProgItem->mHeight, gProgItem->mSplitWidths, pos(), saveFile.toUtf8()); auto thread = new VideoSplitThread(mWidth, mHeight, gProgItem->mMaxWidth, gProgItem->mHeight, gProgItem->mSplitWidths, pos(), saveFile.toUtf8());
connect(thread, &VideoSplitThread::emErr, this, [saveFile, waitingDlg](QString err) { connect(thread, &VideoSplitThread::emErr, this, [saveFile, waitingDlg](QString err) {

View File

@ -97,10 +97,9 @@ PageEditor::PageEditor(QWidget *parent) : QWidget(parent) {
connect(actArrayRight, SIGNAL(triggered(bool)), this, SLOT(onArrayRight())); connect(actArrayRight, SIGNAL(triggered(bool)), this, SLOT(onArrayRight()));
vBox->addWidget(toolBar); vBox->addWidget(toolBar);
graphicsView = new QGraphicsView(this); graphicsView = new QGraphicsView;
pal = graphicsView->palette(); pal = graphicsView->palette();
pal.setBrush(QPalette::Base, QColor(0xbbbbbb)); pal.setBrush(QPalette::Base, QColor(0xbbbbbb));
graphicsView->setAutoFillBackground(true);
graphicsView->setPalette(pal); graphicsView->setPalette(pal);
vBox->addWidget(graphicsView); vBox->addWidget(graphicsView);
} }

View File

@ -10,7 +10,6 @@ class PageEditor : public QWidget {
Q_OBJECT Q_OBJECT
public: public:
explicit PageEditor(QWidget *parent = nullptr); explicit PageEditor(QWidget *parent = nullptr);
virtual void keyReleaseEvent(QKeyEvent *event) override; virtual void keyReleaseEvent(QKeyEvent *event) override;
QList<EBase*> sortedEles(); QList<EBase*> sortedEles();

View File

@ -1,32 +1,33 @@
#include "pagelistitem.h" #include "pagelistitem.h"
#include "cfg.h"
#include "tools.h"
#include "base/ffutil.h" #include "base/ffutil.h"
#include "program/wplanlist.h"
#include "base/lodateselector.h" #include "base/lodateselector.h"
#include "program/ebase.h" #include "cfg.h"
#include "program/etext.h"
#include "program/ephoto.h"
#include "program/evideo.h"
#include "program/eaudio.h"
#include "program/egif.h"
#include "program/edclock.h"
#include "program/eaclock.h" #include "program/eaclock.h"
#include "program/eaudio.h"
#include "program/ebase.h"
#include "program/edclock.h"
#include "program/eenviron.h" #include "program/eenviron.h"
#include "program/eweb.h" #include "program/egif.h"
#include "program/etimer.h"
#include "program/emultiwin.h" #include "program/emultiwin.h"
#include <QMessageBox> #include "program/ephoto.h"
#include <QJsonArray> #include "program/etext.h"
#include <QDir> #include "program/etimer.h"
#include "program/evideo.h"
#include "program/eweb.h"
#include "program/wplanlist.h"
#include "tools.h"
#include <QBoxLayout> #include <QBoxLayout>
#include <QSpinBox>
#include <QLineEdit>
#include <QDateEdit> #include <QDateEdit>
#include <QDir>
#include <QGraphicsView>
#include <QJsonArray>
#include <QLineEdit>
#include <QMessageBox>
#include <QSpinBox>
class PageScene : public QGraphicsScene { class PageScene : public QGraphicsScene {
public: public:
PageScene(qreal x, qreal y, qreal width, qreal height, QObject *parent = nullptr) : QGraphicsScene(x, y, width, height, parent) {}; using QGraphicsScene::QGraphicsScene;
void drawBackground(QPainter *painter, const QRectF &rect) { void drawBackground(QPainter *painter, const QRectF &rect) {
QGraphicsScene::drawBackground(painter, rect); QGraphicsScene::drawBackground(painter, rect);
painter->fillRect(sceneRect(), Qt::black); painter->fillRect(sceneRect(), Qt::black);

View File

@ -1,8 +1,9 @@
#ifndef PAGELISTITEM_H #ifndef PAGELISTITEM_H
#define PAGELISTITEM_H #define PAGELISTITEM_H
#include "pageeditor.h" #include <QGraphicsScene>
#include <QJsonObject> #include <QJsonObject>
#include <QLabel>
#include <QListWidget> #include <QListWidget>
class PageListItem : public QObject, public QListWidgetItem { class PageListItem : public QObject, public QListWidgetItem {
@ -10,7 +11,7 @@ class PageListItem : public QObject, public QListWidgetItem {
public: public:
explicit PageListItem(const QJsonObject &attr, const QString &pageDir); explicit PageListItem(const QJsonObject &attr, const QString &pageDir);
~PageListItem() { ~PageListItem() {
if(mAttrWgt!=0) delete mAttrWgt; if(mAttrWgt) delete mAttrWgt;
} }
void updateJson(); void updateJson();

View File

@ -41,20 +41,18 @@ QWidget *gProgEditorWin;
ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(parent), mProgItem(progItem) { ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(parent), mProgItem(progItem) {
gProgEditorWin = this; gProgEditorWin = this;
gProgItem = progItem; gProgItem = progItem;
setAttribute(Qt::WA_DeleteOnClose);
#ifdef Q_OS_WINDOWS
setWindowFlag(Qt::Window); setWindowFlag(Qt::Window);
setWindowModality(Qt::WindowModal); setAttribute(Qt::WA_DeleteOnClose);
#else
setWindowFlag(Qt::Dialog);
#endif
setAttribute(Qt::WA_AlwaysShowToolTips);
if(! parent->isMaximized()) resize(parent->size()); if(! parent->isMaximized()) resize(parent->size());
else resize(1280, 720); else resize(1280, 720);
#ifdef Q_OS_WIN
setWindowModality(Qt::WindowModal);
#else
parentWidget()->hide();
#endif
setAttribute(Qt::WA_AlwaysShowToolTips);
setWindowTitle(progItem->mName); setWindowTitle(progItem->mName);
parent->setVisible(false);
auto vBox = new QVBoxLayout(this); auto vBox = new QVBoxLayout(this);
vBox->setContentsMargins(0, 0, 0, 0); vBox->setContentsMargins(0, 0, 0, 0);
vBox->setSpacing(0); vBox->setSpacing(0);
@ -74,15 +72,15 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
}); });
connect(saveThread, SIGNAL(finished()), saveThread, SLOT(deleteLater())); connect(saveThread, SIGNAL(finished()), saveThread, SLOT(deleteLater()));
connect(saveThread, &QThread::finished, this, [this] { connect(saveThread, &QThread::finished, this, [this] {
this->mProgItem->m_last = QDateTime::currentDateTime(); mProgItem->m_last = QDateTime::currentDateTime();
this->mProgItem->m_fsize = dirFileSize(this->mProgItem->mProgDir); mProgItem->m_fsize = dirFileSize(mProgItem->mProgDir);
this->mProgItem->onSetProgram(); mProgItem->onSetProgram();
}); });
saveThread->start(); saveThread->start();
bool isOK; bool isOK;
QString progName = QInputDialog::getText(this, tr("Save as"), tr("Save as"), QLineEdit::Normal, QString(), &isOK, Qt::Dialog | Qt::WindowCloseButtonHint); QString progName = QInputDialog::getText(this, tr("Save as"), tr("Save as"), QLineEdit::Normal, QString(), &isOK, Qt::Dialog | Qt::WindowCloseButtonHint);
if(! isOK || progName.isEmpty()) return; if(! isOK || progName.isEmpty()) return;
mProgItem->mProgDir = this->mProgItem->mProgsDir + "/" + progName; mProgItem->mProgDir = mProgItem->mProgsDir + "/" + progName;
LoEmptyDialog *dlgTip = new LoEmptyDialog(this); LoEmptyDialog *dlgTip = new LoEmptyDialog(this);
saveThread = QThread::create([this](){ saveThread = QThread::create([this](){
save(); save();
@ -239,10 +237,10 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
connect(toolBar, &QToolBar::actionTriggered, this, [this](QAction *act) { connect(toolBar, &QToolBar::actionTriggered, this, [this](QAction *act) {
auto data = act->data(); auto data = act->data();
if(data.type()!=QVariant::Int) return; if(data.type()!=QVariant::Int) return;
auto scene = progEditorMid->graphicsView->scene(); auto scene = mPageEditor->graphicsView->scene();
if(nullptr == scene) return; if(scene==0) return;
int order = progEditorMid->sortedEles().count(); int order = mPageEditor->sortedEles().count();
EBase *element = nullptr; EBase *element = 0;
int iNewWidth = mProgItem->mWidth; int iNewWidth = mProgItem->mWidth;
int iNewHeight = mProgItem->mHeight; int iNewHeight = mProgItem->mHeight;
if(iNewWidth>128) iNewWidth = iNewWidth * 2 / 3; if(iNewWidth>128) iNewWidth = iNewWidth * 2 / 3;
@ -261,11 +259,8 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
ePhoto->setZValue(order++); ePhoto->setZValue(order++);
scene->addItem(ePhoto); scene->addItem(ePhoto);
if(i==files.count()-1) { if(i==files.count()-1) {
auto scene = progEditorMid->graphicsView->scene(); auto sels = scene->selectedItems();
if(nullptr != scene) { if(sels.count() == 1) sels.at(0)->setSelected(false);
auto list = scene->selectedItems();
if(list.count() == 1) static_cast<EBase*>(list.at(0))->setSelected(false);
}
ePhoto->setSelected(true); ePhoto->setSelected(true);
gFileHome = ePhoto->mDir; gFileHome = ePhoto->mDir;
} }
@ -274,19 +269,16 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
auto files = QFileDialog::getOpenFileNames(this, tr("Select File"), gFileHome, EGif::filters()); auto files = QFileDialog::getOpenFileNames(this, tr("Select File"), gFileHome, EGif::filters());
for(int i=0; i<files.count(); i++) { for(int i=0; i<files.count(); i++) {
auto eGif = EGif::create(files[i], mPageItem); auto eGif = EGif::create(files[i], mPageItem);
if(eGif==nullptr) continue; if(eGif==0) continue;
auto img = eGif->mMovie->currentPixmap(); auto img = eGif->mMovie->currentPixmap();
auto rect = Tools::centerRect(img.width(), img.height(), mProgItem->mWidth, mProgItem->mHeight); auto rect = Tools::centerRect(img.width(), img.height(), mProgItem->mWidth, mProgItem->mHeight);
eGif->setPos(rect.topLeft()); eGif->setPos(rect.topLeft());
eGif->setSize(rect.width(), rect.height()); eGif->setSize(rect.width(), rect.height());
eGif->setZValue(order++); eGif->setZValue(order++);
scene->addItem(eGif); scene->addItem(eGif);
if(i == files.count()-1){ if(i == files.count()-1) {
auto scene = progEditorMid->graphicsView->scene(); auto sels = scene->selectedItems();
if(nullptr != scene) { if(sels.count() == 1) sels.at(0)->setSelected(false);
auto list = scene->selectedItems();
if(list.count() == 1) static_cast<EBase*>(list.at(0))->setSelected(false);
}
eGif->setSelected(true); eGif->setSelected(true);
gFileHome = eGif->mDir; gFileHome = eGif->mDir;
} }
@ -332,7 +324,6 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
element->setSize(mProgItem->mWidth, mProgItem->mHeight); element->setSize(mProgItem->mWidth, mProgItem->mHeight);
} }
else if(type==EBase::Timer) element = new ETimer(); else if(type==EBase::Timer) element = new ETimer();
else if(type==EBase::Audio) ;
else if(type==EBase::Window) element = new EMultiWin(mPageItem); else if(type==EBase::Window) element = new EMultiWin(mPageItem);
if(element) { if(element) {
if(element->mWidth==0) { if(element->mWidth==0) {
@ -341,13 +332,10 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
} }
element->setZValue(order); element->setZValue(order);
scene->addItem(element); scene->addItem(element);
mNewEleX+=8; mNewEleX += 8;
mNewEleY+=8; mNewEleY += 8;
QGraphicsScene *scene = progEditorMid->graphicsView->scene(); auto sels = scene->selectedItems();
if(nullptr != scene){ if(sels.count() == 1) sels.at(0)->setSelected(false);
QList<QGraphicsItem *> list = scene->selectedItems();
if(list.count() == 1) static_cast<EBase*>(list.at(0))->setSelected(false);
}
element->setSelected(true); element->setSelected(true);
} }
}); });
@ -375,11 +363,11 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
toolBar->setIconSize(QSize(22,16)); toolBar->setIconSize(QSize(22,16));
toolBar->setStyleSheet("QToolBar{spacing: 8px;}"); toolBar->setStyleSheet("QToolBar{spacing: 8px;}");
QAction *actAdd = new QAction(QIcon(":/res/program/Add.png"), tr("Add page")); auto actAdd = new QAction(QIcon(":/res/program/Add.png"), tr("Add page"));
connect(actAdd, &QAction::triggered, this, &ProgEditorWin::onAddPage); connect(actAdd, &QAction::triggered, this, &ProgEditorWin::onAddPage);
toolBar->addAction(actAdd); toolBar->addAction(actAdd);
QAction *actCopy = new QAction(QIcon(":/res/program/Copy.png"), tr("Copy page")); auto actCopy = new QAction(QIcon(":/res/program/Copy.png"), tr("Copy page"));
connect(actCopy, &QAction::triggered, this, [this] { connect(actCopy, &QAction::triggered, this, [this] {
if(listPage->count() > 0) { if(listPage->count() > 0) {
auto cur = static_cast<PageListItem*>(listPage->currentItem()); auto cur = static_cast<PageListItem*>(listPage->currentItem());
@ -394,9 +382,9 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
}); });
toolBar->addAction(actCopy); toolBar->addAction(actCopy);
QAction *actDel = new QAction(QIcon(":/res/program/Delete.png"), tr("Delete page")); auto actDel = new QAction(QIcon(":/res/program/Delete.png"), tr("Delete page"));
connect(actDel, &QAction::triggered, this, [this] { connect(actDel, &QAction::triggered, this, [this] {
if(listPage->count() == 1) progEditorMid->onClean(); if(listPage->count() == 1) mPageEditor->onClean();
else if(listPage->count() > 1) { else if(listPage->count() > 1) {
auto item = static_cast<PageListItem*>(listPage->currentItem()); auto item = static_cast<PageListItem*>(listPage->currentItem());
auto res = QMessageBox::information(this, tr("Tip Info"), tr("Are you sure you want to delete this program page?"), QMessageBox::Ok, QMessageBox::Cancel); auto res = QMessageBox::information(this, tr("Tip Info"), tr("Are you sure you want to delete this program page?"), QMessageBox::Ok, QMessageBox::Cancel);
@ -410,7 +398,7 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
}); });
toolBar->addAction(actDel); toolBar->addAction(actDel);
QAction *actMoveUp = new QAction(QIcon(":/res/program/GoUp.png"), tr("Move up")); auto actMoveUp = new QAction(QIcon(":/res/program/GoUp.png"), tr("Move up"));
connect(actMoveUp, &QAction::triggered, this, [this] { connect(actMoveUp, &QAction::triggered, this, [this] {
if(listPage->count() > 1) { if(listPage->count() > 1) {
int index = listPage->currentRow(); int index = listPage->currentRow();
@ -426,7 +414,7 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
}); });
toolBar->addAction(actMoveUp); toolBar->addAction(actMoveUp);
QAction *actMoveDown = new QAction(QIcon(":/res/program/GoDown.png"), tr("Move down")); auto actMoveDown = new QAction(QIcon(":/res/program/GoDown.png"), tr("Move down"));
connect(actMoveDown, &QAction::triggered, this, [this] { connect(actMoveDown, &QAction::triggered, this, [this] {
if(listPage->count() > 1) { if(listPage->count() > 1) {
int index = listPage->currentRow(); int index = listPage->currentRow();
@ -446,30 +434,28 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
listPage = new QListWidget(); listPage = new QListWidget();
listPage->setMaximumWidth(190); listPage->setMaximumWidth(190);
connect(listPage, &QListWidget::currentItemChanged, this, [this](QListWidgetItem *current, QListWidgetItem *previous) { connect(listPage, &QListWidget::currentItemChanged, this, [=](QListWidgetItem *current, QListWidgetItem *previous) {
auto curItem = static_cast<PageListItem*>(current); auto curItem = static_cast<PageListItem*>(current);
auto preItem = static_cast<PageListItem*>(previous); auto preItem = static_cast<PageListItem*>(previous);
if(nullptr != preItem) preItem->mScene->clearSelection(); if(preItem) preItem->mScene->clearSelection();
mPageItem = curItem; mPageItem = curItem;
auto scene = progEditorMid->graphicsView->scene(); auto scene = mPageEditor->graphicsView->scene();
if(scene != nullptr) disconnect(scene, &QGraphicsScene::selectionChanged, this, 0); if(scene) disconnect(scene, 0, 0, 0);
if(progEditorMid->curScale != 100) { if(mPageEditor->curScale != 100) {
progEditorMid->curScale = 100; mPageEditor->curScale = 100;
progEditorMid->fdScale->setText("100"); mPageEditor->fdScale->setText("100");
progEditorMid->graphicsView->resetTransform(); mPageEditor->graphicsView->resetTransform();
} }
if(curItem == nullptr) progEditorMid->graphicsView->setScene(nullptr); if(curItem == 0) mPageEditor->graphicsView->setScene(0);
else { else {
progEditorMid->graphicsView->setScene(scene = curItem->mScene); mPageEditor->graphicsView->setScene(scene = curItem->mScene);
connect(scene, &QGraphicsScene::selectionChanged, this, [this] { connect(scene, &QGraphicsScene::selectionChanged, this, [=] {
auto scene = progEditorMid->graphicsView->scene();
if(scene==nullptr) return;
auto sels = scene->selectedItems(); auto sels = scene->selectedItems();
auto scroll = static_cast<QScrollArea*>(mTabsAttr->widget(0)); auto scroll = static_cast<QScrollArea*>(mTabsAttr->widget(0));
if(sels.size() != 1) { if(sels.size() != 1) {
mTabsAttr->setCurrentIndex(1); mTabsAttr->setCurrentIndex(1);
auto wgt = scroll->takeWidget(); auto wgt = scroll->takeWidget();
if(wgt!=nullptr) delete wgt; if(wgt) delete wgt;
} else { } else {
mTabsAttr->setCurrentIndex(0); mTabsAttr->setCurrentIndex(0);
scroll->setWidget(static_cast<EBase*>(sels[0])->attrWgt()); scroll->setWidget(static_cast<EBase*>(sels[0])->attrWgt());
@ -479,7 +465,7 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
} }
auto scroll = static_cast<QScrollArea*>(mTabsAttr->widget(1)); auto scroll = static_cast<QScrollArea*>(mTabsAttr->widget(1));
scroll->takeWidget(); scroll->takeWidget();
if(curItem != nullptr) { if(curItem) {
scroll->setWidget(curItem->attrWgt()); scroll->setWidget(curItem->attrWgt());
scroll->updateGeometry(); scroll->updateGeometry();
} }
@ -488,7 +474,7 @@ ProgEditorWin::ProgEditorWin(ProgItem *progItem, QWidget *parent) : QWidget(pare
vBoxPage->addWidget(listPage); vBoxPage->addWidget(listPage);
hBox->addLayout(vBoxPage); hBox->addLayout(vBoxPage);
hBox->addWidget(progEditorMid = new PageEditor(this), 1); hBox->addWidget(mPageEditor = new PageEditor, 1);
mTabsAttr = new QTabWidget(); mTabsAttr = new QTabWidget();
mTabsAttr->setMinimumWidth(360); mTabsAttr->setMinimumWidth(360);
@ -567,7 +553,9 @@ void ProgEditorWin::closeEvent(QCloseEvent *event) {
if(res == QMessageBox::Yes) onSave(); if(res == QMessageBox::Yes) onSave();
else if(res == QMessageBox::Cancel) event->ignore(); else if(res == QMessageBox::Cancel) event->ignore();
} }
parentWidget()->setVisible(true); #ifdef Q_OS_MAC
if(event->isAccepted()) parentWidget()->show();
#endif
} }
//停止每个页面元素的播放,将节目目录下的每个页面的文件夹另命名 //停止每个页面元素的播放,将节目目录下的每个页面的文件夹另命名
void ProgEditorWin::save() { void ProgEditorWin::save() {

View File

@ -10,7 +10,6 @@ class ProgEditorWin : public QWidget {
Q_OBJECT Q_OBJECT
public: public:
explicit ProgEditorWin(ProgItem *progItem, QWidget *); explicit ProgEditorWin(ProgItem *progItem, QWidget *);
public slots: public slots:
void onSave(); void onSave();
void onAddPage(); void onAddPage();
@ -23,7 +22,7 @@ private:
QListWidget *listPage; QListWidget *listPage;
PageListItem *mPageItem = nullptr; PageListItem *mPageItem = nullptr;
PageEditor *progEditorMid; PageEditor *mPageEditor;
QTabWidget *mTabsAttr; QTabWidget *mTabsAttr;
QList<QJsonObject> mPageJsons; QList<QJsonObject> mPageJsons;
ProgItem *mProgItem; ProgItem *mProgItem;