ITS00GEOF.cpp 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583
  1. //---------------------------------------------------------------------------
  2. #include "FrmVmsCamF.h"
  3. #include <vcl.h>
  4. #include <Mshtml.h>
  5. #include "ITSSkinF.h"
  6. #include "ITSUtilF.h"
  7. #include "XiMapUtilF.h"
  8. #include "CDSTrafficGradeF.h"
  9. #include "CDSFacilityF.h"
  10. #include "CDSIncidentF.h"
  11. #pragma hdrstop
  12. #include "ITS00GEOF.h"
  13. #include "ITS00G0MF.h"
  14. #include "FrmCctvImgF.h"
  15. #include "FrmCctvCamF.h"
  16. #include "FrmVmsMsgF.h"
  17. #include "FrmLinkInfoF.h"
  18. #include "FrmGisSearchF.h"
  19. #include "FrmMainF.h"
  20. //---------------------------------------------------------------------------
  21. #pragma package(smart_init)
  22. #pragma link "cxCheckBox"
  23. #pragma link "cxContainer"
  24. #pragma link "cxControls"
  25. #pragma link "cxEdit"
  26. #pragma link "cxGraphics"
  27. #pragma link "cxGroupBox"
  28. #pragma link "cxLabel"
  29. #pragma link "cxLookAndFeelPainters"
  30. #pragma link "cxLookAndFeels"
  31. #pragma link "cxMaskEdit"
  32. #pragma link "cxProgressBar"
  33. #pragma link "cxSpinEdit"
  34. #pragma link "cxTextEdit"
  35. #pragma link "dxGDIPlusClasses"
  36. #pragma link "dxSkinBlack"
  37. #pragma link "dxSkinBlue"
  38. #pragma link "dxSkinCaramel"
  39. #pragma link "dxSkinCoffee"
  40. #pragma link "dxSkinDarkRoom"
  41. #pragma link "dxSkinDarkSide"
  42. #pragma link "dxSkinFoggy"
  43. #pragma link "dxSkinGlassOceans"
  44. #pragma link "dxSkiniMaginary"
  45. #pragma link "dxSkinLilian"
  46. #pragma link "dxSkinLiquidSky"
  47. #pragma link "dxSkinLondonLiquidSky"
  48. #pragma link "dxSkinMcSkin"
  49. #pragma link "dxSkinMoneyTwins"
  50. #pragma link "dxSkinOffice2007Black"
  51. #pragma link "dxSkinOffice2007Blue"
  52. #pragma link "dxSkinOffice2007Green"
  53. #pragma link "dxSkinOffice2007Pink"
  54. #pragma link "dxSkinOffice2007Silver"
  55. #pragma link "dxSkinOffice2010Black"
  56. #pragma link "dxSkinOffice2010Blue"
  57. #pragma link "dxSkinOffice2010Silver"
  58. #pragma link "dxSkinsCore"
  59. #pragma link "dxSkinSeven"
  60. #pragma link "dxSkinSharp"
  61. #pragma link "dxSkinSilver"
  62. #pragma link "dxSkinStardust"
  63. #pragma link "GMClasses"
  64. #pragma link "GMMap"
  65. #pragma link "GMMapVCL"
  66. #pragma link "GMLinkedComponents"
  67. #pragma link "GMRectangle"
  68. #pragma link "GMRectangleVCL"
  69. #pragma link "GMGeoCode"
  70. #pragma resource "*.dfm"
  71. //---------------------------------------------------------------------------
  72. TITS00GEO *ITS00GEO = NULL;
  73. //---------------------------------------------------------------------------
  74. __fastcall TITS00GEO::TITS00GEO(TComponent* Owner, TForm *ParentForm)
  75. : TForm(Owner)
  76. {
  77. ::CoInitialize(NULL);
  78. ::OleInitialize(NULL);
  79. ITSSkin_Load(this);
  80. LoadLocalSkin();
  81. FRectangle = false;
  82. FRectangleIdx = 0;
  83. panRemark->Visible = false;
  84. //마우스 제어 플래그 초기화
  85. m_bMouseDown = false;
  86. m_bMoveCenter = false;
  87. m_bCalcMode = false;
  88. m_bCalcCont = false;
  89. m_ptDown.x = m_ptDown.y = 0;
  90. LoadConfig();
  91. }
  92. //---------------------------------------------------------------------------
  93. /*
  94. * 환경설정정보 로딩
  95. *
  96. * arguments
  97. *
  98. * return
  99. * void
  100. */
  101. void __fastcall TITS00GEO::LoadConfig()
  102. {
  103. #if 0
  104. TIniFile *pIniFile = NULL;
  105. String sIniFile = ChangeFileExt(ExtractFileName(Application->ExeName), ".ini");
  106. String sCfgFile = ExtractFilePath(Application->ExeName) + "\\cfg\\" + sIniFile;
  107. try
  108. {
  109. try
  110. {
  111. pIniFile = new TIniFile(sCfgFile);
  112. // 표출이미지 로딩
  113. //LoadImageFile(pIniFile->ReadString("IMAGE", "CENTER", ""), ImgOffice);
  114. LoadImageFile(pIniFile->ReadString("IMAGE", "RSE_N", ""), ImgRseN);
  115. LoadImageFile(pIniFile->ReadString("IMAGE", "RSE_C", ""), ImgRseC);
  116. LoadImageFile(pIniFile->ReadString("IMAGE", "CCTV_N", ""), ImgCctvN);
  117. LoadImageFile(pIniFile->ReadString("IMAGE", "CCTV_C", ""), ImgCctvC);
  118. LoadImageFile(pIniFile->ReadString("IMAGE", "CCTV_M", ""), ImgCctvM);
  119. LoadImageFile(pIniFile->ReadString("IMAGE", "VMS_N", ""), ImgVmsN);
  120. LoadImageFile(pIniFile->ReadString("IMAGE", "VMS_C", ""), ImgVmsC);
  121. LoadImageFile(pIniFile->ReadString("IMAGE", "VMS_M", ""), ImgVmsM);
  122. LoadImageFile(pIniFile->ReadString("IMAGE", "INC_01", ""), ImgInc01);
  123. LoadImageFile(pIniFile->ReadString("IMAGE", "INC_02", ""), ImgInc02);
  124. LoadImageFile(pIniFile->ReadString("IMAGE", "INC_03", ""), ImgInc03);
  125. LoadImageFile(pIniFile->ReadString("IMAGE", "INC_04", ""), ImgInc04);
  126. }
  127. __finally
  128. {
  129. if (pIniFile) delete pIniFile;
  130. pIniFile = NULL;
  131. }
  132. }
  133. catch(...)
  134. {
  135. }
  136. #endif
  137. }
  138. //---------------------------------------------------------------------------
  139. void __fastcall TITS00GEO::LoadImageFile(String sImgFile, TImage *pImage)
  140. {
  141. if (sImgFile.Trim() == "") return;
  142. try
  143. {
  144. ImgTemp->Picture->Assign(NULL);
  145. ImgTemp->Picture->LoadFromFile(sImgFile);
  146. pImage->Picture->Assign(pImage->Picture);
  147. ImgTemp->Picture->Assign(NULL);
  148. }
  149. catch(...)
  150. {
  151. }
  152. }
  153. //---------------------------------------------------------------------------
  154. /*
  155. * 메인화면 FormDestroy시 호출되는 Method
  156. * Form의 자원이 해제 되기 이전에 반드시 이 Method가 호출된다.
  157. * 그러므로 최종적으로 자원을 해제 하고자 한다면 이곳에서 처리하는게 확실함.
  158. * parameter
  159. * Sender : Event를 보낸 객체
  160. * return
  161. * None
  162. */
  163. void __fastcall TITS00GEO::FormDestroy(TObject *Sender)
  164. {
  165. try
  166. {
  167. }
  168. catch (...)
  169. {
  170. }
  171. ::OleUninitialize();
  172. ::CoUninitialize();
  173. }
  174. //---------------------------------------------------------------------------
  175. /*
  176. * form을 보여줄때 호출되는 event 메서드이다.
  177. * arguments
  178. * Sender : event handler 객체
  179. * return
  180. * void
  181. */
  182. void __fastcall TITS00GEO::FormShow(TObject *Sender)
  183. {
  184. Refresh();
  185. FormInit();
  186. Application->ProcessMessages();
  187. TmrShow->Enabled = true;
  188. }
  189. //---------------------------------------------------------------------------
  190. /*
  191. * 닫기버튼 이나 x버튼 클릭시 공통으로 처리하는 로직이들어간다..
  192. * Form과 DataModule class를 delete시킨다.
  193. * arguments
  194. *
  195. * return
  196. * void
  197. */
  198. void __fastcall TITS00GEO::CommClose()
  199. {
  200. //ITS00GEO = NULL;
  201. //::CoUninitialize();
  202. }
  203. //---------------------------------------------------------------------------
  204. /*
  205. * Form의 초기화 작업을 수행한다.
  206. * arguments
  207. * void
  208. * return
  209. * void
  210. */
  211. bool __fastcall TITS00GEO::FormInit()
  212. {
  213. //memset((char*)&m_PrevExt, 0x00, sizeof(m_PrevExt));
  214. memset((char*)&m_ExtQ, 0x00, sizeof(m_ExtQ));
  215. m_ExtQ.bExtent = true;
  216. m_ExtQ.userIdx = 0;
  217. m_ExtQ.currIdx = 0;
  218. return true;
  219. }
  220. //---------------------------------------------------------------------------
  221. /*
  222. * Form의 Skin 초기화 작업을 수행한다.
  223. * arguments
  224. * void
  225. * return
  226. * void
  227. */
  228. void __fastcall TITS00GEO::LoadLocalSkin()
  229. {
  230. //PnlMenu->ParentColor = false;
  231. //PnlMenu->Color = 0x00FF9D62;
  232. PnlTrf00->ParentColor = false;
  233. PnlTrf00->Color = clSilver;
  234. PnlTrf01->ParentColor = false;
  235. PnlTrf01->Color = clLime;
  236. PnlTrf02->ParentColor = false;
  237. PnlTrf02->Color = clYellow;
  238. PnlTrf03->ParentColor = false;
  239. PnlTrf03->Color = clRed;
  240. /*
  241. * GIS Command button skin
  242. */
  243. TImage *pImgZoomIn_n;
  244. TImage *pImgZoomIn_c;
  245. TImage *pImgCenter_n;
  246. TImage *pImgCenter_c;
  247. TImage *pImgPrev_c;
  248. TImage *pImgPrev_n;
  249. TImage *pImgSel_n;
  250. TImage *pImgSel_c;
  251. TImage *pImgDist_n;
  252. TImage *pImgCircle_c;
  253. TImage *pImgCircle_n;
  254. TImage *pImgDist_c;
  255. TImage *pImgStnd_n;
  256. TImage *pImgSave_c;
  257. TImage *pImgSave_n;
  258. TImage *pImgStnd_c;
  259. TImage *pImgZoomOut_n;
  260. TImage *pImgZoomOut_c;
  261. TImage *pImgPan_c;
  262. TImage *pImgPan_n;
  263. TImage *pImgNext_n;
  264. TImage *pImgNext_c;
  265. TImage *pImgBoundary_c;
  266. TImage *pImgBoundary_n;
  267. TImage *pImgSquare_n;
  268. TImage *pImgSquare_c;
  269. TImage *pImgFull_c;
  270. TImage *pImgFull_n;
  271. TImage *pImgRefresh_n;
  272. TImage *pImgRefresh_c;
  273. TImage *pImgPrint_c;
  274. TImage *pImgPrint_n;
  275. int nSkin = 1;
  276. switch (nSkin)
  277. {
  278. case 10:
  279. pImgZoomIn_n = ImgZoomIn_c;
  280. pImgZoomIn_c = ImgZoomIn_n;
  281. pImgZoomOut_n = ImgZoomOut_c;
  282. pImgZoomOut_c = ImgZoomOut_n;
  283. pImgCenter_n = ImgCenter_c;
  284. pImgCenter_c = ImgCenter_n;
  285. pImgPan_c = ImgPan_n;
  286. pImgPan_n = ImgPan_c;
  287. pImgPrev_c = ImgPrev_n;
  288. pImgPrev_n = ImgPrev_c;
  289. pImgNext_n = ImgNext_c;
  290. pImgNext_c = ImgNext_n;
  291. pImgBoundary_c = ImgBoundary_n;
  292. pImgBoundary_n = ImgBoundary_c;
  293. pImgSel_n = ImgSel_c;
  294. pImgSel_c = ImgSel_n;
  295. pImgDist_n = ImgDist_c;
  296. pImgDist_c = ImgDist_n;
  297. pImgSquare_n = ImgSquare_c;
  298. pImgSquare_c = ImgSquare_n;
  299. pImgCircle_c = ImgCircle_n;
  300. pImgCircle_n = ImgCircle_c;
  301. pImgFull_c = ImgFull_n;
  302. pImgFull_n = ImgFull_c;
  303. pImgStnd_n = ImgStnd_c;
  304. pImgStnd_c = ImgStnd_n;
  305. pImgRefresh_n = ImgRefresh_c;
  306. pImgRefresh_c = ImgRefresh_n;
  307. pImgPrint_c = ImgPrint_n;
  308. pImgPrint_n = ImgPrint_c;
  309. pImgSave_c = ImgSave_n;
  310. pImgSave_n = ImgSave_c;
  311. break;
  312. case 1: case 2: case 3: case 0:
  313. case 4: case 5: default:
  314. pImgZoomIn_n = ImgZoomIn_n;
  315. pImgZoomIn_c = ImgZoomIn_c;
  316. pImgZoomOut_n = ImgZoomOut_n;
  317. pImgZoomOut_c = ImgZoomOut_c;
  318. pImgCenter_n = ImgCenter_n;
  319. pImgCenter_c = ImgCenter_c;
  320. pImgPan_c = ImgPan_c;
  321. pImgPan_n = ImgPan_n;
  322. pImgPrev_c = ImgPrev_c;
  323. pImgPrev_n = ImgPrev_n;
  324. pImgNext_n = ImgNext_n;
  325. pImgNext_c = ImgNext_c;
  326. pImgBoundary_c = ImgBoundary_c;
  327. pImgBoundary_n = ImgBoundary_n;
  328. pImgSel_n = ImgSel_n;
  329. pImgSel_c = ImgSel_c;
  330. pImgDist_n = ImgDist_n;
  331. pImgDist_c = ImgDist_c;
  332. pImgSquare_n = ImgSquare_n;
  333. pImgSquare_c = ImgSquare_c;
  334. pImgCircle_c = ImgCircle_c;
  335. pImgCircle_n = ImgCircle_n;
  336. pImgFull_c = ImgFull_c;
  337. pImgFull_n = ImgFull_n;
  338. pImgStnd_n = ImgStnd_n;
  339. pImgStnd_c = ImgStnd_c;
  340. pImgRefresh_n = ImgRefresh_n;
  341. pImgRefresh_c = ImgRefresh_c;
  342. pImgPrint_c = ImgPrint_c;
  343. pImgPrint_n = ImgPrint_n;
  344. pImgSave_c = ImgSave_c;
  345. pImgSave_n = ImgSave_n;
  346. break;
  347. }
  348. try
  349. {
  350. ImgZoomIn->NormalPicture->Assign(pImgZoomIn_n->Picture);
  351. ImgZoomIn->Picture->Assign(pImgZoomIn_n->Picture);
  352. ImgZoomIn->TogglePicture->Assign(pImgZoomIn_c->Picture);
  353. ImgZoomIn->ClickedPicture->Assign(pImgZoomIn_n->Picture);
  354. ImgZoomOut->NormalPicture->Assign(pImgZoomOut_n->Picture);
  355. ImgZoomOut->Picture->Assign(pImgZoomOut_n->Picture);
  356. ImgZoomOut->TogglePicture->Assign(pImgZoomOut_c->Picture);
  357. ImgZoomOut->ClickedPicture->Assign(pImgZoomOut_n->Picture);
  358. ImgCenter->NormalPicture->Assign(pImgCenter_n->Picture);
  359. ImgCenter->Picture->Assign(pImgCenter_n->Picture);
  360. ImgCenter->TogglePicture->Assign(pImgCenter_c->Picture);
  361. ImgCenter->ClickedPicture->Assign(pImgCenter_n->Picture);
  362. ImgPan->NormalPicture->Assign(pImgPan_n->Picture);
  363. ImgPan->Picture->Assign(pImgPan_n->Picture);
  364. ImgPan->TogglePicture->Assign(pImgPan_c->Picture);
  365. ImgPan->ClickedPicture->Assign(pImgPan_n->Picture);
  366. ImgPrev->NormalPicture->Assign(pImgPrev_n->Picture);
  367. ImgPrev->Picture->Assign(pImgPrev_n->Picture);
  368. ImgPrev->TogglePicture->Assign(pImgPrev_c->Picture);
  369. ImgPrev->ClickedPicture->Assign(pImgPrev_n->Picture);
  370. ImgNext->NormalPicture->Assign(pImgNext_n->Picture);
  371. ImgNext->Picture->Assign(pImgNext_n->Picture);
  372. ImgNext->TogglePicture->Assign(pImgNext_c->Picture);
  373. ImgNext->ClickedPicture->Assign(pImgNext_n->Picture);
  374. ImgPrev->Cursor = crHandPoint;
  375. ImgNext->Cursor = crHandPoint;
  376. ImgBoundary->NormalPicture->Assign(pImgBoundary_n->Picture);
  377. ImgBoundary->Picture->Assign(pImgBoundary_n->Picture);
  378. ImgBoundary->TogglePicture->Assign(pImgBoundary_c->Picture);
  379. ImgBoundary->ClickedPicture->Assign(pImgBoundary_n->Picture);
  380. ImgSel->NormalPicture->Assign(pImgSel_n->Picture);
  381. ImgSel->Picture->Assign(pImgSel_n->Picture);
  382. ImgSel->TogglePicture->Assign(pImgSel_c->Picture);
  383. ImgSel->ClickedPicture->Assign(pImgSel_n->Picture);
  384. ImgDist->NormalPicture->Assign(pImgDist_n->Picture);
  385. ImgDist->Picture->Assign(pImgDist_n->Picture);
  386. ImgDist->TogglePicture->Assign(pImgDist_c->Picture);
  387. ImgDist->ClickedPicture->Assign(pImgDist_n->Picture);
  388. ImgSquare->NormalPicture->Assign(pImgSquare_n->Picture);
  389. ImgSquare->Picture->Assign(pImgSquare_n->Picture);
  390. ImgSquare->TogglePicture->Assign(pImgSquare_c->Picture);
  391. ImgSquare->ClickedPicture->Assign(pImgSquare_n->Picture);
  392. ImgCircle->NormalPicture->Assign(pImgCircle_n->Picture);
  393. ImgCircle->Picture->Assign(pImgCircle_n->Picture);
  394. ImgCircle->TogglePicture->Assign(pImgCircle_c->Picture);
  395. ImgCircle->ClickedPicture->Assign(pImgCircle_n->Picture);
  396. ImgFull->NormalPicture->Assign(pImgFull_n->Picture);
  397. ImgFull->Picture->Assign(pImgFull_n->Picture);
  398. ImgFull->TogglePicture->Assign(pImgFull_c->Picture);
  399. ImgFull->ClickedPicture->Assign(pImgFull_n->Picture);
  400. ImgStnd->NormalPicture->Assign(pImgStnd_n->Picture);
  401. ImgStnd->Picture->Assign(pImgStnd_n->Picture);
  402. ImgStnd->TogglePicture->Assign(pImgStnd_c->Picture);
  403. ImgStnd->ClickedPicture->Assign(pImgStnd_n->Picture);
  404. ImgRefresh->NormalPicture->Assign(pImgRefresh_n->Picture);
  405. ImgRefresh->Picture->Assign(pImgRefresh_n->Picture);
  406. ImgRefresh->TogglePicture->Assign(pImgRefresh_c->Picture);
  407. ImgRefresh->ClickedPicture->Assign(pImgRefresh_n->Picture);
  408. ImgPrint->NormalPicture->Assign(pImgPrint_n->Picture);
  409. ImgPrint->Picture->Assign(pImgPrint_n->Picture);
  410. ImgPrint->TogglePicture->Assign(pImgPrint_c->Picture);
  411. ImgPrint->ClickedPicture->Assign(pImgPrint_n->Picture);
  412. ImgSave->NormalPicture->Assign(pImgSave_n->Picture);
  413. ImgSave->Picture->Assign(pImgSave_n->Picture);
  414. ImgSave->TogglePicture->Assign(pImgSave_c->Picture);
  415. ImgSave->ClickedPicture->Assign(pImgSave_n->Picture);
  416. }
  417. catch(...)
  418. {
  419. }
  420. }
  421. //---------------------------------------------------------------------------
  422. void __fastcall TITS00GEO::TmrShowTimer(TObject *Sender)
  423. {
  424. TmrShow->Enabled = false;
  425. Application->ProcessMessages();
  426. LoadGisMap();
  427. Application->ProcessMessages();
  428. UpdateFacilityStatus();
  429. Application->ProcessMessages();
  430. UpdateIncidentStatus();
  431. }
  432. //---------------------------------------------------------------------------
  433. /*
  434. * 지도데이터 로드 및 프로그램 초기화 작업 수행
  435. * arguments
  436. *
  437. * return
  438. *
  439. */
  440. void __fastcall TITS00GEO::LoadGisMap()
  441. {
  442. try
  443. {
  444. try
  445. {
  446. // 지도로딩 상태바 표출
  447. GMMap1->Active = true;
  448. FVehRect = GMVehRect->Items[0];
  449. FVehBounds = new TLatLngBounds(0, 0, 0, 0);
  450. PnlProgress->Left = (this->Width - PnlProgress->Width) / 2;
  451. PnlProgress->Top = (this->Height - PnlProgress->Height) / 2;
  452. PnlProgress->Top -= 50;
  453. PnlProgress->Visible = true;
  454. PbLoadMap->Properties->Text = "전자지도 표출색상 정보 로딩 중...";
  455. Application->ProcessMessages();
  456. PbLoadMap->Position = 50;
  457. PbLoadMap->Position = 100;
  458. PbLoadMap->Properties->Text = "전자지도 로딩 중...";
  459. Application->ProcessMessages();
  460. m_nMapLevel = GMMap1->RequiredProp->Zoom;
  461. LblZoomLevel->Caption = String(GMMap1->RequiredProp->Zoom);
  462. //xsrvrMap->SetFullExtent(DDRect(g_GisInfo.dRightBottomX, g_GisInfo.dLeftTopX, g_GisInfo.dRightBottomY, g_GisInfo.dLeftTopY));
  463. // start client
  464. pmuControlGisClick((TObject*)pmuMove); // 전자지도 마우스이벤트를 이동으로 설정
  465. }
  466. catch (...)
  467. {
  468. }
  469. }
  470. __finally
  471. {
  472. PnlProgress->Visible = false;
  473. }
  474. }
  475. //---------------------------------------------------------------------------
  476. void __fastcall TITS00GEO::SetGisTrafficColor()
  477. {
  478. }
  479. //---------------------------------------------------------------------------
  480. void __fastcall TITS00GEO::GisMenuCheckClear()
  481. {
  482. pmuZoomIn->Checked = false;
  483. pmuZoomOut->Checked = false;
  484. pmuMove->Checked = false;
  485. pmuIconSel->Checked = false;
  486. pmuCalLen->Checked = false;
  487. pmuCalArea->Checked = false;
  488. pmuRadius->Checked = false;
  489. pmuMoveCenter->Checked = false;
  490. pmuGisDefault->Checked = false;
  491. }
  492. //---------------------------------------------------------------------------
  493. void __fastcall TITS00GEO::pmuGisCalcClick(TObject *Sender)
  494. {
  495. TMenuItem *pMenu = (TMenuItem *)Sender;
  496. //SetMapOperation((TXiMapOperation)pMenu->Tag);
  497. }
  498. //---------------------------------------------------------------------------
  499. void __fastcall TITS00GEO::pmuControlGisClick(TObject *Sender)
  500. {
  501. TMenuItem *pMenu = (TMenuItem*)Sender;
  502. //SetMapOperation((TXiMapOperation)pMenu->Tag);
  503. }
  504. //---------------------------------------------------------------------------
  505. #if 0
  506. /*
  507. * 지도제어 설정
  508. * arguments
  509. *
  510. * return
  511. *
  512. */
  513. void __fastcall TITS00GEO::SetMapOperation(TXiMapOperation nMapOper)
  514. {
  515. GisMenuCheckClear();
  516. m_bMoveCenter = false;
  517. m_bCalcMode = false;
  518. m_bCalcCont = false;
  519. }
  520. //---------------------------------------------------------------------------
  521. #endif
  522. void __fastcall TITS00GEO::MnuLayerSettingClick(TObject *Sender)
  523. {
  524. Application->ProcessMessages();
  525. ShowLayerEditForm();
  526. }
  527. //---------------------------------------------------------------------------
  528. /*
  529. * 레이어편집 설정창 표출
  530. * arguments
  531. *
  532. * return
  533. * void
  534. */
  535. void __fastcall TITS00GEO::ShowLayerEditForm()
  536. {
  537. }
  538. //---------------------------------------------------------------------------
  539. #if 0
  540. /*
  541. * 전자지도의 영역을 설정한다.
  542. * arguments
  543. * double : left 영역
  544. * double : top 영역
  545. * double : right 영역
  546. * double : bottom 영역
  547. * return
  548. * void
  549. */
  550. void __fastcall TITS00GEO::SetExtent(TDDRect &curRc)
  551. {
  552. }
  553. //---------------------------------------------------------------------------
  554. #endif
  555. #if 0
  556. /*
  557. * 지도 영역 이동 함수. 현재 영역을 영역이동 큐에 추가한다.
  558. * 다음 버튼을 비활성 시킨다.
  559. * arguments
  560. * return
  561. * void
  562. */
  563. bool __fastcall TITS00GEO::AddExtentQ(TDDRect &curRc)
  564. {
  565. #if 0
  566. TDDRect *pExt = &m_ExtQ.extent[m_ExtQ.userIdx];
  567. memcpy((char*)pExt, (char*)&curRc, sizeof(curRc));
  568. if (m_PrevExt.MinX == pExt->MinX &&
  569. m_PrevExt.MinY == pExt->MinY &&
  570. m_PrevExt.MaxX == pExt->MaxX &&
  571. m_PrevExt.MaxY == pExt->MaxY)
  572. {
  573. return false;
  574. }
  575. memcpy((char*)&m_PrevExt, pExt, sizeof(m_PrevExt));
  576. if (m_ExtQ.userIdx >= D_EXT_QUEUE_SIZE)
  577. {
  578. m_ExtQ.userIdx = D_EXT_QUEUE_SIZE;
  579. memcpy((char *)&m_ExtQ.extent[0], (char *)&m_ExtQ.extent[1], sizeof(TDDRect)*D_EXT_QUEUE_SIZE);
  580. }
  581. else
  582. {
  583. m_ExtQ.userIdx++;
  584. }
  585. m_ExtQ.currIdx = m_ExtQ.userIdx-1;
  586. #endif
  587. return true;
  588. }
  589. //---------------------------------------------------------------------------
  590. #endif
  591. /*
  592. * 지도 영역 이동 함수. 이전 영역으로 이동
  593. * 이동 범위에 따라 이전/다음 버튼을 활성/비활성 시킨다.
  594. * arguments
  595. * return
  596. * void
  597. */
  598. bool __fastcall TITS00GEO::PrevExtentQ()
  599. {
  600. #if 0
  601. m_ExtQ.bExtent = false;
  602. if (m_ExtQ.currIdx <= 0)
  603. {
  604. m_ExtQ.currIdx = 0;
  605. return false;
  606. }
  607. m_ExtQ.currIdx--;
  608. TDDRect *pExt = &m_ExtQ.extent[m_ExtQ.currIdx];
  609. SetExtent(*pExt);
  610. #endif
  611. return true;
  612. }
  613. //---------------------------------------------------------------------------
  614. /*
  615. * 지도 영역 이동 함수. 다음 영역으로 이동
  616. * 이동 범위에 따라 이전/다음 버튼을 활성/비활성 시킨다.
  617. * arguments
  618. * return
  619. * void
  620. */
  621. bool __fastcall TITS00GEO::NextExtentQ()
  622. {
  623. #if 0
  624. m_ExtQ.bExtent = false;
  625. if (m_ExtQ.currIdx >= m_ExtQ.userIdx-1)
  626. {
  627. m_ExtQ.currIdx = m_ExtQ.userIdx-1;
  628. return false;
  629. }
  630. m_ExtQ.currIdx++;
  631. TDDRect *pExt = &m_ExtQ.extent[m_ExtQ.currIdx];
  632. SetExtent(*pExt);
  633. #endif
  634. return true;
  635. }
  636. //---------------------------------------------------------------------------
  637. void __fastcall TITS00GEO::ImgPrevClick(TObject *Sender)
  638. {
  639. PrevExtentQ();
  640. }
  641. //---------------------------------------------------------------------------
  642. void __fastcall TITS00GEO::ImgNextClick(TObject *Sender)
  643. {
  644. NextExtentQ();
  645. }
  646. //---------------------------------------------------------------------------
  647. void __fastcall TITS00GEO::ChkTrafficLayerClick(TObject *Sender)
  648. {
  649. SetTrfLayerShow(ChkTrafficLayer->Checked);
  650. }
  651. //---------------------------------------------------------------------------
  652. /*
  653. * 소통정보 레이어 보기 숨기기
  654. * arguments
  655. *
  656. * return
  657. * void
  658. */
  659. void __fastcall TITS00GEO::SetTrfLayerShow(bool bShow)
  660. {
  661. }
  662. //---------------------------------------------------------------------------
  663. void __fastcall TITS00GEO::ChkToolTipClick(TObject *Sender)
  664. {
  665. if (!ChkToolTip->Checked)
  666. {
  667. }
  668. }
  669. //---------------------------------------------------------------------------
  670. void __fastcall TITS00GEO::TmrSelectTimer(TObject *Sender)
  671. {
  672. TmrSelect->Enabled = false;
  673. ImgSelect->Visible = false;
  674. }
  675. //---------------------------------------------------------------------------
  676. void __fastcall TITS00GEO::SelectObjectByPos(double dPosX, double dPosY, bool bArrow/*=false*/)
  677. {
  678. }
  679. //---------------------------------------------------------------------------
  680. void __fastcall TITS00GEO::SelectObjectByPos()
  681. {
  682. TPoint ptTmp;
  683. //ImgSelect->Parent = xclntMap;
  684. ImgSelect->Visible = false;
  685. TmrSelect->Enabled = false;
  686. TmrSelect->Interval = 3000;
  687. //ptTmp = xclntMap->RealToScreen(m_ptSelect);
  688. ImgSelect->Left = ptTmp.x - (ImgSelect->Width/2);
  689. ImgSelect->Top = ptTmp.y - (ImgSelect->Height)-10;
  690. TmrSelect->Enabled = true;
  691. ImgSelect->Visible = true;
  692. }
  693. //---------------------------------------------------------------------------
  694. String __fastcall TITS00GEO::GetLinkLayerName()
  695. {
  696. if (m_nMapLevel < 3 || m_nMapLevel > 7) return "no_map";
  697. }
  698. //---------------------------------------------------------------------------
  699. bool __fastcall TITS00GEO::SelectLinkById(int ALinkLevel, String sId, bool bHide/*=false*/)
  700. {
  701. bool bResult = false;
  702. String sLinkLyrName = "";
  703. int nLyrIndex = -1;
  704. return bResult;
  705. }
  706. //---------------------------------------------------------------------------
  707. bool __fastcall TITS00GEO::SelectLinkByPos(int X, int Y)
  708. {
  709. String sLinkId;
  710. return false;
  711. }
  712. //---------------------------------------------------------------------------
  713. void __fastcall TITS00GEO::TmrLinkSelectTimer(TObject *Sender)
  714. {
  715. TmrLinkSelect->Enabled = false;
  716. }
  717. //---------------------------------------------------------------------------
  718. /*
  719. * 링크레이어 도움말 표출
  720. * arguments
  721. * return
  722. * void
  723. */
  724. bool __fastcall TITS00GEO::GetLevelLinkId(int ALinkLevel, String &sLinkId, int X, int Y)
  725. {
  726. String sLinkLyrName = "";
  727. int nLyrIndex = -1;
  728. sLinkId = "";
  729. return false;
  730. }
  731. //---------------------------------------------------------------------------
  732. void __fastcall TITS00GEO::MnuSetStdAreaClick(TObject *Sender)
  733. {
  734. Application->ProcessMessages();
  735. if (Application->MessageBox(L"현재 영역을 표준영역으로 지정하시겠습니까?", L"확인",
  736. MB_YESNO|MB_ICONQUESTION) != IDYES)
  737. {
  738. return;
  739. }
  740. TIniFile *pIniFile = NULL;
  741. String sIniFile = ChangeFileExt(ExtractFileName(Application->ExeName), ".ini");
  742. String sCfgFile = ExtractFilePath(Application->ExeName) + "\\cfg\\" + sIniFile;
  743. try
  744. {
  745. try
  746. {
  747. pIniFile = new TIniFile(sCfgFile);
  748. #if 0
  749. TDDRect rc = xclntMap->GetViewExtent();
  750. pIniFile->WriteString("MAP", "LEFTTOPX", String(rc.MaxX));
  751. pIniFile->WriteString("MAP", "LEFTTOPY", String(rc.MaxY));
  752. pIniFile->WriteString("MAP", "RIGHTBOTTOMX", String(rc.MinX));
  753. pIniFile->WriteString("MAP", "RIGHTBOTTOMY", String(rc.MinY));
  754. g_GisInfo.dLeftTopX = rc.MaxX;
  755. g_GisInfo.dLeftTopY = rc.MaxY;
  756. g_GisInfo.dRightBottomX = rc.MinX;
  757. g_GisInfo.dRightBottomY = rc.MinY;
  758. #endif
  759. }
  760. __finally
  761. {
  762. if (pIniFile) delete pIniFile;
  763. pIniFile = NULL;
  764. }
  765. }
  766. catch(...)
  767. {
  768. }
  769. }
  770. //---------------------------------------------------------------------------
  771. void __fastcall TITS00GEO::SetTrafficInfo(bool bFlag)
  772. {
  773. bool alivethread = false;
  774. }
  775. //---------------------------------------------------------------------------
  776. void __fastcall TITS00GEO::RefreshMapTraffic()
  777. {
  778. }
  779. //---------------------------------------------------------------------------
  780. void __fastcall TITS00GEO::ChkDrawIncidentClick(TObject *Sender)
  781. {
  782. UpdateIncidentStatus();
  783. }
  784. //---------------------------------------------------------------------------
  785. void __fastcall TITS00GEO::ChkDrawGisClick(TObject *Sender)
  786. {
  787. UpdateFacilityStatus();
  788. }
  789. //---------------------------------------------------------------------------
  790. void __fastcall TITS00GEO::ShowLinkDetailInfo(String sLinkId, int nLinkLevel)
  791. {
  792. try
  793. {
  794. if (FrmLinkInfo == NULL)
  795. {
  796. FrmLinkInfo = new TFrmLinkInfo(Application);
  797. }
  798. FrmLinkInfo->Show();
  799. FrmLinkInfo->ShowLinkInfo(sLinkId, nLinkLevel);
  800. }
  801. catch(...)
  802. {
  803. }
  804. }
  805. //---------------------------------------------------------------------------
  806. void __fastcall TITS00GEO::ChkGisSearchClick(TObject *Sender)
  807. {
  808. try
  809. {
  810. if (ChkGisSearch->Checked)
  811. {
  812. if (FrmGisSearch == NULL)
  813. {
  814. FrmGisSearch = new TFrmGisSearch(this);
  815. //FrmGisSearch->Parent = this;
  816. }
  817. FrmGisSearch->Show();
  818. }
  819. else
  820. {
  821. if (FrmGisSearch)
  822. {
  823. if (FrmGisSearch->m_bClose == false)
  824. {
  825. FrmGisSearch->Close();
  826. }
  827. }
  828. }
  829. }
  830. catch(...)
  831. {
  832. }
  833. }
  834. //---------------------------------------------------------------------------
  835. void __fastcall TITS00GEO::FormClose(TObject *Sender, TCloseAction &Action)
  836. {
  837. CommClose();
  838. //ITS00GEO = NULL;
  839. Action = caFree;
  840. }
  841. //---------------------------------------------------------------------------
  842. void __fastcall TITS00GEO::panRemarkMouseDown(TObject *Sender, TMouseButton Button, TShiftState Shift, int X, int Y)
  843. {
  844. TcxGroupBox *pGroup = (TcxGroupBox*)Sender;
  845. ReleaseCapture();
  846. pGroup->Perform(WM_SYSCOMMAND, 0xf012, 0);
  847. }
  848. //---------------------------------------------------------------------------
  849. void __fastcall TITS00GEO::ChkViewExamplePropertiesChange(TObject *Sender)
  850. {
  851. panRemark->Visible = ChkViewExample->Checked;
  852. }
  853. //---------------------------------------------------------------------------
  854. /*
  855. * 시설물의 상태에 따라 이미지를 전자지도에 표출한다.(XiClient->CCTVIconList)
  856. * arguments
  857. *
  858. * return
  859. * void
  860. */
  861. void __fastcall TITS00GEO::UpdateFacilityStatus()
  862. {
  863. static String sStatusMsg[3] = { "정상", "이상", "모름", };
  864. int nStatus = 0;
  865. TItsFacility *pFacility;
  866. //xclntMap->ClearCCTVEvent(true);
  867. if (ChkDrawCtv->Checked)
  868. {
  869. try
  870. {
  871. ItsFacilityManager->FCctvLists.Lock();
  872. FOR_STL(TItsCctv *, pObj, ItsFacilityManager->FCctvLists)
  873. {
  874. nStatus = 2;
  875. pFacility = ItsFacilityManager->FLists.Find(pObj->CCTV_CTLR_ID);
  876. if (pFacility)
  877. {
  878. if (pFacility->CommStatus == "CMS0") nStatus = 0;
  879. else
  880. if (pFacility->CommStatus == "CMS1") nStatus = 1;
  881. }
  882. try {
  883. String sTitle = "▶▶CCTV 정보◀◀|CCTV ID : " + pObj->CCTV_CTLR_ID + "|명칭 : " + pObj->ISTL_LCTN_NM + "|상태 : " + sStatusMsg[nStatus];
  884. //xclntMap->ADDCCTVEvent(DDPoint(pObj->X_CRDN.ToDouble(), pObj->Y_CRDN.ToDouble()), pObj->CCTV_CTLR_ID, "CCTV", sTitle, nStatus+1, 1, 7);
  885. } catch(...) { }
  886. }
  887. }
  888. __finally
  889. {
  890. ItsFacilityManager->FCctvLists.UnLock();
  891. }
  892. }
  893. if (ChkDrawVms->Checked)
  894. {
  895. try
  896. {
  897. ItsFacilityManager->FVmsLists.Lock();
  898. FOR_STL(TItsVms *, pObj, ItsFacilityManager->FVmsLists)
  899. {
  900. nStatus = 2;
  901. pFacility = ItsFacilityManager->FLists.Find(pObj->VMS_CTLR_ID);
  902. if (pFacility)
  903. {
  904. if (pFacility->CommStatus == "CMS0") nStatus = 0;
  905. else
  906. if (pFacility->CommStatus == "CMS1") nStatus = 1;
  907. }
  908. try {
  909. String sTitle = "▶▶VMS 정보◀◀|VMS ID : " + pObj->VMS_CTLR_ID + "|명칭 : " + pObj->VMS_NM + "|상태 : " + sStatusMsg[nStatus];
  910. //xclntMap->ADDCCTVEvent(DDPoint(pObj->X_CRDN.ToDouble(), pObj->Y_CRDN.ToDouble()), pObj->VMS_CTLR_ID, "VMS", sTitle, nStatus+4, 1, 7);
  911. } catch(...) { }
  912. }
  913. }
  914. __finally
  915. {
  916. ItsFacilityManager->FVmsLists.UnLock();
  917. }
  918. }
  919. if (ChkDrawRse->Checked)
  920. {
  921. try
  922. {
  923. ItsFacilityManager->FRseLists.Lock();
  924. FOR_STL(TItsRse *, pObj, ItsFacilityManager->FRseLists)
  925. {
  926. nStatus = 2;
  927. pFacility = ItsFacilityManager->FLists.Find(pObj->RSEID);
  928. if (pFacility)
  929. {
  930. if (pFacility->CommStatus == "CMS0") nStatus = 0;
  931. else
  932. if (pFacility->CommStatus == "CMS1") nStatus = 1;
  933. }
  934. try {
  935. String sTitle = "▶▶RSE 정보◀◀|RSE ID : " + pObj->RSEID + "|명칭 : " + pObj->LOCATION + "|상태 : " + sStatusMsg[nStatus];
  936. //xclntMap->ADDCCTVEvent(DDPoint(pObj->COORDX.ToDouble(), pObj->COORDY.ToDouble()), pObj->RSEID, "RSE", sTitle, nStatus+7, 1, 7);
  937. } catch(...) { }
  938. }
  939. }
  940. __finally
  941. {
  942. ItsFacilityManager->FRseLists.UnLock();
  943. }
  944. }
  945. //xclntMap->ReDraw();
  946. }
  947. //---------------------------------------------------------------------------
  948. /*
  949. * 돌발 상태에 따라 이미지를 전자지도에 표출한다.(XiClient->ADDAccEvent)
  950. * arguments
  951. *
  952. * return
  953. * void
  954. */
  955. void __fastcall TITS00GEO::UpdateIncidentStatus()
  956. {
  957. static String sStatusMsg[5] = { "사고", "공사", "행사", "기상", "기타", };
  958. int nStatus = 0;
  959. //xclntMap->ClearAccEvent(true);
  960. if (ChkDrawIncident->Checked)
  961. {
  962. try
  963. {
  964. ItsIncidentManager->FLists.Lock();
  965. FOR_STL(TItsIncident *, pObj, ItsIncidentManager->FLists)
  966. {
  967. if (pObj->INCD_PRGR_STEP_CD == "ISS2")
  968. {
  969. nStatus = 4;
  970. if (pObj->INCD_TYPE_CLSF_CD == "1") nStatus = 0;
  971. else
  972. if (pObj->INCD_TYPE_CLSF_CD == "2") nStatus = 1;
  973. else
  974. if (pObj->INCD_TYPE_CLSF_CD == "3") nStatus = 2;
  975. else
  976. if (pObj->INCD_TYPE_CLSF_CD == "4") nStatus = 3;
  977. String sTitle = "▶▶돌발 정보◀◀|돌발 ID : " + pObj->INCD_OCRR_ID + "|제목 : " + pObj->INCD_TITL + "|유형 : " + sStatusMsg[nStatus];
  978. sTitle += "|돌발등록시각: " + ITSUtil_StrToTime(pObj->RGST_DT) + "|돌발시작시각: " + ITSUtil_StrToTime(pObj->FINCD_STRT_DT);
  979. sTitle += "|돌발종료시각: " + ITSUtil_StrToTime(pObj->INCD_END_PRAR_DT);
  980. //xclntMap->ADDAccEvent(DDPoint(pObj->X_CRDN.ToDouble(), pObj->Y_CRDN.ToDouble()), pObj->INCD_OCRR_ID, sTitle, sTitle, "", nStatus+10, false, 1, 7);
  981. }
  982. }
  983. }
  984. __finally
  985. {
  986. ItsIncidentManager->FLists.UnLock();
  987. }
  988. }
  989. //xclntMap->ReDraw();
  990. }
  991. //---------------------------------------------------------------------------
  992. void __fastcall TITS00GEO::pmuFacilityPopup(TObject *Sender)
  993. {
  994. TPopupMenu *pMenu = (TPopupMenu*)Sender;
  995. if (pMenu->Tag == 0)
  996. {
  997. MnuCctvId->Caption = "[CCTV] " + FSelId;
  998. }
  999. else
  1000. if (pMenu->Tag == 1)
  1001. {
  1002. MnuVmsId->Caption = "[VMS] " + FSelId;
  1003. }
  1004. else
  1005. if (pMenu->Tag == 2)
  1006. {
  1007. MnuRseId->Caption = "[RSE] " + FSelId;
  1008. }
  1009. }
  1010. //---------------------------------------------------------------------------
  1011. void __fastcall TITS00GEO::mnuFacilityPingClick(TObject *Sender)
  1012. {
  1013. TMenuItem *pMenu = (TMenuItem*)Sender;
  1014. String sIp;
  1015. Application->ProcessMessages();
  1016. if (pMenu->Tag >= 11 && 15 >= pMenu->Tag)
  1017. {
  1018. String sIp;
  1019. TItsCctv *pObj = ItsFacilityManager->FCctvLists.Find(FSelId);
  1020. if (pObj)
  1021. {
  1022. switch(pMenu->Tag)
  1023. {
  1024. case 12: sIp = pObj->CCTV_CAPT_IP.Trim(); break;
  1025. case 13: sIp = pObj->CCTV_ENCD_IP.Trim(); break;
  1026. case 14: sIp = pObj->STRM_SVR_IP.Trim(); break;
  1027. case 15: sIp = pObj->CCTV_FIBR_IP.Trim(); break;
  1028. case 11:
  1029. default: sIp = pObj->CCTV_CTLR_IP.Trim(); break;
  1030. }
  1031. }
  1032. }
  1033. else
  1034. if (pMenu->Tag >= 21 && 22 >= pMenu->Tag)
  1035. {
  1036. String sIp;
  1037. TItsVms *pObj = ItsFacilityManager->FVmsLists.Find(FSelId);
  1038. if (pObj)
  1039. {
  1040. switch(pMenu->Tag)
  1041. {
  1042. case 22: sIp = pObj->WEB_CMRA_IP.Trim(); break;
  1043. case 21:
  1044. default: sIp = pObj->VMS_CTLR_IP.Trim(); break;
  1045. }
  1046. }
  1047. }
  1048. else
  1049. if (pMenu->Tag == 2)
  1050. {
  1051. TItsRse *pObj = ItsFacilityManager->FRseLists.Find(FSelId);
  1052. if (pObj) sIp = pObj->RSEIP.Trim();
  1053. }
  1054. if (sIp.IsEmpty())
  1055. {
  1056. Application->MessageBox(L"IP Address 정보가 없습니다.\r\nIP Address 정보를 확인하세요.",
  1057. L"네크워크 연결확인", MB_OK|MB_ICONERROR|MB_APPLMODAL);
  1058. return;
  1059. }
  1060. ITSUtil_NetworkPing(sIp);
  1061. }
  1062. //---------------------------------------------------------------------------
  1063. void __fastcall TITS00GEO::mnuStopImageClick(TObject *Sender)
  1064. {
  1065. Application->ProcessMessages();
  1066. TPoint pt;
  1067. GetCursorPos(&pt);
  1068. pt = ITS00G0M->ScreenToClient(pt);
  1069. ShowCctvStopImage(FSelId, pt);
  1070. }
  1071. //---------------------------------------------------------------------------
  1072. void __fastcall TITS00GEO::mnuCctvCamClick(TObject *Sender)
  1073. {
  1074. Application->ProcessMessages();
  1075. TPoint pt;
  1076. GetCursorPos(&pt);
  1077. pt = ITS00G0M->ScreenToClient(pt);
  1078. ShowCctvCamera(FSelId, pt);
  1079. }
  1080. //---------------------------------------------------------------------------
  1081. void __fastcall TITS00GEO::mnuVmsMsgClick(TObject *Sender)
  1082. {
  1083. Application->ProcessMessages();
  1084. TPoint pt;
  1085. GetCursorPos(&pt);
  1086. pt = ITS00G0M->ScreenToClient(pt);
  1087. ShowVmsMessage(FSelId, pt);
  1088. }
  1089. //---------------------------------------------------------------------------
  1090. void __fastcall TITS00GEO::mnuVmsCamClick(TObject *Sender)
  1091. {
  1092. Application->ProcessMessages();
  1093. TPoint pt;
  1094. GetCursorPos(&pt);
  1095. pt = ITS00G0M->ScreenToClient(pt);
  1096. ShowVmsCamera(FSelId, pt);
  1097. }
  1098. //---------------------------------------------------------------------------
  1099. void __fastcall TITS00GEO::ShowCctvStopImage(String AId, TPoint pt)
  1100. {
  1101. TItsCctv *pObj = ItsFacilityManager->FCctvLists.Find(AId);
  1102. if (!pObj) return;
  1103. try {
  1104. if (pObj->FData1)
  1105. {
  1106. TFrmCctvImg *pForm = (TFrmCctvImg *)pObj->FData1;
  1107. pForm->SetFocus();
  1108. pForm->LoadStopImage();
  1109. }
  1110. else
  1111. {
  1112. TFrmCctvImg *pForm = new TFrmCctvImg(ITS00G0M);
  1113. pForm->Parent = ITS00G0M;
  1114. if ((pt.x + pForm->Width + 5) > this->Width)
  1115. {
  1116. pt.x = this->Width - pForm->Width - 5;
  1117. }
  1118. if ((pt.y + pForm->Height + 5) > this->Height)
  1119. {
  1120. pt.y = this->Height - pForm->Height - 5;
  1121. }
  1122. pForm->Left = Left + pt.x;
  1123. pForm->Top = Top + pt.y;
  1124. pForm->FObj = pObj;
  1125. pObj->FData1 = (void*)pForm;
  1126. pForm->Show();
  1127. }
  1128. } catch(...) {}
  1129. }
  1130. //---------------------------------------------------------------------------
  1131. void __fastcall TITS00GEO::ShowCctvCamera(String AId, TPoint pt)
  1132. {
  1133. TItsCctv *pObj = ItsFacilityManager->FCctvLists.Find(AId);
  1134. if (!pObj) return;
  1135. try {
  1136. if (pObj->FData2)
  1137. {
  1138. TFrmCctvCam *pForm = (TFrmCctvCam *)pObj->FData2;
  1139. pForm->SetFocus();
  1140. }
  1141. else
  1142. {
  1143. TFrmCctvCam *pForm = new TFrmCctvCam(ITS00G0M);
  1144. pForm->Parent = ITS00G0M;
  1145. if ((pt.x + pForm->Width + 5) > this->Width)
  1146. {
  1147. pt.x = this->Width - pForm->Width - 5;
  1148. }
  1149. if ((pt.y + pForm->Height + 5) > this->Height)
  1150. {
  1151. pt.y = this->Height - pForm->Height - 5;
  1152. }
  1153. pForm->Left = Left + pt.x;
  1154. pForm->Top = Top + pt.y;
  1155. pForm->FObj = pObj;
  1156. pObj->FData2 = (void*)pForm;
  1157. pForm->Show();
  1158. }
  1159. } catch(...) {}
  1160. }
  1161. //---------------------------------------------------------------------------
  1162. void __fastcall TITS00GEO::ShowVmsMessage(String AId, TPoint pt)
  1163. {
  1164. TItsVms *pObj = ItsFacilityManager->FVmsLists.Find(FSelId);
  1165. if (!pObj) return;
  1166. try {
  1167. if (pObj->FData1)
  1168. {
  1169. TFrmVmsMsg *pForm = (TFrmVmsMsg *)pObj->FData1;
  1170. pForm->SetFocus();
  1171. }
  1172. else
  1173. {
  1174. TFrmVmsMsg *pForm = new TFrmVmsMsg(ITS00G0M, pObj);
  1175. pForm->Parent = ITS00G0M;
  1176. int nHG = pForm->ClientHeight - pForm->PnlVmsMsgDisp->Height;
  1177. int nWG = pForm->ClientWidth - pForm->PnlVmsMsgDisp->Width;
  1178. #if 0
  1179. pForm->ClientHeight = nHG + pObj->Height;
  1180. pForm->ClientWidth = nWG + pObj->Width;
  1181. #endif
  1182. if ((pt.x + pForm->Width + 5) > this->Width)
  1183. {
  1184. pt.x = this->Width - pForm->Width - 5;
  1185. }
  1186. if ((pt.y + pForm->Height + 5) > this->Height)
  1187. {
  1188. pt.y = this->Height - pForm->Height - 5;
  1189. }
  1190. pForm->Left = Left + pt.x;
  1191. pForm->Top = Top + pt.y;
  1192. pForm->FObj = pObj;
  1193. pObj->FData1 = (void*)pForm;
  1194. pForm->Show();
  1195. }
  1196. } catch(...) {}
  1197. }
  1198. //---------------------------------------------------------------------------
  1199. void __fastcall TITS00GEO::ShowVmsCamera(String AId, TPoint pt)
  1200. {
  1201. TItsVms *pObj = ItsFacilityManager->FVmsLists.Find(FSelId);
  1202. if (!pObj) return;
  1203. try {
  1204. if (pObj->FData2)
  1205. {
  1206. TFrmVmsCam *pForm = (TFrmVmsCam *)pObj->FData2;
  1207. #if 0
  1208. if ((pt.x + pForm->Width + 5) > this->Width)
  1209. {
  1210. pt.x = this->Width - pForm->Width - 5;
  1211. }
  1212. if ((pt.y + pForm->Height + 5) > this->Height)
  1213. {
  1214. pt.y = this->Height - pForm->Height - 5;
  1215. }
  1216. pForm->Left = Left + pt.x;
  1217. pForm->Top = Top + pt.y;
  1218. #endif
  1219. pForm->SetFocus();
  1220. }
  1221. else
  1222. {
  1223. TFrmVmsCam *pForm = new TFrmVmsCam(ITS00G0M, pObj);
  1224. pForm->Parent = ITS00G0M;
  1225. if ((pt.x + pForm->Width + 5) > this->Width)
  1226. {
  1227. pt.x = this->Width - pForm->Width - 5;
  1228. }
  1229. if ((pt.y + pForm->Height + 5) > this->Height)
  1230. {
  1231. pt.y = this->Height - pForm->Height - 5;
  1232. }
  1233. pForm->Left = Left + pt.x;
  1234. pForm->Top = Top + pt.y;
  1235. pForm->FObj = pObj;
  1236. pObj->FData2 = (void*)pForm;
  1237. pForm->Show();
  1238. }
  1239. } catch(...) {}
  1240. }
  1241. //---------------------------------------------------------------------------
  1242. void __fastcall TITS00GEO::GMMap1AfterPageLoaded(TObject *Sender, bool First)
  1243. {
  1244. if (First)
  1245. {
  1246. GMMap1->DoMap();
  1247. }
  1248. }
  1249. //---------------------------------------------------------------------------
  1250. void __fastcall TITS00GEO::WebBrowser1DocumentComplete(TObject *ASender, const IDispatch *pDisp, OleVariant &URL)
  1251. {
  1252. try {
  1253. Variant vBody;
  1254. Variant vObj = WebBrowser1->OleObject;
  1255. String strDocCompatMode = vObj.OlePropertyGet("document").OlePropertyGet("compatMode");
  1256. if (SameText(strDocCompatMode, "CSS1Compat"))
  1257. vBody = vObj.OlePropertyGet("Document").OlePropertyGet("documentElement");
  1258. else
  1259. vBody = vObj.OlePropertyGet("Document").OlePropertyGet("body");
  1260. vBody.OlePropertyGet("style").OlePropertySet("overflow", "hidden");
  1261. } catch(...) {}
  1262. }
  1263. //---------------------------------------------------------------------------
  1264. void __fastcall TITS00GEO::GMMap1ZoomChanged(TObject *Sender, int NewZoom)
  1265. {
  1266. m_nMapLevel = NewZoom;
  1267. LblZoomLevel->Caption = String(NewZoom);
  1268. }
  1269. //---------------------------------------------------------------------------
  1270. void __fastcall TITS00GEO::ImgStndClick(TObject *Sender)
  1271. {
  1272. if (FRectangle)
  1273. {
  1274. // 사각형 그리기 끝내기
  1275. FRectangle = false;
  1276. FRectangleIdx = 0;
  1277. }
  1278. else
  1279. {
  1280. FRectangle = true;
  1281. FRectangleIdx = 0;
  1282. }
  1283. if (ImgStnd->Tag == 13)
  1284. {
  1285. GMMap1->NonVisualProp->Options = (GMMap1->NonVisualProp->Options >> Draggable);
  1286. GMMap1->NonVisualProp->Options = (GMMap1->NonVisualProp->Options >> ScrollWheel);
  1287. GMMap1->DoMap();
  1288. ImgStnd->Tag = 20;
  1289. }
  1290. else
  1291. {
  1292. FVehRect->Visible = false;
  1293. GMMap1->NonVisualProp->Options = (GMMap1->NonVisualProp->Options << Draggable);
  1294. GMMap1->NonVisualProp->Options = (GMMap1->NonVisualProp->Options << ScrollWheel);
  1295. GMMap1->DoMap();
  1296. ImgStnd->Tag = 13;
  1297. }
  1298. }
  1299. //---------------------------------------------------------------------------
  1300. void __fastcall TITS00GEO::GMMap1Click(TObject *Sender, TLatLng *LatLng, double X, double Y)
  1301. {
  1302. if (FRectangle && FRectangleIdx == 0)
  1303. {
  1304. FVehRect->Visible = true;
  1305. Edit1->Text = LatLng->LatToStr(GMMap1->Precision);
  1306. Edit2->Text = LatLng->LngToStr(GMMap1->Precision);
  1307. FVehRect->Bounds->NE->Lat = LatLng->Lat;
  1308. FVehRect->Bounds->NE->Lng = LatLng->Lng;
  1309. FVehRect->Bounds->SW->Lat = LatLng->Lat;
  1310. FVehRect->Bounds->SW->Lng = LatLng->Lng;
  1311. FRectangleIdx = 1;
  1312. Memo1->Lines->Add(Edit1->Text + " " + Edit2->Text);
  1313. }
  1314. else
  1315. if (FRectangle && FRectangleIdx == 1)
  1316. {
  1317. Edit1->Text = LatLng->LatToStr(GMMap1->Precision);
  1318. Edit2->Text = LatLng->LngToStr(GMMap1->Precision);
  1319. if (LatLng->Lng > FVehRect->Bounds->NE->Lng)
  1320. {
  1321. FVehRect->Bounds->SW->Lat = FVehRect->Bounds->NE->Lat;
  1322. FVehRect->Bounds->SW->Lng = FVehRect->Bounds->NE->Lng;
  1323. FVehRect->Bounds->NE->Lat = LatLng->Lat;
  1324. FVehRect->Bounds->NE->Lng = LatLng->Lng;
  1325. }
  1326. else
  1327. {
  1328. FVehRect->Bounds->SW->Lat = LatLng->Lat;
  1329. FVehRect->Bounds->SW->Lng = LatLng->Lng;
  1330. }
  1331. Memo1->Lines->Add(Edit1->Text + " " + Edit2->Text);
  1332. FRectangle = false;
  1333. FRectangleIdx = 0;
  1334. //FVehRect->Visible = false;
  1335. }
  1336. }
  1337. //---------------------------------------------------------------------------
  1338. void __fastcall TITS00GEO::GMMap1MouseMove(TObject *Sender, TLatLng *LatLng, double X, double Y)
  1339. {
  1340. return;
  1341. if (FRectangle && FRectangleIdx == 1)
  1342. {
  1343. if (LatLng->Lng > FVehRect->Bounds->NE->Lng)
  1344. {
  1345. FVehRect->Bounds->SW->Lat = FVehRect->Bounds->NE->Lat;
  1346. FVehRect->Bounds->SW->Lng = FVehRect->Bounds->NE->Lng;
  1347. FVehRect->Bounds->NE->Lat = LatLng->Lat;
  1348. FVehRect->Bounds->NE->Lng = LatLng->Lng;
  1349. }
  1350. else
  1351. {
  1352. FVehRect->Bounds->SW->Lat = LatLng->Lat;
  1353. FVehRect->Bounds->SW->Lng = LatLng->Lng;
  1354. }
  1355. }
  1356. }
  1357. //---------------------------------------------------------------------------
  1358. void __fastcall TITS00GEO::FormCreate(TObject *Sender)
  1359. {
  1360. //Application->OnMessage = WebMessageHandler;
  1361. }
  1362. //---------------------------------------------------------------------------
  1363. void __fastcall TITS00GEO::WebMessageHandler(TMsg &Msg, bool &Handled)
  1364. {
  1365. if (Msg.hwnd == WebBrowser1->Handle)
  1366. {
  1367. if (FRectangle)
  1368. {
  1369. if (Msg.message == WM_LBUTTONDOWN)
  1370. {
  1371. Handled = true;
  1372. }
  1373. else
  1374. if (Msg.message == WM_LBUTTONUP)
  1375. {
  1376. Handled = true;
  1377. }
  1378. }
  1379. }
  1380. #if 0
  1381. Handled = IsDialogMessage(WebBrowser1->Handle, &Msg) == true;
  1382. if (!Handled || WebBrowser1->Busy) return;
  1383. if (FRectangle)
  1384. {
  1385. if (Msg.message == WM_LBUTTONDOWN)
  1386. {
  1387. //Handled = true;
  1388. }
  1389. else
  1390. if (Msg.message == WM_LBUTTONUP)
  1391. {
  1392. //Handled = true;
  1393. }
  1394. }
  1395. #endif
  1396. }
  1397. //---------------------------------------------------------------------------
  1398. void __fastcall TITS00GEO::GMVehRectMouseUp(TObject *Sender, TLatLng *LatLng, int Index, TLinkedComponent *LinkedComponent)
  1399. {
  1400. if (Index == 0)
  1401. {
  1402. Memo1->Lines->Add("job completed");
  1403. }
  1404. }
  1405. //---------------------------------------------------------------------------