transmitterswitch.cpp 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994
  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 "savetotemplate.h"
  13. #include "importtemplate.h"
  14. #include "warning.h"
  15. #include "tipwidget.h"
  16. #include "UIStyleManager.h"
  17. #include "PlanData.h"
  18. #include "plancard.h"
  19. #include "flowlayout.h"
  20. #include "managerplan.h"
  21. #include "importtemplate.h"
  22. #include "copytoother.h"
  23. TransmitterSwitch::TransmitterSwitch(QWidget *parent) :
  24. QWidget(parent),
  25. ui(new Ui::TransmitterSwitch)
  26. {
  27. ui->setupUi(this);
  28. /* 创建一个布局 */
  29. QVBoxLayout* layout = new QVBoxLayout(parent);
  30. layout->setMargin(0);
  31. layout->setSpacing(0);
  32. parent->setLayout(layout);
  33. layout->addWidget(this);
  34. /* 创建一个流式布局,存放卡片 */
  35. m_flowlayout = new FlowLayout(ui->scrollAreaContents_Card, 0, m_cardHorSpacing, m_cardVerSpacing);
  36. // m_flowlayout->setContentsMargins(0, 0, 0, 0);
  37. // m_flowlayout->setSpacing(200);
  38. ui->scrollAreaContents_Card->setLayout(m_flowlayout);
  39. /* 创建WebAPI实例 */
  40. m_fromWebAPI = new FromWebAPI;
  41. /* 设置“默认计划”按钮可点击 */
  42. ui->pBtn_defaultPlan->setCheckable(true);
  43. ui->pBtn_allFrequency->setCheckable(true);
  44. connect(ui->pBtn_allFrequency, &QPushButton::clicked, this, &TransmitterSwitch::do_selectFrequencyBtn);
  45. /* 设置提示文本 */
  46. m_tipText = new QLabel(this);
  47. m_tipText->resize(936,56);
  48. m_tipText->setObjectName("label_TipText");
  49. m_tipText->setText(R"(按时刻执行模式:即以时刻点为单位进行执行,若某日既为普通日和特殊日,在某一时刻皆有执行动作,将优先执行特殊日在此时刻所计划的动作。
  50. 按天执行模式:即以天为单位进行执行,若某日既为普通日和特殊日,则当日一整天优先执行特殊日所计划的动作,普通日计划当日不再执行。)");
  51. m_tipText->hide();
  52. QPoint pos = ui->label_Tip->mapTo(this, ui->label_Tip->pos());
  53. m_tipText->move(pos.x() + 2, pos.y() + 2 ); /* 去掉阴影的宽度和高度 */
  54. ui->label_Tip->installEventFilter(this);
  55. /* 设置默认值 */
  56. ui->pBtn_defaultPlan->setChecked(true);
  57. ui->rBtn_moment->setChecked(true);
  58. /* 连接信号和槽 */
  59. connect(ui->pBtn_addPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnAddExecPlan);
  60. connect(ui->pBtn_importPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_importData);
  61. connect(ui->pBtn_exportPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_exportData);
  62. connect(ui->pBtn_editPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnModifyExecPlan);
  63. connect(ui->pBtn_refresh, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnRefresh);
  64. connect(ui->pBtn_defaultPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnIsOpenPlan);
  65. connect(ui->rBtn_moment, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnExecMode);
  66. connect(ui->rBtn_day, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnExecMode);
  67. connect(ui->pBtn_clearPlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnClearPlan);
  68. connect(ui->pBtn_deletePlan, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnClearPlan);
  69. connect(ui->pBtn_cloneToOther, &QPushButton::clicked, this, &TransmitterSwitch::do_pBtnCopyToOther);
  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_pBtnCopyToOther()
  484. {
  485. /* 先判断有没有选中的频率卡片 */
  486. auto pCard = PData.getCurrentPlanCard();
  487. if(pCard == nullptr)
  488. {
  489. TipWidget::display(TipWidget::OPERATOR_FAIL, "没有选中频率卡片", this);
  490. return;
  491. }
  492. /* 判断卡片有没有计划 */
  493. if(pCard->isPlanEmpty())
  494. {
  495. TipWidget::display(TipWidget::OPERATOR_FAIL, "当前频率没有计划", this);
  496. return;
  497. }
  498. std::shared_ptr<CopyToOther> cto = std::make_shared<CopyToOther>(this);
  499. cto->setQSSPath(EPUIStyle.getQSSPath());
  500. cto->setFrequencyList(pCard->getChannelInfo(), ChnContainer.getMapChannel());
  501. cto->exec();
  502. /* 判断有没有点击OK */
  503. if(!cto->isOk())
  504. {
  505. return;
  506. }
  507. /* 获取选中的频率列表 */
  508. auto list = cto->getSelectedFrequencyList();
  509. /* 获取当前频率的计划列表 */
  510. QList<OnePlanItemInfo> listPlan;
  511. pCard->getAllPlanInfo(listPlan);
  512. /* 遍历所有的频率 */
  513. bool isSuccess = true;
  514. for(auto& it : list)
  515. {
  516. auto pTmpCard = PData.findPlanCard(it.ChannelID);
  517. if(pTmpCard == nullptr)
  518. {
  519. LH_WRITE_ERROR(QString("没有找到频率ID为%1的卡片").arg(it.ChannelID));
  520. continue;
  521. }
  522. /* 设置计划列表 */
  523. pTmpCard->setPlanList(listPlan);
  524. /* 写入数据库 */
  525. if(!m_fromWebAPI->insertData(it.ChannelID, listPlan))
  526. {
  527. LH_WRITE_ERROR(QString("频率ID为%1的计划写入数据库失败").arg(it.ChannelID));
  528. TipWidget::display(TipWidget::OPERATOR_FAIL, QString("频率<%1>计划写入数据库失败").arg(it.ChannelName), this);
  529. isSuccess = false;
  530. }
  531. }
  532. if(isSuccess)
  533. {
  534. TipWidget::display(TipWidget::OPERATOR_OK, "复制计划成功", this);
  535. }
  536. }
  537. /* 导入数据 */
  538. void TransmitterSwitch::do_importData()
  539. {
  540. QMultiMap<int, OneTemplateInfo> tabList;
  541. /* 判断有没有选中卡片 */
  542. auto pCard = PData.getCurrentPlanCard();
  543. bool isSuccess = true;
  544. if(pCard == nullptr)
  545. {
  546. /* 没有选中卡片,获取全部的频率 */
  547. if(!m_fromWebAPI->getTemplateList(tabList))
  548. {
  549. isSuccess = false;
  550. }
  551. }else {
  552. /* 选中了卡片,只获取这个卡片的频率列表 */
  553. QList<OneTemplateInfo> list;
  554. if(m_fromWebAPI->getTemplateList(pCard->getChannelInfo().ChannelID, list))
  555. {
  556. for(auto it = list.begin(), end = list.end(); it != end; it++)
  557. {
  558. tabList.insert(it->channelInfo.ChannelID, *it);
  559. }
  560. }else {
  561. isSuccess = false;
  562. LH_WRITE_ERROR(QString("获取频率ID为%1的模版列表失败").arg(pCard->getChannelInfo().ChannelID));
  563. }
  564. }
  565. if(isSuccess == false)
  566. {
  567. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取模版列表失败", this);
  568. return;
  569. }
  570. /* 将模板列表添加频率信息 */
  571. for(auto it = tabList.begin(), end = tabList.end(); it != end; it++)
  572. {
  573. auto chnInfo = ChnContainer.getChannel(it->channelInfo.ChannelID);
  574. it->channelInfo = chnInfo;
  575. }
  576. std::shared_ptr<ImportTemplate> it = std::make_shared<ImportTemplate>();
  577. it->setQSSPath(EPUIStyle.getQSSPath());
  578. it->setTemplateList(tabList);
  579. it->exec();
  580. /* 判断有没有点击OK */
  581. if(!it->isOk())
  582. {
  583. return;
  584. }
  585. /* 获取选中的模版 */
  586. auto tmpList = it->getSelectedTemplateList();
  587. QMap<int, QList<OnePlanItemInfo>> mapPlan;
  588. m_fromWebAPI->getTemplateData(tmpList, mapPlan);
  589. /* 将所有的模板数据插入到卡片中 */
  590. for(auto begin = mapPlan.begin(), end = mapPlan.end(); begin != end; begin++)
  591. {
  592. auto pCard = PData.findPlanCard(begin.key());
  593. if(pCard == nullptr)
  594. {
  595. LH_WRITE_ERROR(QString("没有找到频率ID为%1的卡片").arg(begin.key()));
  596. continue;
  597. }
  598. /* 设置计划列表 */
  599. pCard->setPlanList(begin.value());
  600. }
  601. TipWidget::display(TipWidget::OPERATOR_OK, "导入模版成功", this);
  602. /* 调用回调函数 */
  603. if(m_trackCB != nullptr)
  604. {
  605. m_trackCB(3, g_mapTrack.value(3));
  606. }
  607. }
  608. /* 导出数据 */
  609. void TransmitterSwitch::do_exportData()
  610. {
  611. /* 先获取选中的卡片 */
  612. auto pCard = PData.getCurrentPlanCard();
  613. if(pCard == nullptr)
  614. {
  615. LH_WRITE_ERROR("没有选中频率卡片");
  616. TipWidget::display(TipWidget::OPERATOR_WARN, "未选中频率卡片", this);
  617. return;
  618. }
  619. /* 判断该卡片的计划列表是否为空 */
  620. if(pCard->isPlanEmpty())
  621. {
  622. TipWidget::display(TipWidget::OPERATOR_WARN, "当前频率没有计划", this);
  623. return;
  624. }
  625. int chnID = pCard->getChannelInfo().ChannelID;
  626. /* 获取所有的模板名称 */
  627. QList<OneTemplateInfo> list;
  628. if(!m_fromWebAPI->getTemplateList(chnID, list))
  629. {
  630. LH_WRITE_ERROR(QString("获取频率ID为%1的模版列表失败").arg(chnID));
  631. TipWidget::display(TipWidget::OPERATOR_FAIL, "获取模版列表失败", this);
  632. return;
  633. }
  634. /* 弹出导出页面 */
  635. std::shared_ptr<SaveToTemplate> stt = std::make_shared<SaveToTemplate>(this);
  636. stt->setQSS(EPUIStyle.getQSSPath());
  637. stt->setTemplateList(list);
  638. stt->exec();
  639. if(stt->isOk())
  640. {
  641. /* 获取一天的数据 */
  642. QList<OnePlanItemInfo> listTmp;
  643. pCard->getAllPlanInfo(listTmp);
  644. /* 保存到模板 */
  645. if(m_fromWebAPI->saveTemplate(stt->getTemplateName(), listTmp))
  646. {
  647. TipWidget::display(TipWidget::OPERATOR_OK, "保存模版成功", this);
  648. }else {
  649. TipWidget::display(TipWidget::OPERATOR_FAIL, "保存模版失败", this);
  650. }
  651. /* 调用回调函数 */
  652. if(m_trackCB != nullptr)
  653. {
  654. m_trackCB(3, g_mapTrack.value(3));
  655. }
  656. }
  657. }
  658. /* 删除一个模板 */
  659. void TransmitterSwitch::do_deleteTemplate(QString name)
  660. {
  661. m_fromWebAPI->deleteTemplate(name);
  662. }
  663. /* 保存计划到EQM数据库 */
  664. void TransmitterSwitch::do_pBtn_savePlan()
  665. {
  666. /* 跳出弹窗提示 */
  667. Warning w(this);
  668. w.setQSS(EPUIStyle.getQSSPath());
  669. w.setText("将计划保存到数据库?");
  670. w.exec();
  671. if(!w.isOk())
  672. {
  673. return;
  674. }
  675. saveExecPlanToEQM();
  676. }
  677. /* 从EQM数据库获取计划 */
  678. void TransmitterSwitch::do_pBtn_getPlan()
  679. {
  680. /* 跳出弹窗提示 */
  681. Warning w(this);
  682. w.setQSS(EPUIStyle.getQSSPath());
  683. w.setText("从数据库获取计划,将清空当前所有的计划,请注意保存当前计划!");
  684. w.exec();
  685. if(!w.isOk())
  686. {
  687. return;
  688. }
  689. getExecPlanFromEQM();
  690. }
  691. /* 切换亮色/暗色外观 */
  692. void TransmitterSwitch::do_setUIStyle()
  693. {
  694. this->setStyleSheet(EPUIStyle.StrQSS_TransmitterSwitch);
  695. /* 给所有的按钮设置样式 */
  696. ui->pBtn_allFrequency->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  697. // LH_WRITE_LOG(QString("频率按钮设置样式:%1").arg(EPUIStyle.StrQSS_PBtnFrequency));
  698. }
  699. /* 选择了一个频率按钮,取消其他的选择 */
  700. void TransmitterSwitch::do_selectFrequencyBtn()
  701. {
  702. /* 获取信号发送者 */
  703. auto btn = qobject_cast<QPushButton*>(sender());
  704. if(btn == nullptr)
  705. {
  706. return;
  707. }
  708. /* 取消其他按钮的选择 */
  709. for(auto& it : m_listFrequencyBtn)
  710. {
  711. if(it != btn)
  712. {
  713. it->setChecked(false);
  714. }
  715. }
  716. if(btn != ui->pBtn_allFrequency)
  717. {
  718. ui->pBtn_allFrequency->setChecked(false);
  719. /* 设置当前按钮的选择状态 */
  720. btn->setChecked(true);
  721. /* 设置该按钮对应的卡片状态 */
  722. auto pCard = static_cast<PBtnUserData2*>(btn->userData(m_userData_Btn))->getCard();
  723. pCard->clickedCard();
  724. }else {
  725. ui->pBtn_allFrequency->setChecked(true);
  726. /* 取消所有的卡片选择状态 */
  727. PData.clearAllSelectedCard();
  728. }
  729. /* 显示当前按钮对应的卡片,隐藏其他卡片 */
  730. showOneCard(btn);
  731. }
  732. /* 添加一个频率,包括左侧按钮和右侧卡片 */
  733. void TransmitterSwitch::createOneCard(const ChannelInfo& chnInfo)
  734. {
  735. /* 创建按钮 */
  736. QPushButton* pBtn = new QPushButton(this);
  737. pBtn->setObjectName(chnInfo.ChannelName);
  738. pBtn->setText(chnInfo.ChannelName);
  739. pBtn->setCheckable(true);
  740. pBtn->setMinimumHeight(40);
  741. PBtnUserData2* userData = new PBtnUserData2();
  742. userData->setChannelInfo(chnInfo);
  743. pBtn->setUserData(m_userData_Btn, userData);
  744. /* 设置按钮的样式表 */
  745. pBtn->setStyleSheet(EPUIStyle.StrQSS_PBtnFrequency);
  746. /* 连接信号和槽 */
  747. connect(pBtn, &QPushButton::clicked, this, &TransmitterSwitch::do_selectFrequencyBtn);
  748. m_listFrequencyBtn.push_back(pBtn);
  749. auto vLayout = qobject_cast<QVBoxLayout*>(ui->widget_frequency->layout());
  750. /* 减1是去掉最下面的弹簧 */
  751. vLayout->insertWidget(vLayout->count() - 1, pBtn);
  752. /* 创建卡片 */
  753. PlanCard* pCard = PData.createOneCard(chnInfo);
  754. m_flowlayout->addWidget(pCard);
  755. userData->setCard(pCard); /* 设置按钮的卡片指针 */
  756. /* 排序 */
  757. }
  758. /* 删除一个频率 */
  759. void TransmitterSwitch::deleteOneCard(int channelID)
  760. {
  761. /* 删除按钮 */
  762. for(auto it = m_listFrequencyBtn.begin(); it != m_listFrequencyBtn.end(); ++it)
  763. {
  764. auto userData = static_cast<PBtnUserData2*>((*it)->userData(m_userData_Btn));
  765. if(userData != nullptr && userData->getChannelInfo().ChannelID == channelID)
  766. {
  767. delete *it;
  768. m_listFrequencyBtn.erase(it);
  769. break;
  770. }
  771. }
  772. /* 删除卡片 */
  773. PData.deleteOneCard(channelID);
  774. }
  775. /* 创建所有频率卡片 */
  776. void TransmitterSwitch::createAllCard()
  777. {
  778. for(const auto& it : ChnContainer.getMapChannel())
  779. {
  780. /* 创建一个按钮和卡片 */
  781. createOneCard(it);
  782. }
  783. }
  784. /* 显示某个卡片,隐藏其他卡片 */
  785. void TransmitterSwitch::showOneCard(QPushButton *btn)
  786. {
  787. /* 判断是否是显示全部卡片的按钮 */
  788. if(btn == ui->pBtn_allFrequency)
  789. {
  790. /* 设置卡片间的横向间距 */
  791. m_flowlayout->setHorizontalSpacing(m_cardHorSpacing);
  792. /* 显示全部卡片 */
  793. for(auto& it : m_listFrequencyBtn)
  794. {
  795. auto ud = it->userData(m_userData_Btn);
  796. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  797. if(userData != nullptr)
  798. {
  799. auto pCard = userData->getCard();
  800. if(pCard != nullptr)
  801. {
  802. pCard->show();
  803. }
  804. }
  805. }
  806. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  807. ui->scrollAreaContents_Card->updateGeometry();
  808. return;
  809. }
  810. /* 设置卡片间的横向间距 */
  811. m_flowlayout->setHorizontalSpacing(0);
  812. /* 不是显示全部的按钮,隐藏所有卡片 */
  813. for(auto& it : m_listFrequencyBtn)
  814. {
  815. auto ud = it->userData(m_userData_Btn);
  816. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  817. if(userData != nullptr)
  818. {
  819. auto pCard = userData->getCard();
  820. if(pCard != nullptr)
  821. {
  822. pCard->hide();
  823. }
  824. }
  825. }
  826. /* 显示当前卡片 */
  827. auto ud = btn->userData(m_userData_Btn);
  828. PBtnUserData2* userData = static_cast<PBtnUserData2*>(ud);
  829. if(userData != nullptr)
  830. {
  831. auto pCard = userData->getCard();
  832. if(pCard != nullptr)
  833. {
  834. pCard->show();
  835. }
  836. }
  837. /* 刷新布局,刷新了才会让FlowLayout重新布局 */
  838. ui->scrollAreaContents_Card->updateGeometry();
  839. }
  840. /* 计算并设置设置卡片大小 */
  841. void TransmitterSwitch::setCardSize()
  842. {
  843. /* 获取滚动条的区域 */
  844. int vsb = 0;
  845. if(ui->scrollArea->verticalScrollBar()->isVisible())
  846. {
  847. vsb = ui->scrollArea->verticalScrollBar()->width();
  848. }
  849. /* 去掉滚动条的宽度和阴影的宽度,再减去一个横向间距,和滚动条有些距离,不挨着太紧 */
  850. int saWidth = ui->scrollArea->width() - vsb - m_cardHorSpacing - 2;
  851. int saHeight = ui->scrollArea->height();
  852. int cardWidth = ( saWidth - (m_cardHorNumber - 1) * m_cardHorSpacing ) / m_cardHorNumber;
  853. int cardHeight = ( saHeight - (m_cardVerNumber - 1) * m_cardVerSpacing ) / m_cardVerNumber;
  854. /* 设置卡片大小 */
  855. PData.setCardSize(cardWidth, cardHeight);
  856. // LH_WRITE_LOG_DEBUG(QString("卡片大小:%1*%2").arg(cardWidth).arg(cardHeight));
  857. }
  858. /* 事件过滤器 */
  859. bool TransmitterSwitch::eventFilter(QObject *watched, QEvent *event)
  860. {
  861. if(watched == ui->label_Tip)
  862. {
  863. if(event->type() == QEvent::Enter)
  864. {
  865. m_tipText->show();
  866. return true;
  867. }else if(event->type() == QEvent::Leave)
  868. {
  869. m_tipText->hide();
  870. }
  871. }
  872. return QWidget::eventFilter(watched,event);
  873. }
  874. /* 窗口缩放事件 */
  875. void TransmitterSwitch::resizeEvent(QResizeEvent *event)
  876. {
  877. /* 设置提示文本的位置 */
  878. // if(m_tipText != nullptr)
  879. // {
  880. // QPoint pos = ui->label_Tip->mapTo(this, ui->label_Tip->pos());
  881. // m_tipText->move(pos.x() + 2, pos.y() + 2 );
  882. // }
  883. setCardSize();
  884. QWidget::resizeEvent(event);
  885. }
  886. /* 显示事件 */
  887. void TransmitterSwitch::showEvent(QShowEvent *event)
  888. {
  889. /* 设置提示文本的位置 */
  890. setCardSize();
  891. QWidget::showEvent(event);
  892. }