transmitterswitch.cpp 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880
  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. QMap<int, QList<OnePlanItemInfo>> mapPlan;
  187. if(m_fromWebAPI->getExecPlanData(mapPlan))
  188. {
  189. /* 先清空所有的计划 */
  190. PData.clearAllPlanItem();
  191. /* 遍历所有的频率 */
  192. for(auto begin = mapPlan.begin(), end = mapPlan.end(); begin != end; begin++)
  193. {
  194. auto pCard = PData.findPlanCard(begin.key());
  195. if(pCard != nullptr)
  196. {
  197. pCard->setPlanList(begin.value());
  198. }
  199. }
  200. TipWidget::display(TipWidget::OPERATOR_OK, "获取计划成功", this);
  201. }else {
  202. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("获取计划失败"), this);
  203. }
  204. /* 调用回调函数 */
  205. if(m_trackCB != nullptr)
  206. {
  207. m_trackCB(2, g_mapTrack.value(2));
  208. }
  209. }
  210. /* 将计划保存到EQM数据库 */
  211. void TransmitterSwitch::saveExecPlanToEQM()
  212. {
  213. QList<OnePlanItemInfo> list;
  214. /* 获取当前计划的执行模式 */
  215. int execType = 0;
  216. if(ui->rBtn_moment->isChecked())
  217. {
  218. execType = 0;
  219. } else
  220. {
  221. execType = 1;
  222. }
  223. // for(const auto& it : IData.getMapItem())
  224. // {
  225. // for(const auto& it1 : *it)
  226. // {
  227. // OnePlanItemInfo info;
  228. // info.ExecType = execType;
  229. // info.devName = it1->getDevName();
  230. // info.actionID = it1->getActionNum();
  231. // info.actionName = it1->getActionName();
  232. // info.execTime = it1->getExecTime();
  233. // info.date = it1->getDate();
  234. // info.WeekDay = it1->getWeekDay() + 1;
  235. // list.push_back(info);
  236. // }
  237. // }
  238. /* 写入数据库 */
  239. // if(m_fromWebAPI->insertData(list))
  240. // {
  241. // TipWidget::display(TipWidget::OPERATOR_OK, "保存计划成功", this);
  242. // }else {
  243. // TipWidget::display(TipWidget::OPERATOR_FAIL, "保存计划失败", this);
  244. // }
  245. /* 保存“默认计划”和“执行模式” */
  246. ConfigData config1;
  247. config1.key = static_cast<int>(enum_ExecPlanConfig::OpenPlan);
  248. config1.value = ui->pBtn_defaultPlan->isChecked() ? 1 : 0;
  249. config1.updateTime = QDateTime::currentDateTime();
  250. CfgData.updateConfigData(config1);
  251. ConfigData config2;
  252. config2.key = static_cast<int>(enum_ExecPlanConfig::ExecMode);
  253. config2.value = ui->rBtn_moment->isChecked() ? 0 : 1;
  254. config2.updateTime = QDateTime::currentDateTime();
  255. CfgData.updateConfigData(config2);
  256. /* 更新“计划是否更新”标志位,在更新前需要先获取数据库的标志位,如果依旧为1,那么本地是否更改都设置为1 */
  257. ConfigData config3;
  258. if(!m_fromWebAPI->getConfigData(static_cast<int>(enum_ExecPlanConfig::IsChanged), config3))
  259. {
  260. config3.key = static_cast<int>(enum_ExecPlanConfig::IsChanged);
  261. }
  262. /* 只要数据库和本地更新标志位有一个为true,说明还未被读走,则设置标志位为true */
  263. // if((config3.value == 1) || IData.isUpdate())
  264. // {
  265. // config3.value = 1;
  266. // }
  267. config3.updateTime = QDateTime::currentDateTime();
  268. CfgData.updateConfigData(config3);
  269. /* 将配置写入数据库 */
  270. m_fromWebAPI->insertConfigData(CfgData.getMapConfigData());
  271. /* 调用回调函数 */
  272. if(m_trackCB != nullptr)
  273. {
  274. m_trackCB(1, g_mapTrack.value(1));
  275. }
  276. }
  277. /* 亮/暗换肤,0是亮色,1是暗色 */
  278. void TransmitterSwitch::setUIStyle(int style)
  279. {
  280. if(style == 0)
  281. {
  282. EPUIStyle.setUIStyle(enum_UIStyle::UI_Light);
  283. }
  284. else if(style == 1)
  285. {
  286. EPUIStyle.setUIStyle(enum_UIStyle::UI_Dark);
  287. }else {
  288. LH_WRITE_ERROR(QString("错误的样式类型: %1").arg(style));
  289. }
  290. }
  291. /* 设置回调函数 */
  292. void TransmitterSwitch::setTrackCallBack(trackCallBack cb)
  293. {
  294. if(cb == nullptr)
  295. {
  296. return;
  297. }
  298. m_trackCB = cb;
  299. }
  300. /* 点击了添加计划按钮 */
  301. void TransmitterSwitch::do_pBtnAddExecPlan()
  302. {
  303. /* 创建新增窗口 */
  304. std::shared_ptr<ManagerPlan> mp = std::make_shared<ManagerPlan>();
  305. /* 获取当前选中的窗口 */
  306. auto pCard = PData.getCurrentPlanCard();
  307. ChannelInfo chnInfo;
  308. if(pCard == nullptr)
  309. {
  310. LH_WRITE_LOG_DEBUG("没有选中频率卡片");
  311. }else {
  312. mp->setFrequencyID(pCard->getChannelInfo());
  313. }
  314. mp->exec();
  315. /* 判断是否点击了OK */
  316. if(!mp->isOK())
  317. {
  318. return;
  319. }
  320. /* 获取计划信息 */
  321. auto& mapPlanInfo = mp->getPlanInfo();
  322. /* 遍历所有的频率 */
  323. bool isSuccess = true;
  324. for(auto begin = mapPlanInfo.begin(), end = mapPlanInfo.end(); begin != end; begin++)
  325. {
  326. /* 获取频率ID */
  327. int chnID = begin.key();
  328. /* 获取计划列表 */
  329. auto& list = begin.value();
  330. /* 查找这个频率的Card */
  331. auto pCard = PData.findPlanCard(chnID);
  332. if(pCard == nullptr)
  333. {
  334. LH_WRITE_ERROR(QString("没有找到频率ID为%1的卡片").arg(chnID));
  335. continue;
  336. }
  337. /* 设置计划列表 */
  338. pCard->setPlanList(list);
  339. /* 写入数据库 */
  340. QList<OnePlanItemInfo> listPlan;
  341. pCard->getAllPlanInfo(listPlan);
  342. if(!m_fromWebAPI->insertData(chnID, listPlan))
  343. {
  344. LH_WRITE_ERROR(QString("频率ID为%1的计划写入数据库失败").arg(chnID));
  345. isSuccess = false;
  346. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划写入数据库失败").arg(pCard->getChannelInfo().ChannelName), this);
  347. }
  348. }
  349. if(isSuccess)
  350. {
  351. TipWidget::display(TipWidget::OPERATOR_OK, "添加计划成功", this);
  352. }
  353. }
  354. /* 点击了修改按钮 */
  355. void TransmitterSwitch::do_pBtnModifyExecPlan()
  356. {
  357. /* 创建新增窗口 */
  358. std::shared_ptr<ManagerPlan> mp = std::make_shared<ManagerPlan>();
  359. mp->setMode(Enum_Mode::Mode_Modify);
  360. auto pCard = PData.getCurrentPlanCard();
  361. if(pCard == nullptr)
  362. {
  363. LH_WRITE_ERROR("没有选中频率卡片");
  364. return;
  365. }
  366. /* 设置频率信息 */
  367. mp->setFrequencyID(pCard->getChannelInfo());
  368. mp->exec();
  369. /* 判断是否点击了OK */
  370. if(!mp->isOK())
  371. {
  372. return;
  373. }
  374. /* 获取计划信息 */
  375. auto& mapPlanInfo = mp->getPlanInfo();
  376. auto list = mapPlanInfo.find(pCard->getChannelInfo().ChannelID);
  377. pCard->setPlanList(*list);
  378. int chnID = pCard->getChannelInfo().ChannelID;
  379. QList<OnePlanItemInfo> listPlan;
  380. pCard->getAllPlanInfo(listPlan);
  381. if(!m_fromWebAPI->insertData(chnID, listPlan))
  382. {
  383. LH_WRITE_ERROR(QString("频率ID为%1的计划写入数据库失败").arg(chnID));
  384. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划写入数据库失败").arg(pCard->getChannelInfo().ChannelName), this);
  385. }
  386. TipWidget::display(TipWidget::OPERATOR_OK, "修改计划成功", this);
  387. /* 调用回调函数 */
  388. if(m_trackCB != nullptr)
  389. {
  390. m_trackCB(1, g_mapTrack.value(1));
  391. }
  392. }
  393. /* 点击了刷新按钮 */
  394. void TransmitterSwitch::do_pBtnRefresh()
  395. {
  396. getExecPlanFromEQM();
  397. }
  398. /* 点击了“是否开启计划”按钮 */
  399. void TransmitterSwitch::do_pBtnIsOpenPlan()
  400. {
  401. /* 保存“默认计划”和“执行模式” */
  402. ConfigData config1;
  403. config1.key = static_cast<int>(enum_ExecPlanConfig::OpenPlan);
  404. config1.value = ui->pBtn_defaultPlan->isChecked() ? 1 : 0;
  405. config1.updateTime = QDateTime::currentDateTime();
  406. CfgData.updateConfigData(config1);
  407. /* 更新“计划是否更新”标志位,在更新前需要先获取数据库的标志位,如果依旧为1,那么本地是否更改都设置为1 */
  408. ConfigData config3;
  409. if(!m_fromWebAPI->getConfigData(static_cast<int>(enum_ExecPlanConfig::IsChanged), config3))
  410. {
  411. config3.key = static_cast<int>(enum_ExecPlanConfig::IsChanged);
  412. }
  413. /* 只要数据库和本地更新标志位有一个为true,说明还未被读走,则设置标志位为true */
  414. config3.value = 1;
  415. config3.updateTime = QDateTime::currentDateTime();
  416. CfgData.updateConfigData(config3);
  417. /* 将配置写入数据库 */
  418. m_fromWebAPI->insertConfigData(CfgData.getMapConfigData());
  419. }
  420. /* 点击了“执行模式”按钮 */
  421. void TransmitterSwitch::do_pBtnExecMode()
  422. {
  423. /* 保存“默认计划”和“执行模式” */
  424. ConfigData config1;
  425. config1.key = static_cast<int>(enum_ExecPlanConfig::ExecMode);
  426. config1.value = ui->rBtn_moment->isChecked() ? 0 : 1;
  427. config1.updateTime = QDateTime::currentDateTime();
  428. CfgData.updateConfigData(config1);
  429. /* 更新“计划是否更新”标志位,在更新前需要先获取数据库的标志位,如果依旧为1,那么本地是否更改都设置为1 */
  430. ConfigData config3;
  431. if(!m_fromWebAPI->getConfigData(static_cast<int>(enum_ExecPlanConfig::IsChanged), config3))
  432. {
  433. config3.key = static_cast<int>(enum_ExecPlanConfig::IsChanged);
  434. }
  435. /* 只要数据库和本地更新标志位有一个为true,说明还未被读走,则设置标志位为true */
  436. config3.value = 1;
  437. config3.updateTime = QDateTime::currentDateTime();
  438. CfgData.updateConfigData(config3);
  439. /* 将配置写入数据库 */
  440. m_fromWebAPI->insertConfigData(CfgData.getMapConfigData());
  441. }
  442. /* 点击了清空计划按钮 */
  443. void TransmitterSwitch::do_pBtnClearPlan()
  444. {
  445. /* 先判断有没有选中的频率卡片 */
  446. if(PData.getCurrentPlanCard() == nullptr)
  447. {
  448. TipWidget::display(TipWidget::OPERATOR_FAIL, "没有选中频率卡片", this);
  449. return;
  450. }
  451. /* 跳出弹窗警告 */
  452. Warning w(this);
  453. w.setQSS(EPUIStyle.getQSSPath());
  454. w.setText("确定删除对应频率开关机计划?");
  455. bool flag = false;
  456. connect(&w,&Warning::signal_ok,this,[&](){
  457. flag = true;
  458. });
  459. w.exec();
  460. if(!flag)
  461. {
  462. return;
  463. }
  464. /* 获取选中的卡片 */
  465. auto pCard = PData.getCurrentPlanCard();
  466. if(pCard == nullptr)
  467. {
  468. LH_WRITE_ERROR("没有选中频率卡片");
  469. return;
  470. }
  471. /* 清空计划 */
  472. pCard->clearPlanItem();
  473. /* 删除数据库中的计划 */
  474. if(!m_fromWebAPI->deleteOneChnPlan(pCard->getChannelInfo().ChannelID))
  475. {
  476. LH_WRITE_ERROR(QString("频率ID为%1的计划删除失败").arg(pCard->getChannelInfo().ChannelID));
  477. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划删除失败").arg(pCard->getChannelInfo().ChannelName), this);
  478. }else {
  479. TipWidget::display(TipWidget::OPERATOR_OK, "清空计划成功", this);
  480. }
  481. }
  482. /* 导入数据 */
  483. void TransmitterSwitch::do_importData()
  484. {
  485. /* 获取模版列表 */
  486. QMultiMap<int, TemplateInfo> tabList;
  487. if(!m_fromWebAPI->getTemplateList(tabList))
  488. {
  489. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取模版列表失败", this);
  490. return;
  491. }
  492. /* 将模板列表添加频率信息 */
  493. std::shared_ptr<ImportTemplate> it = std::make_shared<ImportTemplate>();
  494. it->exec();
  495. }
  496. /* 导出数据 */
  497. void TransmitterSwitch::do_exportData()
  498. {
  499. // /* 先获取所有的模板名称 */
  500. // QMap<QString, int> tabList;
  501. // m_fromWebAPI->getTemplateList(tabList);
  502. // /* 弹出导出页面 */
  503. // std::shared_ptr<SaveToTemplate> stt = std::make_shared<SaveToTemplate>(this);
  504. // stt->setQSS(EPUIStyle.getQSSPath());
  505. // /* 注册事件过滤器 */
  506. // stt->installEventFilter(this);
  507. // int weekDay = ui->stackedWidget_items->currentIndex();
  508. // /* 设置周几 */
  509. // stt->setWeekDay(weekDay);
  510. // /* 判断当前页是否有计划 */
  511. // if(IData.getOneDay(weekDay)->size() == 0)
  512. // {
  513. // stt->setItemEmpty(true);
  514. // }else
  515. // {
  516. // stt->setItemEmpty(false);
  517. // }
  518. // /* 判断当前是正常日还是特殊日 */
  519. // int type = -1;
  520. // if(weekDay < 7 && weekDay >= 0)
  521. // {
  522. // type = 0;
  523. // }else if(weekDay == 7)
  524. // {
  525. // type = 1;
  526. // }
  527. // /* 获取所有的模板名称,并设置 */
  528. // stt->setTemplateName(tabList, type);
  529. // stt->exec();
  530. // if(stt->isOk())
  531. // {
  532. // /* 获取一天的数据 */
  533. // auto list = IData.getOneDayExecPlan(weekDay);
  534. // /* 保存到模板 */
  535. // if(m_fromWebAPI->saveTemplate(stt->getTemplateName(), type, list))
  536. // {
  537. // TipWidget::display(TipWidget::OPERATOR_OK, "保存模版成功", this);
  538. // }else {
  539. // TipWidget::display(TipWidget::OPERATOR_FAIL, "保存模版失败", this);
  540. // }
  541. // /* 调用回调函数 */
  542. // if(m_trackCB != nullptr)
  543. // {
  544. // m_trackCB(3, g_mapTrack.value(3));
  545. // }
  546. // }
  547. }
  548. /* 删除一个模板 */
  549. void TransmitterSwitch::do_deleteTemplate(QString name)
  550. {
  551. m_fromWebAPI->deleteTemplate(name);
  552. }
  553. /* 保存计划到EQM数据库 */
  554. void TransmitterSwitch::do_pBtn_savePlan()
  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. saveExecPlanToEQM();
  566. }
  567. /* 从EQM数据库获取计划 */
  568. void TransmitterSwitch::do_pBtn_getPlan()
  569. {
  570. /* 跳出弹窗提示 */
  571. Warning w(this);
  572. w.setQSS(EPUIStyle.getQSSPath());
  573. w.setText("从数据库获取计划,将清空当前所有的计划,请注意保存当前计划!");
  574. w.exec();
  575. if(!w.isOk())
  576. {
  577. return;
  578. }
  579. getExecPlanFromEQM();
  580. }
  581. /* 切换亮色/暗色外观 */
  582. void TransmitterSwitch::do_setUIStyle()
  583. {
  584. this->setStyleSheet(EPUIStyle.StrQSS_TransmitterSwitch);
  585. /* 给所有的按钮设置样式 */
  586. ui->pBtn_allFrequency->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  587. // LH_WRITE_LOG(QString("频率按钮设置样式:%1").arg(EPUIStyle.StrQSS_PBtnFrequency));
  588. }
  589. /* 选择了一个频率按钮,取消其他的选择 */
  590. void TransmitterSwitch::do_selectFrequencyBtn()
  591. {
  592. /* 获取信号发送者 */
  593. auto btn = qobject_cast<QPushButton*>(sender());
  594. if(btn == nullptr)
  595. {
  596. return;
  597. }
  598. /* 判断是否是“所有频率”按钮 */
  599. bool isAllFrequency = false;
  600. if(btn != ui->pBtn_allFrequency)
  601. {
  602. ui->pBtn_allFrequency->setChecked(false);
  603. }else {
  604. isAllFrequency = true;
  605. }
  606. /* 取消其他按钮的选择 */
  607. for(auto& it : m_listFrequencyBtn)
  608. {
  609. if(it != btn)
  610. {
  611. it->setChecked(false);
  612. }
  613. }
  614. if(btn != ui->pBtn_allFrequency)
  615. {
  616. /* 设置当前按钮的选择状态 */
  617. btn->setChecked(true);
  618. /* 设置该按钮对应的卡片状态 */
  619. auto pCard = static_cast<PBtnUserData2*>(btn->userData(m_userData_Btn))->getCard();
  620. pCard->clickedCard();
  621. }
  622. /* 显示当前按钮对应的卡片,隐藏其他卡片 */
  623. showOneCard(btn);
  624. }
  625. /* 添加一个频率,包括左侧按钮和右侧卡片 */
  626. void TransmitterSwitch::createOneCard(const ChannelInfo& chnInfo)
  627. {
  628. /* 创建按钮 */
  629. QPushButton* pBtn = new QPushButton(this);
  630. pBtn->setObjectName(chnInfo.ChannelName);
  631. pBtn->setText(chnInfo.ChannelName);
  632. pBtn->setCheckable(true);
  633. pBtn->setMinimumHeight(40);
  634. PBtnUserData2* userData = new PBtnUserData2();
  635. userData->setChannelInfo(chnInfo);
  636. pBtn->setUserData(m_userData_Btn, userData);
  637. /* 设置按钮的样式表 */
  638. pBtn->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  639. /* 连接信号和槽 */
  640. connect(pBtn, &QPushButton::clicked, this, &TransmitterSwitch::do_selectFrequencyBtn);
  641. m_listFrequencyBtn.push_back(pBtn);
  642. auto vLayout = qobject_cast<QVBoxLayout*>(ui->widget_frequency->layout());
  643. /* 减1是去掉最下面的弹簧 */
  644. vLayout->insertWidget(vLayout->count() - 1, pBtn);
  645. /* 创建卡片 */
  646. PlanCard* pCard = PData.createOneCard(chnInfo);
  647. m_flowlayout->addWidget(pCard);
  648. userData->setCard(pCard); /* 设置按钮的卡片指针 */
  649. /* 排序 */
  650. }
  651. /* 删除一个频率 */
  652. void TransmitterSwitch::deleteOneCard(int channelID)
  653. {
  654. /* 删除按钮 */
  655. for(auto it = m_listFrequencyBtn.begin(); it != m_listFrequencyBtn.end(); ++it)
  656. {
  657. auto userData = static_cast<PBtnUserData2*>((*it)->userData(m_userData_Btn));
  658. if(userData != nullptr && userData->getChannelInfo().ChannelID == channelID)
  659. {
  660. delete *it;
  661. m_listFrequencyBtn.erase(it);
  662. break;
  663. }
  664. }
  665. /* 删除卡片 */
  666. PData.deleteOneCard(channelID);
  667. }
  668. /* 创建所有频率卡片 */
  669. void TransmitterSwitch::createAllCard()
  670. {
  671. for(const auto& it : ChnContainer.getMapChannel())
  672. {
  673. /* 创建一个按钮和卡片 */
  674. createOneCard(it);
  675. }
  676. }
  677. /* 显示某个卡片,隐藏其他卡片 */
  678. void TransmitterSwitch::showOneCard(QPushButton *btn)
  679. {
  680. /* 判断是否是显示全部卡片的按钮 */
  681. if(btn == ui->pBtn_allFrequency)
  682. {
  683. /* 设置卡片间的横向间距 */
  684. m_flowlayout->setHorizontalSpacing(m_cardHorSpacing);
  685. /* 显示全部卡片 */
  686. for(auto& it : m_listFrequencyBtn)
  687. {
  688. auto ud = it->userData(m_userData_Btn);
  689. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  690. if(userData != nullptr)
  691. {
  692. auto pCard = userData->getCard();
  693. if(pCard != nullptr)
  694. {
  695. pCard->show();
  696. }
  697. }
  698. }
  699. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  700. ui->scrollAreaContents_Card->updateGeometry();
  701. return;
  702. }
  703. /* 设置卡片间的横向间距 */
  704. m_flowlayout->setHorizontalSpacing(0);
  705. /* 不是显示全部的按钮,隐藏所有卡片 */
  706. for(auto& it : m_listFrequencyBtn)
  707. {
  708. auto ud = it->userData(m_userData_Btn);
  709. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  710. if(userData != nullptr)
  711. {
  712. auto pCard = userData->getCard();
  713. if(pCard != nullptr)
  714. {
  715. pCard->hide();
  716. }
  717. }
  718. }
  719. /* 显示当前卡片 */
  720. auto ud = btn->userData(m_userData_Btn);
  721. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  722. if(userData != nullptr)
  723. {
  724. auto pCard = userData->getCard();
  725. if(pCard != nullptr)
  726. {
  727. pCard->show();
  728. }
  729. }
  730. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  731. ui->scrollAreaContents_Card->updateGeometry();
  732. }
  733. /* 计算并设置设置卡片大小 */
  734. void TransmitterSwitch::setCardSize()
  735. {
  736. /* 获取滚动条的区域 */
  737. int vsb = 0;
  738. if(ui->scrollArea->verticalScrollBar()->isVisible())
  739. {
  740. vsb = ui->scrollArea->verticalScrollBar()->width();
  741. }
  742. /* 去掉滚动条的宽度和阴影的宽度,再减去一个横向间距,和滚动条有些距离,不挨着太紧 */
  743. int saWidth = ui->scrollArea->width() - vsb - m_cardHorSpacing - 2;
  744. int saHeight = ui->scrollArea->height();
  745. int cardWidth = ( saWidth - (m_cardHorNumber - 1) * m_cardHorSpacing ) / m_cardHorNumber;
  746. int cardHeight = ( saHeight - (m_cardVerNumber - 1) * m_cardVerSpacing ) / m_cardVerNumber;
  747. /* 设置卡片大小 */
  748. PData.setCardSize(cardWidth, cardHeight);
  749. // LH_WRITE_LOG_DEBUG(QString("卡片大小:%1*%2").arg(cardWidth).arg(cardHeight));
  750. }
  751. /* 事件过滤器 */
  752. bool TransmitterSwitch::eventFilter(QObject *watched, QEvent *event)
  753. {
  754. if(watched == ui->label_Tip)
  755. {
  756. if(event->type() == QEvent::Enter)
  757. {
  758. m_tipText->show();
  759. return true;
  760. }else if(event->type() == QEvent::Leave)
  761. {
  762. m_tipText->hide();
  763. }
  764. }
  765. return QWidget::eventFilter(watched,event);
  766. }
  767. /* 窗口缩放事件 */
  768. void TransmitterSwitch::resizeEvent(QResizeEvent *event)
  769. {
  770. /* 设置提示文本的位置 */
  771. // if(m_tipText != nullptr)
  772. // {
  773. // QPoint pos = ui->label_Tip->mapTo(this, ui->label_Tip->pos());
  774. // m_tipText->move(pos.x() + 2, pos.y() + 2 );
  775. // }
  776. setCardSize();
  777. QWidget::resizeEvent(event);
  778. }
  779. /* 显示事件 */
  780. void TransmitterSwitch::showEvent(QShowEvent *event)
  781. {
  782. /* 设置提示文本的位置 */
  783. setCardSize();
  784. QWidget::showEvent(event);
  785. }