transmitterswitch.cpp 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864
  1. #include "transmitterswitch.h"
  2. #include "ui_transmitterswitch.h"
  3. #include <QFile>
  4. #include <QList>
  5. #include <memory>
  6. #include <QLayout>
  7. #include <QScrollBar>
  8. #include "LHQLogAPI.h"
  9. #include "pBtnUserData2.h"
  10. #include "WebAPI/FromWebAPI.h"
  11. #include "TransmitterSwitchInfo.h"
  12. #include "timewidget.h"
  13. #include "cdate.h"
  14. #include "savetotemplate.h"
  15. #include "importtemplate.h"
  16. #include "warning.h"
  17. #include "tipwidget.h"
  18. #include "UIStyleManager.h"
  19. #include "PlanData.h"
  20. #include "PlanCard.h"
  21. #include "flowlayout.h"
  22. #include "managerplan.h"
  23. #include "importtemplate.h"
  24. TransmitterSwitch::TransmitterSwitch(QWidget *parent) :
  25. QWidget(parent),
  26. ui(new Ui::TransmitterSwitch)
  27. {
  28. ui->setupUi(this);
  29. /* 创建一个布局 */
  30. QVBoxLayout* layout = new QVBoxLayout(parent);
  31. layout->setMargin(0);
  32. layout->setSpacing(0);
  33. parent->setLayout(layout);
  34. layout->addWidget(this);
  35. /* 创建一个流式布局,存放卡片 */
  36. m_flowlayout = new FlowLayout(ui->scrollAreaContents_Card, 0, m_cardHorSpacing, m_cardVerSpacing);
  37. // m_flowlayout->setContentsMargins(0, 0, 0, 0);
  38. // m_flowlayout->setSpacing(200);
  39. ui->scrollAreaContents_Card->setLayout(m_flowlayout);
  40. /* 创建WebAPI实例 */
  41. m_fromWebAPI = new FromWebAPI;
  42. /* 设置“默认计划”按钮可点击 */
  43. ui->pBtn_defaultPlan->setCheckable(true);
  44. ui->pBtn_allFrequency->setCheckable(true);
  45. connect(ui->pBtn_allFrequency, &QPushButton::clicked, this, &TransmitterSwitch::do_selectFrequencyBtn);
  46. /* 设置提示文本 */
  47. m_tipText = new QLabel(this);
  48. m_tipText->resize(936,56);
  49. m_tipText->setObjectName("label_TipText");
  50. m_tipText->setText(R"(按时刻执行模式:即以时刻点为单位进行执行,若某日既为普通日和特殊日,在某一时刻皆有执行动作,将优先执行特殊日在此时刻所计划的动作。
  51. 按天执行模式:即以天为单位进行执行,若某日既为普通日和特殊日,则当日一整天优先执行特殊日所计划的动作,普通日计划当日不再执行。)");
  52. m_tipText->hide();
  53. QPoint pos = ui->label_Tip->mapTo(this, ui->label_Tip->pos());
  54. m_tipText->move(pos.x() + 2, pos.y() + 2 ); /* 去掉阴影的宽度和高度 */
  55. ui->label_Tip->installEventFilter(this);
  56. /* 设置默认值 */
  57. ui->pBtn_defaultPlan->setChecked(true);
  58. ui->rBtn_moment->setChecked(true);
  59. /* 连接信号和槽 */
  60. connect(ui->pBtn_addPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnAddExecPlan);
  61. connect(ui->pBtn_importPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_importData);
  62. connect(ui->pBtn_exportPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_exportData);
  63. connect(ui->pBtn_editPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnModifyExecPlan);
  64. connect(ui->pBtn_refresh, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnRefresh);
  65. connect(ui->pBtn_defaultPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnIsOpenPlan);
  66. connect(ui->rBtn_moment, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnExecMode);
  67. connect(ui->rBtn_day, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnExecMode);
  68. connect(ui->pBtn_clearPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnClearPlan);
  69. connect(ui->pBtn_deletePlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnClearPlan);
  70. /* 设置QSS */
  71. connect(&EPUIStyle, &UIStyleManager::signal_qssChanged, this, &TransmitterSwitch::do_setUIStyle);
  72. /* 设置默认的皮肤 */
  73. EPUIStyle.setUIStyle(enum_UIStyle::UI_Dark);
  74. /* 设置默认点击的按钮 */
  75. ui->pBtn_allFrequency->setChecked(true);
  76. }
  77. TransmitterSwitch::~TransmitterSwitch()
  78. {
  79. if(m_tipText != nullptr)
  80. {
  81. delete m_tipText;
  82. m_tipText = nullptr;
  83. }
  84. delete ui;
  85. }
  86. /* 设置样式表路径,给弹窗页面使用,不需要包含最后的white,black */
  87. void TransmitterSwitch::setQSSPath(const QString &qssPath)
  88. {
  89. if(qssPath.isEmpty())
  90. {
  91. return;
  92. }
  93. /* 去掉最后的“/” */
  94. // if(qssPath.endsWith("/"))
  95. // {
  96. // EPUIStyle.setQSSPath(qssPath.left(qssPath.length() - 1));
  97. // } else
  98. // {
  99. // EPUIStyle.setQSSPath(qssPath);
  100. // }
  101. }
  102. /**
  103. * @brief 设置WebAPI信息
  104. *
  105. * @param url WebAPI地址
  106. * @param serID 数据库ID
  107. * @param serKey 限制的关键字
  108. */
  109. void TransmitterSwitch::setWebAPIInfo(const QString &url, const QString &serverID, const QString &serverKey)
  110. {
  111. if(m_fromWebAPI == nullptr)
  112. {
  113. m_fromWebAPI = new FromWebAPI;
  114. }
  115. if(url.isEmpty() || serverID.isEmpty() || serverKey.isEmpty())
  116. {
  117. LH_WRITE_ERROR("WebAPI info is empty");
  118. return;
  119. }
  120. m_fromWebAPI->initWebApi(url, serverID, serverKey);
  121. /* 获取支持的设备 */
  122. m_fromWebAPI->getDeviceInfo(DeviceContainer.getMapDevice());
  123. m_fromWebAPI->getChannelInfo(ChnContainer.getMapChannel());
  124. /* 创建获取到的卡片信息 */
  125. createAllCard();
  126. }
  127. /* 初始化webAPI,重载版 */
  128. void TransmitterSwitch::setWebAPIInfo(const InitData& data)
  129. {
  130. setWebAPIInfo(data.url, data.serverID, data.serverKey);
  131. }
  132. /**
  133. * @brief 获取EQM数据库计划,包括所有的配置信息
  134. *
  135. */
  136. void TransmitterSwitch::getExecPlanFromEQM()
  137. {
  138. /* 获取页面的配置信息 */
  139. if(m_fromWebAPI->getConfigData(CfgData.getMapConfigData()))
  140. {
  141. // TipWidget::display(TipWidget::OPERATOR_OK, "获取配置成功", this);
  142. }else {
  143. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取配置失败", this);
  144. return;
  145. }
  146. /* 设置计划配置 */
  147. auto& mapConfig = CfgData.getMapConfigData();
  148. for(auto begin = mapConfig.begin(), end = mapConfig.end(); begin != end; begin++)
  149. {
  150. if(begin->key == static_cast<int>(enum_ExecPlanConfig::OpenPlan))
  151. {
  152. ui->pBtn_defaultPlan->setChecked(begin->value == 1 ? true : false);
  153. }
  154. else if(begin->key == static_cast<int>(enum_ExecPlanConfig::ExecMode))
  155. {
  156. if(begin->value == 0)
  157. {
  158. ui->rBtn_moment->setChecked(true);
  159. }else {
  160. ui->rBtn_day->setChecked(true);
  161. }
  162. }
  163. }
  164. /* 获取所有频率的计划 */
  165. bool isSuccess = true;
  166. for(const auto& chn : ChnContainer.getMapChannel())
  167. {
  168. /* 获取计划 */
  169. QList<OnePlanItemInfo> list;
  170. if(m_fromWebAPI->getExecPlanData(chn.ChannelID, list))
  171. {
  172. auto pCard = PData.findPlanCard(chn.ChannelID);
  173. if(pCard != nullptr)
  174. {
  175. pCard->setPlanList(list);
  176. }
  177. }else {
  178. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("获取频率<%1>计划失败").arg(chn.ChannelName), this);
  179. isSuccess = false;
  180. LH_WRITE_ERROR(QString("获取频率“%1”计划失败").arg(chn.ChannelName));
  181. }
  182. /* 先显示已获取到的数据,避免等待时间太久,卡顿 */
  183. QEventLoop loop;
  184. loop.processEvents();
  185. }
  186. if(isSuccess)
  187. {
  188. TipWidget::display(TipWidget::OPERATOR_OK, "获取计划成功", this);
  189. }
  190. /* 调用回调函数 */
  191. if(m_trackCB != nullptr)
  192. {
  193. m_trackCB(2, g_mapTrack.value(2));
  194. }
  195. }
  196. /* 将计划保存到EQM数据库 */
  197. void TransmitterSwitch::saveExecPlanToEQM()
  198. {
  199. QList<OnePlanItemInfo> list;
  200. /* 获取当前计划的执行模式 */
  201. int execType = 0;
  202. if(ui->rBtn_moment->isChecked())
  203. {
  204. execType = 0;
  205. } else
  206. {
  207. execType = 1;
  208. }
  209. // for(const auto& it : IData.getMapItem())
  210. // {
  211. // for(const auto& it1 : *it)
  212. // {
  213. // OnePlanItemInfo info;
  214. // info.ExecType = execType;
  215. // info.devName = it1->getDevName();
  216. // info.actionID = it1->getActionNum();
  217. // info.actionName = it1->getActionName();
  218. // info.execTime = it1->getExecTime();
  219. // info.date = it1->getDate();
  220. // info.WeekDay = it1->getWeekDay() + 1;
  221. // list.push_back(info);
  222. // }
  223. // }
  224. /* 写入数据库 */
  225. // if(m_fromWebAPI->insertData(list))
  226. // {
  227. // TipWidget::display(TipWidget::OPERATOR_OK, "保存计划成功", this);
  228. // }else {
  229. // TipWidget::display(TipWidget::OPERATOR_FAIL, "保存计划失败", this);
  230. // }
  231. /* 保存“默认计划”和“执行模式” */
  232. ConfigData config1;
  233. config1.key = static_cast<int>(enum_ExecPlanConfig::OpenPlan);
  234. config1.value = ui->pBtn_defaultPlan->isChecked() ? 1 : 0;
  235. config1.updateTime = QDateTime::currentDateTime();
  236. CfgData.updateConfigData(config1);
  237. ConfigData config2;
  238. config2.key = static_cast<int>(enum_ExecPlanConfig::ExecMode);
  239. config2.value = ui->rBtn_moment->isChecked() ? 0 : 1;
  240. config2.updateTime = QDateTime::currentDateTime();
  241. CfgData.updateConfigData(config2);
  242. /* 更新“计划是否更新”标志位,在更新前需要先获取数据库的标志位,如果依旧为1,那么本地是否更改都设置为1 */
  243. ConfigData config3;
  244. if(!m_fromWebAPI->getConfigData(static_cast<int>(enum_ExecPlanConfig::IsChanged), config3))
  245. {
  246. config3.key = static_cast<int>(enum_ExecPlanConfig::IsChanged);
  247. }
  248. /* 只要数据库和本地更新标志位有一个为true,说明还未被读走,则设置标志位为true */
  249. // if((config3.value == 1) || IData.isUpdate())
  250. // {
  251. // config3.value = 1;
  252. // }
  253. config3.updateTime = QDateTime::currentDateTime();
  254. CfgData.updateConfigData(config3);
  255. /* 将配置写入数据库 */
  256. m_fromWebAPI->insertConfigData(CfgData.getMapConfigData());
  257. /* 调用回调函数 */
  258. if(m_trackCB != nullptr)
  259. {
  260. m_trackCB(1, g_mapTrack.value(1));
  261. }
  262. }
  263. /* 亮/暗换肤,0是亮色,1是暗色 */
  264. void TransmitterSwitch::setUIStyle(int style)
  265. {
  266. if(style == 0)
  267. {
  268. EPUIStyle.setUIStyle(enum_UIStyle::UI_Light);
  269. }
  270. else if(style == 1)
  271. {
  272. EPUIStyle.setUIStyle(enum_UIStyle::UI_Dark);
  273. }else {
  274. LH_WRITE_ERROR(QString("错误的样式类型: %1").arg(style));
  275. }
  276. }
  277. /* 设置回调函数 */
  278. void TransmitterSwitch::setTrackCallBack(trackCallBack cb)
  279. {
  280. if(cb == nullptr)
  281. {
  282. return;
  283. }
  284. m_trackCB = cb;
  285. }
  286. /* 点击了添加计划按钮 */
  287. void TransmitterSwitch::do_pBtnAddExecPlan()
  288. {
  289. /* 创建新增窗口 */
  290. std::shared_ptr<ManagerPlan> mp = std::make_shared<ManagerPlan>();
  291. /* 获取当前选中的窗口 */
  292. auto pCard = PData.getCurrentPlanCard();
  293. ChannelInfo chnInfo;
  294. if(pCard == nullptr)
  295. {
  296. LH_WRITE_LOG_DEBUG("没有选中频率卡片");
  297. }else {
  298. mp->setFrequencyID(pCard->getChannelInfo());
  299. }
  300. mp->exec();
  301. /* 判断是否点击了OK */
  302. if(!mp->isOK())
  303. {
  304. return;
  305. }
  306. /* 获取计划信息 */
  307. auto& mapPlanInfo = mp->getPlanInfo();
  308. /* 遍历所有的频率 */
  309. bool isSuccess = true;
  310. for(auto begin = mapPlanInfo.begin(), end = mapPlanInfo.end(); begin != end; begin++)
  311. {
  312. /* 获取频率ID */
  313. int chnID = begin.key();
  314. /* 获取计划列表 */
  315. auto& list = begin.value();
  316. /* 查找这个频率的Card */
  317. auto pCard = PData.findPlanCard(chnID);
  318. if(pCard == nullptr)
  319. {
  320. LH_WRITE_ERROR(QString("没有找到频率ID为%1的卡片").arg(chnID));
  321. continue;
  322. }
  323. /* 设置计划列表 */
  324. pCard->setPlanList(list);
  325. /* 写入数据库 */
  326. QList<OnePlanItemInfo> listPlan;
  327. pCard->getAllPlanInfo(listPlan);
  328. if(!m_fromWebAPI->insertData(chnID, listPlan))
  329. {
  330. LH_WRITE_ERROR(QString("频率ID为%1的计划写入数据库失败").arg(chnID));
  331. isSuccess = false;
  332. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划写入数据库失败").arg(pCard->getChannelInfo().ChannelName), this);
  333. }
  334. }
  335. if(isSuccess)
  336. {
  337. TipWidget::display(TipWidget::OPERATOR_OK, "添加计划成功", this);
  338. }
  339. }
  340. /* 点击了修改按钮 */
  341. void TransmitterSwitch::do_pBtnModifyExecPlan()
  342. {
  343. /* 创建新增窗口 */
  344. std::shared_ptr<ManagerPlan> mp = std::make_shared<ManagerPlan>();
  345. mp->setMode(Enum_Mode::Mode_Modify);
  346. auto pCard = PData.getCurrentPlanCard();
  347. if(pCard == nullptr)
  348. {
  349. LH_WRITE_ERROR("没有选中频率卡片");
  350. return;
  351. }
  352. /* 设置频率信息 */
  353. mp->setFrequencyID(pCard->getChannelInfo());
  354. mp->exec();
  355. /* 判断是否点击了OK */
  356. if(!mp->isOK())
  357. {
  358. return;
  359. }
  360. /* 获取计划信息 */
  361. auto& mapPlanInfo = mp->getPlanInfo();
  362. auto list = mapPlanInfo.find(pCard->getChannelInfo().ChannelID);
  363. pCard->setPlanList(*list);
  364. int chnID = pCard->getChannelInfo().ChannelID;
  365. QList<OnePlanItemInfo> listPlan;
  366. pCard->getAllPlanInfo(listPlan);
  367. if(!m_fromWebAPI->insertData(chnID, listPlan))
  368. {
  369. LH_WRITE_ERROR(QString("频率ID为%1的计划写入数据库失败").arg(chnID));
  370. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划写入数据库失败").arg(pCard->getChannelInfo().ChannelName), this);
  371. }
  372. TipWidget::display(TipWidget::OPERATOR_OK, "修改计划成功", this);
  373. /* 调用回调函数 */
  374. if(m_trackCB != nullptr)
  375. {
  376. m_trackCB(1, g_mapTrack.value(1));
  377. }
  378. }
  379. /* 点击了刷新按钮 */
  380. void TransmitterSwitch::do_pBtnRefresh()
  381. {
  382. getExecPlanFromEQM();
  383. }
  384. /* 点击了“是否开启计划”按钮 */
  385. void TransmitterSwitch::do_pBtnIsOpenPlan()
  386. {
  387. /* 保存“默认计划”和“执行模式” */
  388. ConfigData config1;
  389. config1.key = static_cast<int>(enum_ExecPlanConfig::OpenPlan);
  390. config1.value = ui->pBtn_defaultPlan->isChecked() ? 1 : 0;
  391. config1.updateTime = QDateTime::currentDateTime();
  392. CfgData.updateConfigData(config1);
  393. /* 更新“计划是否更新”标志位,在更新前需要先获取数据库的标志位,如果依旧为1,那么本地是否更改都设置为1 */
  394. ConfigData config3;
  395. if(!m_fromWebAPI->getConfigData(static_cast<int>(enum_ExecPlanConfig::IsChanged), config3))
  396. {
  397. config3.key = static_cast<int>(enum_ExecPlanConfig::IsChanged);
  398. }
  399. /* 只要数据库和本地更新标志位有一个为true,说明还未被读走,则设置标志位为true */
  400. config3.value = 1;
  401. config3.updateTime = QDateTime::currentDateTime();
  402. CfgData.updateConfigData(config3);
  403. /* 将配置写入数据库 */
  404. m_fromWebAPI->insertConfigData(CfgData.getMapConfigData());
  405. }
  406. /* 点击了“执行模式”按钮 */
  407. void TransmitterSwitch::do_pBtnExecMode()
  408. {
  409. /* 保存“默认计划”和“执行模式” */
  410. ConfigData config1;
  411. config1.key = static_cast<int>(enum_ExecPlanConfig::ExecMode);
  412. config1.value = ui->rBtn_moment->isChecked() ? 0 : 1;
  413. config1.updateTime = QDateTime::currentDateTime();
  414. CfgData.updateConfigData(config1);
  415. /* 更新“计划是否更新”标志位,在更新前需要先获取数据库的标志位,如果依旧为1,那么本地是否更改都设置为1 */
  416. ConfigData config3;
  417. if(!m_fromWebAPI->getConfigData(static_cast<int>(enum_ExecPlanConfig::IsChanged), config3))
  418. {
  419. config3.key = static_cast<int>(enum_ExecPlanConfig::IsChanged);
  420. }
  421. /* 只要数据库和本地更新标志位有一个为true,说明还未被读走,则设置标志位为true */
  422. config3.value = 1;
  423. config3.updateTime = QDateTime::currentDateTime();
  424. CfgData.updateConfigData(config3);
  425. /* 将配置写入数据库 */
  426. m_fromWebAPI->insertConfigData(CfgData.getMapConfigData());
  427. }
  428. /* 点击了清空计划按钮 */
  429. void TransmitterSwitch::do_pBtnClearPlan()
  430. {
  431. /* 先判断有没有选中的频率卡片 */
  432. if(PData.getCurrentPlanCard() == nullptr)
  433. {
  434. TipWidget::display(TipWidget::OPERATOR_FAIL, "没有选中频率卡片", this);
  435. return;
  436. }
  437. /* 跳出弹窗警告 */
  438. Warning w(this);
  439. w.setQSS(EPUIStyle.getQSSPath());
  440. w.setText("确定删除对应频率开关机计划?");
  441. bool flag = false;
  442. connect(&w,&Warning::signal_ok,this,[&](){
  443. flag = true;
  444. });
  445. w.exec();
  446. if(!flag)
  447. {
  448. return;
  449. }
  450. /* 获取选中的卡片 */
  451. auto pCard = PData.getCurrentPlanCard();
  452. if(pCard == nullptr)
  453. {
  454. LH_WRITE_ERROR("没有选中频率卡片");
  455. return;
  456. }
  457. /* 清空计划 */
  458. pCard->clearPlanItem();
  459. /* 删除数据库中的计划 */
  460. if(!m_fromWebAPI->deleteOneChnPlan(pCard->getChannelInfo().ChannelID))
  461. {
  462. LH_WRITE_ERROR(QString("频率ID为%1的计划删除失败").arg(pCard->getChannelInfo().ChannelID));
  463. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划删除失败").arg(pCard->getChannelInfo().ChannelName), this);
  464. }else {
  465. TipWidget::display(TipWidget::OPERATOR_OK, "清空计划成功", this);
  466. }
  467. }
  468. /* 导入数据 */
  469. void TransmitterSwitch::do_importData()
  470. {
  471. /* 获取模版列表 */
  472. QMultiMap<int, TemplateInfo> tabList;
  473. if(!m_fromWebAPI->getTemplateList(tabList))
  474. {
  475. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取模版列表失败", this);
  476. return;
  477. }
  478. /* 将模板列表添加频率信息 */
  479. std::shared_ptr<ImportTemplate> it = std::make_shared<ImportTemplate>();
  480. it->exec();
  481. }
  482. /* 导出数据 */
  483. void TransmitterSwitch::do_exportData()
  484. {
  485. // /* 先获取所有的模板名称 */
  486. // QMap<QString, int> tabList;
  487. // m_fromWebAPI->getTemplateList(tabList);
  488. // /* 弹出导出页面 */
  489. // std::shared_ptr<SaveToTemplate> stt = std::make_shared<SaveToTemplate>(this);
  490. // stt->setQSS(EPUIStyle.getQSSPath());
  491. // /* 注册事件过滤器 */
  492. // stt->installEventFilter(this);
  493. // int weekDay = ui->stackedWidget_items->currentIndex();
  494. // /* 设置周几 */
  495. // stt->setWeekDay(weekDay);
  496. // /* 判断当前页是否有计划 */
  497. // if(IData.getOneDay(weekDay)->size() == 0)
  498. // {
  499. // stt->setItemEmpty(true);
  500. // }else
  501. // {
  502. // stt->setItemEmpty(false);
  503. // }
  504. // /* 判断当前是正常日还是特殊日 */
  505. // int type = -1;
  506. // if(weekDay < 7 && weekDay >= 0)
  507. // {
  508. // type = 0;
  509. // }else if(weekDay == 7)
  510. // {
  511. // type = 1;
  512. // }
  513. // /* 获取所有的模板名称,并设置 */
  514. // stt->setTemplateName(tabList, type);
  515. // stt->exec();
  516. // if(stt->isOk())
  517. // {
  518. // /* 获取一天的数据 */
  519. // auto list = IData.getOneDayExecPlan(weekDay);
  520. // /* 保存到模板 */
  521. // if(m_fromWebAPI->saveTemplate(stt->getTemplateName(), type, list))
  522. // {
  523. // TipWidget::display(TipWidget::OPERATOR_OK, "保存模版成功", this);
  524. // }else {
  525. // TipWidget::display(TipWidget::OPERATOR_FAIL, "保存模版失败", this);
  526. // }
  527. // /* 调用回调函数 */
  528. // if(m_trackCB != nullptr)
  529. // {
  530. // m_trackCB(3, g_mapTrack.value(3));
  531. // }
  532. // }
  533. }
  534. /* 删除一个模板 */
  535. void TransmitterSwitch::do_deleteTemplate(QString name)
  536. {
  537. m_fromWebAPI->deleteTemplate(name);
  538. }
  539. /* 保存计划到EQM数据库 */
  540. void TransmitterSwitch::do_pBtn_savePlan()
  541. {
  542. /* 跳出弹窗提示 */
  543. Warning w(this);
  544. w.setQSS(EPUIStyle.getQSSPath());
  545. w.setText("将计划保存到数据库?");
  546. w.exec();
  547. if(!w.isOk())
  548. {
  549. return;
  550. }
  551. saveExecPlanToEQM();
  552. }
  553. /* 从EQM数据库获取计划 */
  554. void TransmitterSwitch::do_pBtn_getPlan()
  555. {
  556. /* 跳出弹窗提示 */
  557. Warning w(this);
  558. w.setQSS(EPUIStyle.getQSSPath());
  559. w.setText("从数据库获取计划,将清空当前所有的计划,请注意保存当前计划!");
  560. w.exec();
  561. if(!w.isOk())
  562. {
  563. return;
  564. }
  565. getExecPlanFromEQM();
  566. }
  567. /* 切换亮色/暗色外观 */
  568. void TransmitterSwitch::do_setUIStyle()
  569. {
  570. this->setStyleSheet(EPUIStyle.StrQSS_TransmitterSwitch);
  571. /* 给所有的按钮设置样式 */
  572. ui->pBtn_allFrequency->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  573. // LH_WRITE_LOG(QString("频率按钮设置样式:%1").arg(EPUIStyle.StrQSS_PBtnFrequency));
  574. }
  575. /* 选择了一个频率按钮,取消其他的选择 */
  576. void TransmitterSwitch::do_selectFrequencyBtn()
  577. {
  578. /* 获取信号发送者 */
  579. auto btn = qobject_cast<QPushButton*>(sender());
  580. if(btn == nullptr)
  581. {
  582. return;
  583. }
  584. /* 判断是否是“所有频率”按钮 */
  585. bool isAllFrequency = false;
  586. if(btn != ui->pBtn_allFrequency)
  587. {
  588. ui->pBtn_allFrequency->setChecked(false);
  589. }else {
  590. isAllFrequency = true;
  591. }
  592. /* 取消其他按钮的选择 */
  593. for(auto& it : m_listFrequencyBtn)
  594. {
  595. if(it != btn)
  596. {
  597. it->setChecked(false);
  598. }
  599. }
  600. if(btn != ui->pBtn_allFrequency)
  601. {
  602. /* 设置当前按钮的选择状态 */
  603. btn->setChecked(true);
  604. /* 设置该按钮对应的卡片状态 */
  605. auto pCard = static_cast<PBtnUserData2*>(btn->userData(m_userData_Btn))->getCard();
  606. pCard->clickedCard();
  607. }
  608. /* 显示当前按钮对应的卡片,隐藏其他卡片 */
  609. showOneCard(btn);
  610. }
  611. /* 添加一个频率,包括左侧按钮和右侧卡片 */
  612. void TransmitterSwitch::createOneCard(const ChannelInfo& chnInfo)
  613. {
  614. /* 创建按钮 */
  615. QPushButton* pBtn = new QPushButton(this);
  616. pBtn->setObjectName(chnInfo.ChannelName);
  617. pBtn->setText(chnInfo.ChannelName);
  618. pBtn->setCheckable(true);
  619. pBtn->setMinimumHeight(40);
  620. PBtnUserData2* userData = new PBtnUserData2();
  621. userData->setChannelInfo(chnInfo);
  622. pBtn->setUserData(m_userData_Btn, userData);
  623. /* 设置按钮的样式表 */
  624. pBtn->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  625. /* 连接信号和槽 */
  626. connect(pBtn, &QPushButton::clicked, this, &TransmitterSwitch::do_selectFrequencyBtn);
  627. m_listFrequencyBtn.push_back(pBtn);
  628. auto vLayout = qobject_cast<QVBoxLayout*>(ui->widget_frequency->layout());
  629. /* 减1是去掉最下面的弹簧 */
  630. vLayout->insertWidget(vLayout->count() - 1, pBtn);
  631. /* 创建卡片 */
  632. PlanCard* pCard = PData.createOneCard(chnInfo);
  633. m_flowlayout->addWidget(pCard);
  634. userData->setCard(pCard); /* 设置按钮的卡片指针 */
  635. /* 排序 */
  636. }
  637. /* 删除一个频率 */
  638. void TransmitterSwitch::deleteOneCard(int channelID)
  639. {
  640. /* 删除按钮 */
  641. for(auto it = m_listFrequencyBtn.begin(); it != m_listFrequencyBtn.end(); ++it)
  642. {
  643. auto userData = static_cast<PBtnUserData2*>((*it)->userData(m_userData_Btn));
  644. if(userData != nullptr && userData->getChannelInfo().ChannelID == channelID)
  645. {
  646. delete *it;
  647. m_listFrequencyBtn.erase(it);
  648. break;
  649. }
  650. }
  651. /* 删除卡片 */
  652. PData.deleteOneCard(channelID);
  653. }
  654. /* 创建所有频率卡片 */
  655. void TransmitterSwitch::createAllCard()
  656. {
  657. for(const auto& it : ChnContainer.getMapChannel())
  658. {
  659. /* 创建一个按钮和卡片 */
  660. createOneCard(it);
  661. }
  662. }
  663. /* 显示某个卡片,隐藏其他卡片 */
  664. void TransmitterSwitch::showOneCard(QPushButton *btn)
  665. {
  666. /* 判断是否是显示全部卡片的按钮 */
  667. if(btn == ui->pBtn_allFrequency)
  668. {
  669. /* 设置卡片间的横向间距 */
  670. m_flowlayout->setHorizontalSpacing(m_cardHorSpacing);
  671. /* 显示全部卡片 */
  672. for(auto& it : m_listFrequencyBtn)
  673. {
  674. auto ud = it->userData(m_userData_Btn);
  675. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  676. if(userData != nullptr)
  677. {
  678. auto pCard = userData->getCard();
  679. if(pCard != nullptr)
  680. {
  681. pCard->show();
  682. }
  683. }
  684. }
  685. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  686. ui->scrollAreaContents_Card->updateGeometry();
  687. return;
  688. }
  689. /* 设置卡片间的横向间距 */
  690. m_flowlayout->setHorizontalSpacing(0);
  691. /* 不是显示全部的按钮,隐藏所有卡片 */
  692. for(auto& it : m_listFrequencyBtn)
  693. {
  694. auto ud = it->userData(m_userData_Btn);
  695. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  696. if(userData != nullptr)
  697. {
  698. auto pCard = userData->getCard();
  699. if(pCard != nullptr)
  700. {
  701. pCard->hide();
  702. }
  703. }
  704. }
  705. /* 显示当前卡片 */
  706. auto ud = btn->userData(m_userData_Btn);
  707. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  708. if(userData != nullptr)
  709. {
  710. auto pCard = userData->getCard();
  711. if(pCard != nullptr)
  712. {
  713. pCard->show();
  714. }
  715. }
  716. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  717. ui->scrollAreaContents_Card->updateGeometry();
  718. }
  719. /* 计算并设置设置卡片大小 */
  720. void TransmitterSwitch::setCardSize()
  721. {
  722. /* 获取滚动条的区域 */
  723. int vsb = 0;
  724. if(ui->scrollArea->verticalScrollBar()->isVisible())
  725. {
  726. vsb = ui->scrollArea->verticalScrollBar()->width();
  727. }
  728. /* 去掉滚动条的宽度和阴影的宽度,再减去一个横向间距,和滚动条有些距离,不挨着太紧 */
  729. int saWidth = ui->scrollArea->width() - vsb - m_cardHorSpacing - 2;
  730. int saHeight = ui->scrollArea->height();
  731. int cardWidth = ( saWidth - (m_cardHorNumber - 1) * m_cardHorSpacing ) / m_cardHorNumber;
  732. int cardHeight = ( saHeight - (m_cardVerNumber - 1) * m_cardVerSpacing ) / m_cardVerNumber;
  733. /* 设置卡片大小 */
  734. PData.setCardSize(cardWidth, cardHeight);
  735. // LH_WRITE_LOG_DEBUG(QString("卡片大小:%1*%2").arg(cardWidth).arg(cardHeight));
  736. }
  737. /* 事件过滤器 */
  738. bool TransmitterSwitch::eventFilter(QObject *watched, QEvent *event)
  739. {
  740. if(watched == ui->label_Tip)
  741. {
  742. if(event->type() == QEvent::Enter)
  743. {
  744. m_tipText->show();
  745. return true;
  746. }else if(event->type() == QEvent::Leave)
  747. {
  748. m_tipText->hide();
  749. }
  750. }
  751. return QWidget::eventFilter(watched,event);
  752. }
  753. /* 窗口缩放事件 */
  754. void TransmitterSwitch::resizeEvent(QResizeEvent *event)
  755. {
  756. /* 设置提示文本的位置 */
  757. // if(m_tipText != nullptr)
  758. // {
  759. // QPoint pos = ui->label_Tip->mapTo(this, ui->label_Tip->pos());
  760. // m_tipText->move(pos.x() + 2, pos.y() + 2 );
  761. // }
  762. setCardSize();
  763. QWidget::resizeEvent(event);
  764. }
  765. /* 显示事件 */
  766. void TransmitterSwitch::showEvent(QShowEvent *event)
  767. {
  768. /* 设置提示文本的位置 */
  769. setCardSize();
  770. QWidget::showEvent(event);
  771. }