transmitterswitch.cpp 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905
  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. QMultiMap<int, OneTemplateInfo> tabList;
  486. /* 判断有没有选中卡片 */
  487. auto pCard = PData.getCurrentPlanCard();
  488. bool isSuccess = true;
  489. if(pCard == nullptr)
  490. {
  491. /* 没有选中卡片,获取全部的频率 */
  492. if(!m_fromWebAPI->getTemplateList(tabList))
  493. {
  494. isSuccess = false;
  495. }
  496. }else {
  497. /* 选中了卡片,只获取这个卡片的频率列表 */
  498. QList<OneTemplateInfo> list;
  499. if(m_fromWebAPI->getTemplateList(pCard->getChannelInfo().ChannelID, list))
  500. {
  501. for(auto it = list.begin(), end = list.end(); it != end; it++)
  502. {
  503. tabList.insert(it->channelInfo.ChannelID, *it);
  504. }
  505. }else {
  506. isSuccess = false;
  507. LH_WRITE_ERROR(QString("获取频率ID为%1的模版列表失败").arg(pCard->getChannelInfo().ChannelID));
  508. }
  509. }
  510. if(isSuccess == false)
  511. {
  512. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取模版列表失败", this);
  513. return;
  514. }
  515. /* 将模板列表添加频率信息 */
  516. for(auto it = tabList.begin(), end = tabList.end(); it != end; it++)
  517. {
  518. auto chnInfo = ChnContainer.getChannel(it->channelInfo.ChannelID);
  519. it->channelInfo = chnInfo;
  520. }
  521. std::shared_ptr<ImportTemplate> it = std::make_shared<ImportTemplate>();
  522. it->setQSSPath(EPUIStyle.getQSSPath());
  523. it->setTemplateList(tabList);
  524. it->exec();
  525. }
  526. /* 导出数据 */
  527. void TransmitterSwitch::do_exportData()
  528. {
  529. /* 先获取选中的卡片 */
  530. auto pCard = PData.getCurrentPlanCard();
  531. if(pCard == nullptr)
  532. {
  533. LH_WRITE_ERROR("没有选中频率卡片");
  534. TipWidget::display(TipWidget::OPERATOR_WARN, "未选中频率卡片", this);
  535. return;
  536. }
  537. /* 判断该卡片的计划列表是否为空 */
  538. if(pCard->isPlanEmpty())
  539. {
  540. TipWidget::display(TipWidget::OPERATOR_WARN, "当前频率没有计划", this);
  541. return;
  542. }
  543. int chnID = pCard->getChannelInfo().ChannelID;
  544. /* 获取所有的模板名称 */
  545. QList<OneTemplateInfo> list;
  546. if(!m_fromWebAPI->getTemplateList(chnID, list))
  547. {
  548. LH_WRITE_ERROR(QString("获取频率ID为%1的模版列表失败").arg(chnID));
  549. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取模版列表失败", this);
  550. return;
  551. }
  552. /* 弹出导出页面 */
  553. std::shared_ptr<SaveToTemplate> stt = std::make_shared<SaveToTemplate>(this);
  554. stt->setQSS(EPUIStyle.getQSSPath());
  555. stt->setTemplateList(list);
  556. stt->exec();
  557. if(stt->isOk())
  558. {
  559. /* 获取一天的数据 */
  560. QList<OnePlanItemInfo> listTmp;
  561. pCard->getAllPlanInfo(listTmp);
  562. /* 保存到模板 */
  563. if(m_fromWebAPI->saveTemplate(stt->getTemplateName(), listTmp))
  564. {
  565. TipWidget::display(TipWidget::OPERATOR_OK, "保存模版成功", this);
  566. }else {
  567. TipWidget::display(TipWidget::OPERATOR_FAIL, "保存模版失败", this);
  568. }
  569. /* 调用回调函数 */
  570. if(m_trackCB != nullptr)
  571. {
  572. m_trackCB(3, g_mapTrack.value(3));
  573. }
  574. }
  575. }
  576. /* 删除一个模板 */
  577. void TransmitterSwitch::do_deleteTemplate(QString name)
  578. {
  579. m_fromWebAPI->deleteTemplate(name);
  580. }
  581. /* 保存计划到EQM数据库 */
  582. void TransmitterSwitch::do_pBtn_savePlan()
  583. {
  584. /* 跳出弹窗提示 */
  585. Warning w(this);
  586. w.setQSS(EPUIStyle.getQSSPath());
  587. w.setText("将计划保存到数据库?");
  588. w.exec();
  589. if(!w.isOk())
  590. {
  591. return;
  592. }
  593. saveExecPlanToEQM();
  594. }
  595. /* 从EQM数据库获取计划 */
  596. void TransmitterSwitch::do_pBtn_getPlan()
  597. {
  598. /* 跳出弹窗提示 */
  599. Warning w(this);
  600. w.setQSS(EPUIStyle.getQSSPath());
  601. w.setText("从数据库获取计划,将清空当前所有的计划,请注意保存当前计划!");
  602. w.exec();
  603. if(!w.isOk())
  604. {
  605. return;
  606. }
  607. getExecPlanFromEQM();
  608. }
  609. /* 切换亮色/暗色外观 */
  610. void TransmitterSwitch::do_setUIStyle()
  611. {
  612. this->setStyleSheet(EPUIStyle.StrQSS_TransmitterSwitch);
  613. /* 给所有的按钮设置样式 */
  614. ui->pBtn_allFrequency->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  615. // LH_WRITE_LOG(QString("频率按钮设置样式:%1").arg(EPUIStyle.StrQSS_PBtnFrequency));
  616. }
  617. /* 选择了一个频率按钮,取消其他的选择 */
  618. void TransmitterSwitch::do_selectFrequencyBtn()
  619. {
  620. /* 获取信号发送者 */
  621. auto btn = qobject_cast<QPushButton*>(sender());
  622. if(btn == nullptr)
  623. {
  624. return;
  625. }
  626. /* 取消其他按钮的选择 */
  627. for(auto& it : m_listFrequencyBtn)
  628. {
  629. if(it != btn)
  630. {
  631. it->setChecked(false);
  632. }
  633. }
  634. if(btn != ui->pBtn_allFrequency)
  635. {
  636. ui->pBtn_allFrequency->setChecked(false);
  637. /* 设置当前按钮的选择状态 */
  638. btn->setChecked(true);
  639. /* 设置该按钮对应的卡片状态 */
  640. auto pCard = static_cast<PBtnUserData2*>(btn->userData(m_userData_Btn))->getCard();
  641. pCard->clickedCard();
  642. }else {
  643. ui->pBtn_allFrequency->setChecked(true);
  644. /* 取消所有的卡片选择状态 */
  645. PData.clearAllSelectedCard();
  646. }
  647. /* 显示当前按钮对应的卡片,隐藏其他卡片 */
  648. showOneCard(btn);
  649. }
  650. /* 添加一个频率,包括左侧按钮和右侧卡片 */
  651. void TransmitterSwitch::createOneCard(const ChannelInfo& chnInfo)
  652. {
  653. /* 创建按钮 */
  654. QPushButton* pBtn = new QPushButton(this);
  655. pBtn->setObjectName(chnInfo.ChannelName);
  656. pBtn->setText(chnInfo.ChannelName);
  657. pBtn->setCheckable(true);
  658. pBtn->setMinimumHeight(40);
  659. PBtnUserData2* userData = new PBtnUserData2();
  660. userData->setChannelInfo(chnInfo);
  661. pBtn->setUserData(m_userData_Btn, userData);
  662. /* 设置按钮的样式表 */
  663. pBtn->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  664. /* 连接信号和槽 */
  665. connect(pBtn, &QPushButton::clicked, this, &TransmitterSwitch::do_selectFrequencyBtn);
  666. m_listFrequencyBtn.push_back(pBtn);
  667. auto vLayout = qobject_cast<QVBoxLayout*>(ui->widget_frequency->layout());
  668. /* 减1是去掉最下面的弹簧 */
  669. vLayout->insertWidget(vLayout->count() - 1, pBtn);
  670. /* 创建卡片 */
  671. PlanCard* pCard = PData.createOneCard(chnInfo);
  672. m_flowlayout->addWidget(pCard);
  673. userData->setCard(pCard); /* 设置按钮的卡片指针 */
  674. /* 排序 */
  675. }
  676. /* 删除一个频率 */
  677. void TransmitterSwitch::deleteOneCard(int channelID)
  678. {
  679. /* 删除按钮 */
  680. for(auto it = m_listFrequencyBtn.begin(); it != m_listFrequencyBtn.end(); ++it)
  681. {
  682. auto userData = static_cast<PBtnUserData2*>((*it)->userData(m_userData_Btn));
  683. if(userData != nullptr && userData->getChannelInfo().ChannelID == channelID)
  684. {
  685. delete *it;
  686. m_listFrequencyBtn.erase(it);
  687. break;
  688. }
  689. }
  690. /* 删除卡片 */
  691. PData.deleteOneCard(channelID);
  692. }
  693. /* 创建所有频率卡片 */
  694. void TransmitterSwitch::createAllCard()
  695. {
  696. for(const auto& it : ChnContainer.getMapChannel())
  697. {
  698. /* 创建一个按钮和卡片 */
  699. createOneCard(it);
  700. }
  701. }
  702. /* 显示某个卡片,隐藏其他卡片 */
  703. void TransmitterSwitch::showOneCard(QPushButton *btn)
  704. {
  705. /* 判断是否是显示全部卡片的按钮 */
  706. if(btn == ui->pBtn_allFrequency)
  707. {
  708. /* 设置卡片间的横向间距 */
  709. m_flowlayout->setHorizontalSpacing(m_cardHorSpacing);
  710. /* 显示全部卡片 */
  711. for(auto& it : m_listFrequencyBtn)
  712. {
  713. auto ud = it->userData(m_userData_Btn);
  714. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  715. if(userData != nullptr)
  716. {
  717. auto pCard = userData->getCard();
  718. if(pCard != nullptr)
  719. {
  720. pCard->show();
  721. }
  722. }
  723. }
  724. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  725. ui->scrollAreaContents_Card->updateGeometry();
  726. return;
  727. }
  728. /* 设置卡片间的横向间距 */
  729. m_flowlayout->setHorizontalSpacing(0);
  730. /* 不是显示全部的按钮,隐藏所有卡片 */
  731. for(auto& it : m_listFrequencyBtn)
  732. {
  733. auto ud = it->userData(m_userData_Btn);
  734. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  735. if(userData != nullptr)
  736. {
  737. auto pCard = userData->getCard();
  738. if(pCard != nullptr)
  739. {
  740. pCard->hide();
  741. }
  742. }
  743. }
  744. /* 显示当前卡片 */
  745. auto ud = btn->userData(m_userData_Btn);
  746. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  747. if(userData != nullptr)
  748. {
  749. auto pCard = userData->getCard();
  750. if(pCard != nullptr)
  751. {
  752. pCard->show();
  753. }
  754. }
  755. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  756. ui->scrollAreaContents_Card->updateGeometry();
  757. }
  758. /* 计算并设置设置卡片大小 */
  759. void TransmitterSwitch::setCardSize()
  760. {
  761. /* 获取滚动条的区域 */
  762. int vsb = 0;
  763. if(ui->scrollArea->verticalScrollBar()->isVisible())
  764. {
  765. vsb = ui->scrollArea->verticalScrollBar()->width();
  766. }
  767. /* 去掉滚动条的宽度和阴影的宽度,再减去一个横向间距,和滚动条有些距离,不挨着太紧 */
  768. int saWidth = ui->scrollArea->width() - vsb - m_cardHorSpacing - 2;
  769. int saHeight = ui->scrollArea->height();
  770. int cardWidth = ( saWidth - (m_cardHorNumber - 1) * m_cardHorSpacing ) / m_cardHorNumber;
  771. int cardHeight = ( saHeight - (m_cardVerNumber - 1) * m_cardVerSpacing ) / m_cardVerNumber;
  772. /* 设置卡片大小 */
  773. PData.setCardSize(cardWidth, cardHeight);
  774. // LH_WRITE_LOG_DEBUG(QString("卡片大小:%1*%2").arg(cardWidth).arg(cardHeight));
  775. }
  776. /* 事件过滤器 */
  777. bool TransmitterSwitch::eventFilter(QObject *watched, QEvent *event)
  778. {
  779. if(watched == ui->label_Tip)
  780. {
  781. if(event->type() == QEvent::Enter)
  782. {
  783. m_tipText->show();
  784. return true;
  785. }else if(event->type() == QEvent::Leave)
  786. {
  787. m_tipText->hide();
  788. }
  789. }
  790. return QWidget::eventFilter(watched,event);
  791. }
  792. /* 窗口缩放事件 */
  793. void TransmitterSwitch::resizeEvent(QResizeEvent *event)
  794. {
  795. /* 设置提示文本的位置 */
  796. // if(m_tipText != nullptr)
  797. // {
  798. // QPoint pos = ui->label_Tip->mapTo(this, ui->label_Tip->pos());
  799. // m_tipText->move(pos.x() + 2, pos.y() + 2 );
  800. // }
  801. setCardSize();
  802. QWidget::resizeEvent(event);
  803. }
  804. /* 显示事件 */
  805. void TransmitterSwitch::showEvent(QShowEvent *event)
  806. {
  807. /* 设置提示文本的位置 */
  808. setCardSize();
  809. QWidget::showEvent(event);
  810. }