No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Main.cs 139KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315
  1. using System.Collections;
  2. using System.Collections.Generic;
  3. using UnityEngine;
  4. using UnityEngine.UI;
  5. using XCharts.Runtime;
  6. using TMPro;
  7. using System;
  8. using UnityEngine.Networking;
  9. using System.Data;
  10. public class Main : MonoBehaviour
  11. {
  12. public CanvasScaler canvasScaler;
  13. public BarChart chart;
  14. public BarChart chart2;
  15. public TMP_FontAsset myFont;
  16. public Sprite UIsprite;public Sprite sprite_check;
  17. AudioSource alarm_sound;
  18. [SerializeField] TMP_InputField 驗證碼_tb;
  19. [SerializeField] TextMeshProUGUI 電表編號_tb,平均電壓_tb,平均電流_tb,累計用電量_tb,副電表編號_tb,副平均電壓_tb,副平均電流_tb,副累計用電量_tb,主跑馬燈_tb,副跑馬燈_tb,
  20. 消防異常page_lb,消防跑馬燈_tb,設備編號_tb,設備位置_tb,設備樓層_tb,設備用途_tb,設備區塊_tb,試算_平均電壓_tb,試算_平均電流_tb,試算_平均功率_tb,試算_總消耗功率_tb,試算_總消耗能量_tb,
  21. 試算_電費試算_tb,試算_計算規則_tb,區間總和_tb,電費總和_tb,詳細平均電壓_tb,詳細平均電流_tb,詳細電流A相_tb,詳細電流B相_tb,詳細電流C相_tb,詳細電流不平衡A相_tb,詳細電流不平衡B相_tb,
  22. 詳細電流不平衡C相_tb,詳細電壓AB相_tb,詳細電壓BC相_tb,詳細電壓CA相_tb,詳細電壓不平衡AB相_tb,詳細電壓不平衡BC相_tb,詳細電壓不平衡CA相_tb,詳細平均有效功率_tb,詳細平均無效功率_tb,
  23. 詳細平均視在功率_tb,提供的有效電能_tb,接收的有效電能_tb,提供加接收的有效電能_tb,提供減接收的有效電能_tb,提供的無效電能_tb,接收的無效電能_tb,提供加接收的無效電能_tb,提供減接收的無效電能_tb,
  24. 提供的視在電能_tb,接收的視在電能_tb,提供加接收的視在電能_tb,提供減接收的視在電能_tb,V2_lb,V3_lb,I2_lb,I3_lb,副V2_lb,副V3_lb,副I2_lb,副I3_lb,詳V2_lb,詳V3_lb,詳I2_lb,詳I3_lb,詳P2_lb,
  25. 詳P3_lb,詳Q2_lb,詳Q3_lb,詳S2_lb,詳S3_lb,彈跳文字_tb,讀取_tb,排碳係數_lb,排碳最新係數_lb,排碳使用度數_lb,排碳量_lb;
  26. [SerializeField] GameObject 電能監控系統_pl,電能背景_ex,主跑馬燈_pl,主電力警報音效_bt,副電力警報音效_bt,副跑馬燈_pl,簡易電表_pl,小電表_pl,驗證碼_pl,彈跳_pl,
  27. 右側按鈕_pl,電費試算表_pl,試算_電表名稱_cb,試算_幣別_tb,試算_幣別_cb,電能報表_pl,開始時間_cb,結束時間_cb,電表編號_cb,詳細電表_pl,讀取_pl;
  28. [SerializeField] TMP_Dropdown 試算_開始年_cb,試算_結束年_cb,試算_開始月_cb,試算_結束月_cb,試算_開始日_cb,試算_結束日_cb,區間_開始_年_cb,區間_開始_月_cb,區間_開始_日_cb,
  29. 電費_開始_年_cb,電費_開始_月_cb,電費_開始_日_cb,電費_開始_小時_cb,電費_結束_年_cb,電費_結束_月_cb,電費_結束_日_cb,電費_結束_小時_cb,排碳_年_cb,排碳_月_cb,排碳_日_cb;
  30. [SerializeField] Slider 詳V1,詳V2,詳V3,詳I1,詳I2,詳I3;
  31. [SerializeField] private List<Sprite> 控件圖片 = new List<Sprite>();
  32. [SerializeField] private List<Sprite> W = new List<Sprite>();[SerializeField] private List<Image> 安全運行天數_img = new List<Image>();
  33. public Transform 小電表清單_tp;public GameObject 小電表清單_rpf;public GameObject 小電表清單_ct;
  34. public Transform 簡易電表清單_tp;public GameObject 簡易電表清單_rpf;public GameObject 簡易電表清單_ct;
  35. public LineChart 電費_chart,年用電_chart;
  36. public BarChart 電壓_barchart,電流_barchart,功率_barchart,度數_chart;
  37. public Transform 電費清單_tp;public GameObject 電費清單_rpf;public GameObject 電費清單_ct;public GameObject 電費清單_lpf;
  38. public Transform 年用電清單_tp;public GameObject 年用電清單_rpf;public GameObject 年用電清單_ct;public GameObject 年用電清單_lpf;
  39. public Transform 度數清單_tp;public GameObject 度數清單_rpf;public GameObject 度數清單_ct;public GameObject 度數清單_lpf;
  40. public AdMobManager adMobManager;
  41. private float timer=0;
  42. private bool 載入完畢=false,已開啟=false;
  43. private int buttonPressCount = 0;
  44. private float lastButtonPressTime = 0.0f;
  45. public float maxButtonPressInterval = 3f;
  46. public int requiredButtonPressCount = 2;
  47. private string loadingText = "";
  48. private int dotCount = 0;
  49. void Awake(){
  50. Global.Zoneoffset = TimeZone.CurrentTimeZone.GetUtcOffset(DateTime.Now).Hours-7;
  51. alarm_sound = GetComponent<AudioSource>();
  52. Global.年=DateTime.Now.Year.ToString();
  53. Global.上次功率因素數值=0;Global.上次副功率因素數值=0;
  54. 讀取_pl.SetActive(true);StartCoroutine(AnimateText());
  55. }
  56. void Start(){
  57. Screen.autorotateToPortrait = false;
  58. Screen.orientation = ScreenOrientation.LandscapeLeft;
  59. float screenWidth = Screen.width;
  60. float screenHeight = Screen.height;
  61. float rate = screenWidth/screenHeight;
  62. if (canvasScaler == null){
  63. canvasScaler = GetComponent<CanvasScaler>();
  64. }
  65. if (rate>(1900f/900f)){
  66. canvasScaler.matchWidthOrHeight = 1f;
  67. }
  68. else{
  69. canvasScaler.matchWidthOrHeight = 0f;
  70. }
  71. if(Global.初次載入主畫面){
  72. adMobManager.RequestBanner();
  73. Global.Wnum = new Sprite[] {W[0],W[1],W[2],W[3],W[4],W[5],W[6],W[7],W[8],W[9]};
  74. Global.sprite_check=sprite_check;
  75. Global.sprite_box=UIsprite;
  76. Global.初次載入主畫面=false;
  77. SQL_CommString.SQL_連線字串_外();
  78. SQL_Module.TestSQL(SQL_Module.ConString4);
  79. if(!SQL_Module.T_SQL){
  80. 彈跳_pl.SetActive(true);
  81. 彈跳文字_tb.text="伺服器維護中,請稍後再重新登入";
  82. Global.彈跳狀態="伺服器維護";
  83. }
  84. SQL_CommString.SQL_連線字串_外2();
  85. SQL_ele_sys.SQL_取得PHP();
  86. if(SQL_Module.dr.Read()){
  87. Global.PHP路徑=SQL_Module.dr[0].ToString();
  88. }
  89. if(PlayerPrefs.HasKey("客戶代號")){
  90. Global.客戶代號 = PlayerPrefs.GetString("客戶代號");
  91. }else{
  92. Global.客戶代號 = "GCM";
  93. }
  94. Debug.Log(Global.客戶代號);
  95. if(Global.PHP路徑==""){
  96. 彈跳_pl.SetActive(true);
  97. 彈跳文字_tb.text="與伺服器連線異常,請稍後再重新登入";
  98. Global.彈跳狀態="PHP路徑取得異常";
  99. }else{
  100. Debug.Log(Global.PHP路徑);
  101. StartCoroutine(PostRequest(10,"取得資料庫_"+ Global.客戶代號,""));
  102. StartCoroutine(PostRequest(11,"取得電表_" + Global.客戶代號,""));
  103. StartCoroutine(PostRequest(12,"是否為PLC_" + Global.客戶代號,""));
  104. }
  105. SQL_ele_sys.SQL_取得排碳係數();
  106. DataSet ds1 = new();
  107. SQL_Module.da.Fill(ds1);
  108. Global.排碳係數表 = ds1.Tables[0];
  109. if(PlayerPrefs.HasKey("副電表編號")){
  110. 副電表編號_tb.text=PlayerPrefs.GetString("副電表編號");
  111. }
  112. 排碳_年_cb.ClearOptions();
  113. 排碳_年_cb.AddOptions(Global.年度Options);
  114. 排碳_年_cb.value=Global.年度Options.IndexOf(DateTime.Today.Year.ToString());
  115. 刷新排碳係數();
  116. 排碳_月_cb.ClearOptions();
  117. List<string> 月份 = new() { "","一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月" };
  118. 排碳_月_cb.AddOptions(月份);
  119. 排碳_月_cb.value= 0;
  120. 排碳_日_cb.ClearOptions();
  121. 已開啟=true;
  122. }
  123. }
  124. void Update(){
  125. timer += Time.deltaTime;
  126. Global.deleytime += Time.deltaTime;
  127. if(!Global.載入電表名稱Option){
  128. Global.電表名稱Option.Clear();
  129. for(int i =0;i<=Global.電表數量-1;i++){
  130. Global.電表名稱Option.Add(Global.電表名稱[i]);
  131. }
  132. Global.載入電表名稱Option=true;
  133. }
  134. if(Global.資料來源=="pi" && timer >= 3f && Global.系統選擇=="電能監控系統" && !電能報表_pl.activeInHierarchy && Global.PHP_Load_End_電表即時路徑){
  135. timer=0f;
  136. for(int i=0;i<=Global.電表數量-1;i++){
  137. StartCoroutine(PostRequest_電表資料(Global.電表資料清單.Rows[i][0].ToString()));
  138. }
  139. if(詳細電表_pl.activeInHierarchy){
  140. 載入詳細電表資料();
  141. }else{
  142. 載入主電表資料();
  143. 載入副電表資料();
  144. 載入簡易電表資料();
  145. }
  146. //載入電表異常();
  147. }else if(Global.資料來源 == "PLC" && timer >= 3f && Global.系統選擇=="電能監控系統" && !電能報表_pl.activeInHierarchy){
  148. timer=0f;
  149. if(Global.客戶代號=="GCM"){
  150. StartCoroutine(PostRequest_電表資料PLC(0,"RDS D6.U 146\r"));
  151. //StartCoroutine(PostRequest_電表資料PLC(1,"RDS M970 " + Global.電表數量.ToString() + "\r"));
  152. StartCoroutine(PostRequest_電表資料PLC(2,"RDS D1006.U 146\r"));
  153. StartCoroutine(PostRequest_電表資料PLC(3,"RDS D2006.U 146\r"));
  154. StartCoroutine(PostRequest_電表資料PLC(4,"RDS D3006.U 146\r"));
  155. StartCoroutine(PostRequest_電表資料PLC(5,"RDS D4006.U 146\r"));
  156. StartCoroutine(PostRequest_電表資料PLC(6,"RDS D5006.U 146\r"));
  157. StartCoroutine(PostRequest_電表資料PLC(7,"RDS D6006.U 146\r"));
  158. }else{
  159. StartCoroutine(PostRequest_電表資料PLC(0,"RDS D6.U 146\r"));
  160. //StartCoroutine(PostRequest_電表資料PLC(1,"RDS M970 " + Global.電表數量.ToString() + "\r"));
  161. StartCoroutine(PostRequest_電表資料PLC(2,"RDS D206.U 146\r"));
  162. StartCoroutine(PostRequest_電表資料PLC(3,"RDS D406.U 146\r"));
  163. StartCoroutine(PostRequest_電表資料PLC(4,"RDS D606.U 146\r"));
  164. StartCoroutine(PostRequest_電表資料PLC(5,"RDS D806.U 146\r"));
  165. StartCoroutine(PostRequest_電表資料PLC(6,"RDS D1006.U 146\r"));
  166. StartCoroutine(PostRequest_電表資料PLC(7,"RDS D1206.U 146\r"));
  167. }
  168. if(詳細電表_pl.activeInHierarchy){
  169. 載入詳細電表資料();
  170. }else{
  171. 載入主電表資料();
  172. 載入副電表資料();
  173. 載入簡易電表資料();
  174. }
  175. 載入電表異常();
  176. }
  177. if(Global.長案){
  178. Global.長案=false;
  179. if(電能監控系統_pl.activeInHierarchy && !電能報表_pl.activeInHierarchy && !詳細電表_pl.activeInHierarchy){
  180. open_report();
  181. }else if(電能報表_pl.activeInHierarchy || 詳細電表_pl.activeInHierarchy){
  182. 電能監控系統();
  183. }
  184. }
  185. if(Global.連點[0]){
  186. Global.連點[0]=false;
  187. Open_detail(0);
  188. }
  189. if(Global.連點[1]){
  190. Global.連點[1]=false;
  191. Open_detail(1);
  192. }
  193. if(電能報表_pl.activeInHierarchy || 詳細電表_pl.activeInHierarchy){
  194. if (Input.touchCount == 3 || Input.GetMouseButton(2) || Input.GetMouseButton(1)){
  195. 電能監控系統();
  196. Global.長案=false;
  197. adMobManager.RequestBanner();
  198. }
  199. }
  200. //==============
  201. /*if(主跑馬燈_pl.activeInHierarchy==true || 副跑馬燈_pl.activeInHierarchy==true ){
  202. if(timer2>=0.5f){
  203. timer2=0;
  204. if(主跑馬燈_tb.text != "" && 主跑馬燈_tb.text.Length>=50){主跑馬燈_tb.text = 文字旋轉(主跑馬燈_tb.text, -1);}
  205. if(副跑馬燈_tb.text != "" && 副跑馬燈_tb.text.Length>=50 ){副跑馬燈_tb.text = 文字旋轉(副跑馬燈_tb.text, -1);}
  206. if(消防跑馬燈_tb.text != "" && 消防跑馬燈_tb.text.Length>=25 ){消防跑馬燈_tb.text = 文字旋轉(消防跑馬燈_tb.text, -1);}
  207. }
  208. }
  209. if(Global.系統選擇 != "消防系統" ){
  210. if(timer5>=3600f){
  211. timer5=0;
  212. 電能監控系統();
  213. }
  214. }else{
  215. timer5=0;
  216. }
  217. if(Global.電表異常BL[1]==true || Global.副電表有異常==true){
  218. if(Global.Ele_alarm_sound==true ){
  219. if(!alarm_sound.isPlaying){
  220. alarm_sound.Play();
  221. }
  222. }else{
  223. alarm_sound.Stop();
  224. }
  225. }else{
  226. alarm_sound.Stop();
  227. }
  228. if(Global.連點[0]){
  229. Global.連點[0]=false;
  230. open_detail(0);
  231. }
  232. if(Global.連點[1]){
  233. Global.連點[1]=false;
  234. open_detail(1);
  235. }
  236. if(電能報表_pl.activeInHierarchy || 詳細電表_pl.activeInHierarchy){
  237. if (Input.touchCount == 3 || Input.GetMouseButton(2) || Input.GetMouseButton(1)){
  238. 電能監控系統();
  239. Main.Global.長案=false;
  240. }
  241. }
  242. if(Global.PHP_Load_End9){
  243. Global.PHP_Load_End9=false;
  244. string alarm_data = Global.PHP_Report9;
  245. string 介面="H01";string ele_data="";string 語言;
  246. 語言="CH";
  247. for(int i=0;i<=18;i++){
  248. if(alarm_data.Substring(i*2,1)=="1"){
  249. //ele_data += Global.系統語言字典[介面+(i+7).ToString("00")+語言].Trim()+" ";
  250. int[] Abase=new int[]{0,2,3,6,8,9,11,12,15};
  251. int[] Bbase=new int[]{0,1,4,6,7,9,10,13,16};
  252. int[] Cbase=new int[]{1,2,5,7,8,10,11,14,17};
  253. if(Abase.Contains(i)){
  254. foreach (Image pic in 小電表清單_ct.GetComponentsInChildren<Image>()){
  255. if(pic.name.Contains("R_"+Global.電表異常num.ToString())){
  256. pic.color=new Color(1f,0f,0.05212975f,1f);
  257. }
  258. }
  259. }else if(Bbase.Contains(i)){
  260. foreach (Image pic in 小電表清單_ct.GetComponentsInChildren<Image>()){
  261. if(pic.name.Contains("S_"+Global.電表異常num.ToString())){
  262. pic.color=new Color(1f,0f,0.05212975f,1f);
  263. }
  264. }
  265. }else if(Cbase.Contains(i)){
  266. foreach (Image pic in 小電表清單_ct.GetComponentsInChildren<Image>()){
  267. if(pic.name.Contains("T_"+Global.電表異常num.ToString())){
  268. pic.color=new Color(1f,0f,0.05212975f,1f);
  269. }
  270. }
  271. }
  272. }
  273. }
  274. if(Global.主電表上次異常內容 != ele_data){
  275. 主跑馬燈_tb.text = ele_data;
  276. Global.主電表上次異常內容 = ele_data;
  277. }
  278. if(Global.副電表上次異常內容 != ele_data){
  279. 副跑馬燈_tb.text = ele_data;
  280. Global.副電表上次異常內容 = ele_data;
  281. }
  282. }*/
  283. if(Global.PHP_Load_End_取得資料庫路徑){
  284. Global.PHP_Load_End_取得資料庫路徑=false;
  285. 取得電表資料資料庫();
  286. 安全運行天數();
  287. 電能監控系統();
  288. 切換排碳時間();
  289. 讀取_pl.SetActive(false);
  290. }
  291. }
  292. public void 開啟驗證碼(){
  293. 驗證碼_pl.SetActive(true);
  294. if(PlayerPrefs.HasKey("驗證碼")){
  295. 驗證碼_tb.text = PlayerPrefs.GetString("驗證碼");
  296. }else{
  297. 驗證碼_tb.text = "";
  298. }
  299. }
  300. public void 輸入驗證碼(){
  301. string 舊驗證碼 = "";
  302. if(PlayerPrefs.HasKey("驗證碼")){
  303. 舊驗證碼 = PlayerPrefs.GetString("驗證碼");
  304. }
  305. if(驗證碼_tb.text != "" && 驗證碼_tb.text != 舊驗證碼){
  306. SQL_ele_sys.SQL_驗證碼判斷(驗證碼_tb.text);
  307. if(SQL_Module.dr.Read()){
  308. Global.客戶代號 = SQL_Module.dr[2].ToString();
  309. if(PlayerPrefs.HasKey("客戶代號")){PlayerPrefs.DeleteKey("客戶代號");}
  310. PlayerPrefs.SetString("客戶代號",Global.客戶代號);
  311. if(PlayerPrefs.HasKey("驗證碼")){PlayerPrefs.DeleteKey("驗證碼");}
  312. PlayerPrefs.SetString("驗證碼",驗證碼_tb.text);
  313. 彈跳_pl.SetActive(true);
  314. 彈跳文字_tb.text="驗證碼認證成功,請重新開啟APP";
  315. if(PlayerPrefs.HasKey("副電表編號")){PlayerPrefs.DeleteKey("副電表編號");}
  316. Global.彈跳狀態="驗證碼認證成功";
  317. }
  318. }else{
  319. 彈跳_pl.SetActive(true);
  320. 彈跳文字_tb.text="驗證碼有誤,請確認驗證碼是否正確!";
  321. Global.彈跳狀態="驗證碼認證失敗";
  322. }
  323. }
  324. public void 回原廠(){
  325. if(PlayerPrefs.HasKey("驗證碼")){PlayerPrefs.DeleteKey("驗證碼");}
  326. if(PlayerPrefs.HasKey("客戶代號")){PlayerPrefs.DeleteKey("客戶代號");}
  327. if(PlayerPrefs.HasKey("副電表編號")){PlayerPrefs.DeleteKey("副電表編號");}
  328. 彈跳_pl.SetActive(true);
  329. 彈跳文字_tb.text="已回復原廠設定,請重新開啟APP";
  330. Global.彈跳狀態="回原廠成功";
  331. }
  332. private void 取得電表資料資料庫(){
  333. SQL_ele_sys.SQL_電表資料資料庫(Global.客戶代號);
  334. DataSet ds1 = new();
  335. SQL_Module.da.Fill(ds1);
  336. Global.電表資料資料庫清單=ds1.Tables[0];
  337. }
  338. private void 刷新排碳係數(){
  339. for(int i=0;i<=Global.排碳係數表.Rows.Count-1;i++){
  340. if(Global.排碳係數表.Rows[i][0].ToString()==排碳_年_cb.options[排碳_年_cb.value].text){
  341. 排碳係數_lb.text=Global.排碳係數表.Rows[i][1].ToString();
  342. }else{
  343. 排碳係數_lb.text=Global.排碳係數表.Rows[0][1].ToString();
  344. }
  345. }
  346. 排碳最新係數_lb.text = Global.排碳係數表.Rows[0][0].ToString();
  347. }
  348. public void 切換排碳時間(){
  349. if(已開啟){
  350. string 排碳時間選擇="月";
  351. if(排碳_月_cb.value==0 && 排碳_日_cb.value==0){
  352. 排碳時間選擇="月";
  353. }else if(排碳_月_cb.value !=0 && 排碳_日_cb.value==0){
  354. 排碳時間選擇="日";
  355. }else if(排碳_月_cb.value !=0 && 排碳_日_cb.value!=0){
  356. 排碳時間選擇="小時";
  357. }
  358. Moudle.載入日期(2,排碳_年_cb,排碳_月_cb,排碳_日_cb);
  359. 計算排碳(排碳時間選擇);
  360. }
  361. }
  362. private void 計算排碳(string 排碳時間選擇){
  363. //讀取_pl.SetActive(true);
  364. string 電表編號 = 副電表編號_tb.text;
  365. int 電表id=0;
  366. string 流水號=取得流水號(副電表編號_tb.text);string 電表編號改="";string 電表迴路="";
  367. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  368. if(Global.電表資料清單.Rows[i][0].ToString().Contains(流水號)){
  369. 電表id=i;
  370. 電表編號改 = Global.電表資料清單.Rows[i][3].ToString();
  371. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  372. }
  373. }
  374. string p;if(電表迴路=="迴路1"){p="P1";}else{p="P2";}
  375. int N_year =int.Parse(排碳_年_cb.options[排碳_年_cb.value].text);
  376. int N_month = 排碳_月_cb.GetComponent<TMP_Dropdown>().value;
  377. int N_day = 排碳_日_cb.GetComponent<TMP_Dropdown>().value;
  378. List<string> TimeData = new(){"01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","24","25","26","27","28","29","30","31"};
  379. DataTable ds3 = new();
  380. float 排碳度數總和 = 0;
  381. if(排碳時間選擇=="小時"){
  382. ds3.Columns.Add("小時",typeof(string));ds3.Columns.Add("度數",typeof(string));
  383. }else if(排碳時間選擇=="日"){
  384. ds3.Columns.Add("日期",typeof(string));ds3.Columns.Add("度數",typeof(string));
  385. }else{
  386. ds3.Columns.Add("月份",typeof(string));ds3.Columns.Add("度數",typeof(string));
  387. }
  388. bool 有無 = 資料庫判斷(N_year.ToString());
  389. if(有無 && 流水號!=null){
  390. List<string> 清單 = 資料庫明細(N_year.ToString());
  391. string SQL語法="SELECT ";
  392. if(排碳時間選擇=="小時"){
  393. for(int n=0;n<=23;n++){
  394. string 開始時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"0000";
  395. string 結束時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"5959";
  396. for(int j=0;j<=清單.Count-1;j++){
  397. if(Global.資料來源=="PLC"){
  398. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  399. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  400. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  401. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  402. }else{
  403. SQL語法+="(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p +@" AS FLOAT)) AS 度
  404. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  405. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  406. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  407. }
  408. }
  409. }
  410. }else if(排碳時間選擇=="日"){
  411. for(int n=1;n<=DateTime.DaysInMonth(N_year,N_month);n++){
  412. string 開始時間=N_year.ToString()+N_month.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"000000";
  413. string 結束時間=N_year.ToString()+N_month.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"235959";
  414. for(int j=0;j<=清單.Count-1;j++){
  415. if(Global.資料來源=="PLC"){
  416. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  417. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  418. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  419. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  420. }else{
  421. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p +@" AS FLOAT)) AS 度
  422. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  423. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  424. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  425. }
  426. }
  427. }
  428. }else{
  429. for(int n=0;n<=Global.月份Options_中.Count-1;n++){
  430. string 開始時間=N_year.ToString()+(n+1).ToString().PadLeft(2,'0')+"01000000";
  431. string 結束時間=N_year.ToString()+(n+1).ToString().PadLeft(2,'0')+"31235959";
  432. for(int j=0;j<=清單.Count-1;j++){
  433. if(Global.資料來源=="PLC"){
  434. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  435. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  436. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  437. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  438. }else{
  439. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p +@" AS FLOAT)) AS 度
  440. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  441. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  442. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  443. }
  444. }
  445. }
  446. }
  447. SQL語法 = SQL語法[..^",".Length];
  448. SQL_ele_sys.SQL_載入區間表格_月_改(SQL語法);
  449. if(SQL_Module.dr.Read()){
  450. if(排碳時間選擇=="小時"){
  451. for(int n=0;n<=23;n++){
  452. DataRow row = ds3.NewRow();
  453. row["小時"] =n.ToString().PadLeft(2,'0');
  454. float 度數=0;
  455. for(int s=0;s<=SQL_Module.dr.FieldCount-1;s++){
  456. string colname = SQL_Module.dr.GetName(s);
  457. if(int.Parse(colname.Substring(3,2))==n){
  458. if(SQL_Module.dr[s].ToString()!=""){
  459. 度數 += float.Parse(SQL_Module.dr[s].ToString());
  460. }
  461. }
  462. }
  463. if(Global.電表功率單位[電表id] == "W"){
  464. row["度數"] = (度數 / 1000).ToString("#,##0.##");
  465. 排碳度數總和 += 度數 / 1000;
  466. }else{
  467. row["度數"] = 度數.ToString("#,##0.##");
  468. 排碳度數總和 += 度數;
  469. }
  470. ds3.Rows.Add(row);
  471. }
  472. }else if(排碳時間選擇=="日"){
  473. for(int n=0;n<=DateTime.DaysInMonth(N_year,N_month)-1;n++){
  474. DataRow row = ds3.NewRow();
  475. row["日期"] =TimeData[n];
  476. float 度數=0;
  477. for(int s=0;s<=SQL_Module.dr.FieldCount-1;s++){
  478. string colname = SQL_Module.dr.GetName(s);
  479. if(int.Parse(colname.Substring(3,2))==n+1){
  480. if(SQL_Module.dr[s].ToString()!=""){
  481. 度數 += float.Parse(SQL_Module.dr[s].ToString());
  482. }
  483. }
  484. }
  485. if(Global.電表功率單位[電表id] == "W"){
  486. row["度數"] = (度數 / 1000).ToString("#,##0.##");
  487. 排碳度數總和 += 度數 / 1000;
  488. }else{
  489. row["度數"] = 度數.ToString("#,##0.##");
  490. 排碳度數總和 += 度數;
  491. }
  492. ds3.Rows.Add(row);
  493. }
  494. }else{
  495. for(int n=0;n<=Global.月份Options_中.Count-1;n++){
  496. DataRow row = ds3.NewRow();
  497. row["月份"] = Global.月份Options_中[n];
  498. float 度數=0;
  499. for(int s=0;s<=SQL_Module.dr.FieldCount-1;s++){
  500. string colname = SQL_Module.dr.GetName(s);
  501. if(int.Parse(colname.Substring(3,2))==n){
  502. if(SQL_Module.dr[s].ToString()!=""){
  503. 度數 += float.Parse(SQL_Module.dr[s].ToString());
  504. }
  505. }
  506. }
  507. if(Global.電表功率單位[電表id] == "W"){
  508. row["度數"] = (度數 / 1000).ToString("#,##0.##");
  509. 排碳度數總和 += 度數 / 1000;
  510. }else{
  511. row["度數"] = 度數.ToString("#,##0.##");
  512. 排碳度數總和 += 度數;
  513. }
  514. ds3.Rows.Add(row);
  515. }
  516. }
  517. }
  518. }
  519. 排碳使用度數_lb.text = string.Format("{0:###,##0.##}",排碳度數總和);
  520. float 排碳係數 = float.Parse(排碳係數_lb.text);
  521. float 排碳量 = 排碳係數 * 排碳度數總和;
  522. 排碳量_lb.text = string.Format("{0:###,##0.##}",排碳量);
  523. }
  524. //============================
  525. public void 電能監控系統(){
  526. 電能報表_pl.SetActive(false);詳細電表_pl.SetActive(false);
  527. if(!電能監控系統_pl.activeInHierarchy){電能監控系統_pl.SetActive(true);}
  528. //Global.資料來源 = "PLC";
  529. Global.系統選擇 = "電能監控系統";
  530. 載入電表編號資料();
  531. //載入小電表();
  532. 載入簡易電表();
  533. 載入圖表上限();
  534. Color[] colorr =new Color[3]{new Color(0,0,0,0),new Color(0,0,0,1),new Color(1,1,1,1)};
  535. Color[] colobr =new Color[3]{new Color(0,0,0,0),new Color(1,1,1,1),new Color(0,0,0,1)};
  536. Color fontcolor=colorr[Global.系統主題];
  537. Color color2 = new Color(0.97f, 0.48f, 0.99f, 1f);
  538. Moudle.BarChart_表格設定(chart,fontcolor,color2,false,false,false);
  539. Moudle.BarChart_表格設定(chart2,fontcolor,color2,false,false,false);
  540. Moudle.BarChart_表格設定(電壓_barchart,fontcolor,color2,false,false,false);
  541. Moudle.BarChart_表格設定(電流_barchart,fontcolor,color2,false,false,false);
  542. Moudle.BarChart_表格設定(功率_barchart,fontcolor,color2,false,false,false);
  543. Moudle.LineChart_表格設定(電費_chart,fontcolor,color2,false,true,true);
  544. Moudle.LineChart_表格設定(年用電_chart,fontcolor,color2,false,true,true);
  545. Moudle.BarChart_表格設定(度數_chart,fontcolor,color2,false,true,true);
  546. //載入主電表資料();
  547. /*if(!string.IsNullOrEmpty(Global.電表名稱[1])){
  548. 載入副電表資料(Global.電表名稱[1]);
  549. }
  550. 載入電表異常();
  551. //載入系統主題();
  552. 載入簡易電表資料();
  553. 載入圖表上限();
  554. Color[] colorr =new Color[3]{new Color(0,0,0,0),new Color(0,0,0,1),new Color(1,1,1,1)};
  555. Color[] colobr =new Color[3]{new Color(0,0,0,0),new Color(1,1,1,1),new Color(0,0,0,1)};
  556. Color fontcolor=colorr[Global.系統主題];
  557. Color color2 = new Color(0.97f, 0.48f, 0.99f, 1f);
  558. Moudle.BarChart_表格設定(chart,fontcolor,color2,false,false,false);
  559. Moudle.BarChart_表格設定(chart2,fontcolor,color2,false,false,false);
  560. Moudle.BarChart_表格設定(電壓_barchart,fontcolor,color2,false,false,false);
  561. Moudle.BarChart_表格設定(電流_barchart,fontcolor,color2,false,false,false);
  562. Moudle.BarChart_表格設定(功率_barchart,fontcolor,color2,false,false,false);
  563. Moudle.LineChart_表格設定(電費_chart,fontcolor,color2,false,true,true);
  564. Moudle.LineChart_表格設定(年用電_chart,fontcolor,color2,false,true,true);
  565. Moudle.BarChart_表格設定(度數_chart,fontcolor,color2,false,true,true);*/
  566. }
  567. private void 安全運行天數(){
  568. if(Global.上次更新天數 != DateTime.Now.Day){
  569. DateTime day2 = DateTime.Now;
  570. int dayear, damonth, daday;
  571. if(DateTime.Now.Year > 2023){
  572. dayear = DateTime.Now.Year - 2023;
  573. day2 = day2.AddYears(-dayear);
  574. }
  575. if(DateTime.Now.Month > 1){
  576. damonth = DateTime.Now.Month - 1;
  577. day2 = day2.AddMonths(-damonth);
  578. }
  579. if(DateTime.Now.Day > 1){
  580. daday = DateTime.Now.Day - 1;
  581. day2 = day2.AddDays(-daday);
  582. }
  583. Global.運行天數 = new TimeSpan(DateTime.Now.Ticks - day2.Ticks);
  584. string ddd = Global.運行天數.Days.ToString().PadLeft(5,'0');
  585. 安全運行天數_img[0].sprite = Global.Wnum[int.Parse(ddd.Substring(0,1))];
  586. 安全運行天數_img[1].sprite = Global.Wnum[int.Parse(ddd.Substring(1,1))];
  587. 安全運行天數_img[2].sprite = Global.Wnum[int.Parse(ddd.Substring(2,1))];
  588. 安全運行天數_img[3].sprite = Global.Wnum[int.Parse(ddd.Substring(3,1))];
  589. 安全運行天數_img[4].sprite = Global.Wnum[int.Parse(ddd.Substring(4,1))];
  590. }
  591. }
  592. private void 載入電表編號資料(){
  593. try{
  594. SQL_ele_sys.SQL_電表清單資料(Global.客戶代號);
  595. DataSet ds1 = new();
  596. SQL_Module.da.Fill(ds1);
  597. Global.電表資料清單=ds1.Tables[0];
  598. Global.電表數量 = ds1.Tables[0].Rows.Count;
  599. if(電表編號_tb.text=="PANEL EMVCB#1" && Global.客戶代號 !="GCM"){
  600. 電表編號_tb.text=ds1.Tables[0].Rows[0][1].ToString();
  601. }
  602. if(副電表編號_tb.text=="PANEL EMVCB#1" && Global.客戶代號 !="GCM"){
  603. 副電表編號_tb.text=ds1.Tables[0].Rows[0][1].ToString();
  604. }
  605. for(int i=0;i<=Global.電表數量-1;i++){
  606. Global.電表名稱[i]=ds1.Tables[0].Rows[i][1].ToString();
  607. if(Global.資料來源=="PLC"){
  608. Global.電表功率單位[i]=ds1.Tables[0].Rows[i]["圖表顯示功率"].ToString();
  609. Global.圖表最大電壓[i]=ds1.Tables[0].Rows[i]["圖表顯示電壓"].ToString();
  610. Global.圖表最大電流[i]=ds1.Tables[0].Rows[i]["圖表顯示電流"].ToString();
  611. Global.圖表最大功率[i]=ds1.Tables[0].Rows[i]["圖表最大功率"].ToString();
  612. }else{
  613. Global.電表功率單位[i]=ds1.Tables[0].Rows[i]["功率單位"].ToString();
  614. Global.圖表最大電壓[i]=ds1.Tables[0].Rows[i]["最大電壓"].ToString();
  615. Global.圖表最大電流[i]=ds1.Tables[0].Rows[i]["最大電流"].ToString();
  616. Global.圖表最大功率[i]=ds1.Tables[0].Rows[i]["最大功率"].ToString();
  617. }
  618. }
  619. Global.載入電表名稱Option=false;
  620. }finally{
  621. SQL_Module.conn.Close();
  622. }
  623. }
  624. private void 載入圖表上限(){
  625. if(詳細電表_pl.activeInHierarchy){
  626. Debug.Log(Global.詳細電表電表ID);
  627. 詳V1.maxValue= int.Parse(Global.圖表最大電壓[Global.詳細電表電表ID-1]);
  628. 詳V2.maxValue= int.Parse(Global.圖表最大電壓[Global.詳細電表電表ID-1]);
  629. 詳V3.maxValue= int.Parse(Global.圖表最大電壓[Global.詳細電表電表ID-1]);
  630. 詳I1.maxValue= int.Parse(Global.圖表最大電流[Global.詳細電表電表ID-1]);
  631. 詳I2.maxValue= int.Parse(Global.圖表最大電流[Global.詳細電表電表ID-1]);
  632. 詳I3.maxValue= int.Parse(Global.圖表最大電流[Global.詳細電表電表ID-1]);
  633. 詳V3_lb.text = Global.圖表最大電壓[Global.詳細電表電表ID-1];
  634. 詳V2_lb.text = (float.Parse(Global.圖表最大電壓[Global.詳細電表電表ID-1])/2).ToString("##0") ;
  635. 詳I3_lb.text = Global.圖表最大電流[Global.詳細電表電表ID-1];
  636. 詳I2_lb.text = (float.Parse(Global.圖表最大電流[Global.詳細電表電表ID-1])/2).ToString("##0") ;
  637. 詳S3_lb.text = Global.圖表最大功率[Global.詳細電表電表ID-1];
  638. 詳S2_lb.text = (float.Parse(Global.圖表最大功率[Global.詳細電表電表ID-1])/2).ToString("##0") ;
  639. 詳Q3_lb.text = Global.圖表最大功率[Global.詳細電表電表ID-1];
  640. 詳Q2_lb.text = (float.Parse(Global.圖表最大功率[Global.詳細電表電表ID-1])/2).ToString("##0") ;
  641. 詳P3_lb.text = Global.圖表最大功率[Global.詳細電表電表ID-1];
  642. 詳P2_lb.text = (float.Parse(Global.圖表最大功率[Global.詳細電表電表ID-1])/2).ToString("##0") ;
  643. }else{
  644. Global.上限電表ID1 = Array.IndexOf(Global.電表名稱, 電表編號_tb.text);
  645. Global.上限電表ID2 = Array.IndexOf(Global.電表名稱, 副電表編號_tb.text);
  646. V3_lb.text = Global.圖表最大電壓[Global.上限電表ID1];
  647. V2_lb.text = (float.Parse(Global.圖表最大電壓[Global.上限電表ID1])/2).ToString("##0") ;
  648. I3_lb.text = Global.圖表最大電流[Global.上限電表ID1];
  649. I2_lb.text = (float.Parse(Global.圖表最大電流[Global.上限電表ID1])/2).ToString("##0") ;
  650. 副V3_lb.text = Global.圖表最大電壓[Global.上限電表ID2];
  651. 副V2_lb.text = (float.Parse(Global.圖表最大電壓[Global.上限電表ID2])/2).ToString("##0") ;
  652. 副I3_lb.text = Global.圖表最大電流[Global.上限電表ID2];
  653. 副I2_lb.text = (float.Parse(Global.圖表最大電流[Global.上限電表ID2])/2).ToString("##0") ;
  654. }
  655. }
  656. private void 載入小電表(){
  657. Moudle.清除控件(小電表清單_ct);
  658. int k=0;
  659. int h=0;
  660. for(int i=0;i<=Global.電表數量-1;i++){
  661. GameObject header = Instantiate(小電表清單_rpf, 小電表清單_tp);
  662. TextMeshProUGUI ele_text = new GameObject("ele_"+i+"_tb").AddComponent<TextMeshProUGUI>();
  663. if (i % 2 == 1){
  664. header.transform.localPosition=new Vector3(6,-10-(140*(k)),0);
  665. k+=1;
  666. }else{
  667. header.transform.localPosition = new Vector3(394, -10 - (140 * (h)), 0);
  668. h+=1;
  669. }
  670. header.AddComponent<Image>().type=Image.Type.Sliced;
  671. header.GetComponent<Image>().sprite=UIsprite;
  672. header.name="小電表_"+i.ToString();
  673. header.GetComponent<Image>().fillCenter=false;
  674. header.GetComponent<Image>().color = new Color(1f,1f,1f,1f);
  675. //header.AddComponent<Button>().onClick.AddListener(() => { 按鈕事件(ele_text); });
  676. Image ele_img = new GameObject("ele_"+i+"_pic").AddComponent<Image>();
  677. ele_img.transform.SetParent(header.transform, false);
  678. ele_img.sprite=控件圖片[3];
  679. ele_img.transform.localPosition = new Vector3(65f,-63f,0f);
  680. string[] title=new string[4]{"R","S","T","N"};
  681. float[] x_data=new float[4]{-25.0756f,-8.5f,8f,24.6f};
  682. for(int j=0;j<=3;j++){
  683. Image Color_img = new GameObject(title[j]+"_"+i+"_pic").AddComponent<Image>();
  684. Color_img.transform.SetParent(ele_img.transform, false);
  685. Color_img.color=new Color(0.05633092f,0.745283f,0.02460841f,1f);
  686. Color_img.transform.localPosition=new Vector3(x_data[j],19.39892f,0);
  687. Color_img.GetComponent<RectTransform>().sizeDelta = new Vector2(13.1166f, 22.0985f);
  688. }
  689. Color[] colorr =new Color[3]{new Color(0,0,0,0),new Color(0,0,0,1),new Color(1,1,1,1)};
  690. Color fontcolor=colorr[Global.系統主題];
  691. ele_text.transform.SetParent(header.transform, false);
  692. ele_text.transform.localPosition = new Vector3(250f,-63f,0f);
  693. ele_text.rectTransform.sizeDelta = new Vector2(246f, 100f);
  694. ele_text.font = myFont;
  695. ele_text.color=fontcolor;
  696. ele_text.alignment = TextAlignmentOptions.Center;
  697. ele_text.fontStyle = FontStyles.Bold;
  698. ele_text.fontSize=30;
  699. ele_text.enableAutoSizing=true;
  700. ele_text.text=Global.電表名稱[i].ToString();
  701. }
  702. int 電表數量 = Global.電表數量-1;
  703. int 商數 = 電表數量 / 2;
  704. int 餘數 = 電表數量 % 2;
  705. int 結果 = 商數 + (餘數 > 0 ? 1 : 0);
  706. 小電表清單_ct.GetComponent<RectTransform>().sizeDelta = new Vector2(小電表清單_ct.GetComponent<RectTransform>().sizeDelta.x,145*結果);
  707. }
  708. private void 載入簡易電表(){
  709. Moudle.清除控件(簡易電表清單_ct);
  710. int[] Vector2X = new int[4] {100,319,180,180};
  711. int[] Vector3X = new int[5] {0,100,419,599,779};
  712. string[] HeaderString = new string[4]{"","電表名稱","電壓","電流"};
  713. string[] CellName = new string[4]{"","Name","V","I"};
  714. for(int j=1;j<=3;j++){
  715. GameObject header = Instantiate(簡易電表清單_rpf, 簡易電表清單_tp);
  716. TextMeshProUGUI ele_text = new GameObject("easyHeader_"+j+"_tb").AddComponent<TextMeshProUGUI>();
  717. header.transform.localPosition=new Vector3(Vector3X[j],0,0);
  718. header.GetComponent<RectTransform>().sizeDelta = new Vector2(Vector3X[j+1]-Vector3X[j],70);
  719. header.AddComponent<Image>().type=Image.Type.Sliced;
  720. header.GetComponent<Image>().sprite=UIsprite;
  721. header.GetComponent<Image>().fillCenter=false;
  722. header.GetComponent<Image>().color = new Color(1f,1f,1f,1f);
  723. Color[] colorr =new Color[3]{new Color(0,0,0,0),new Color(0,0,0,1),new Color(1,1,1,1)};
  724. Color fontcolor=colorr[Global.系統主題];
  725. ele_text.transform.SetParent(header.transform, false);
  726. ele_text.rectTransform.anchoredPosition = new Vector3(0f,0f,0f);
  727. ele_text.rectTransform.sizeDelta = new Vector2(Vector2X[j], 70f);
  728. ele_text.font = myFont;
  729. ele_text.color=fontcolor;
  730. ele_text.alignment = TextAlignmentOptions.Center;
  731. ele_text.fontStyle = FontStyles.Bold;
  732. ele_text.fontSize=36;
  733. ele_text.margin = new Vector4(10, 5, 10, 5);
  734. ele_text.text=HeaderString[j];
  735. }
  736. for(int i=0;i<=Global.電表數量-1;i++){
  737. GameObject header = Instantiate(簡易電表清單_rpf, 簡易電表清單_tp);
  738. Image ele_img = new GameObject("easyChild_pic_"+i.ToString().PadLeft(8,'0')).AddComponent<Image>();
  739. ele_img.rectTransform.sizeDelta = new Vector2(90, 90);
  740. ele_img.transform.SetParent(header.transform, false);
  741. ele_img.sprite=控件圖片[3];
  742. ele_img.transform.localPosition = new Vector3(106.1107f,-50f,0f);
  743. header.transform.localPosition=new Vector3(Vector3X[0],-70-(100*i),0);
  744. header.GetComponent<RectTransform>().sizeDelta = new Vector2(Vector3X[1]-Vector3X[0],100);
  745. header.AddComponent<Image>().type=Image.Type.Sliced;
  746. header.GetComponent<Image>().sprite=UIsprite;
  747. header.GetComponent<Image>().fillCenter=false;
  748. header.GetComponent<Image>().color = new Color(1f,1f,1f,1f);
  749. header.AddComponent<Button>().onClick.AddListener(() => { 按鈕事件(ele_img.name); });
  750. for(int j=1;j<=3;j++){
  751. header = Instantiate(簡易電表清單_rpf, 簡易電表清單_tp);
  752. TextMeshProUGUI ele_text = new GameObject("easyChild_"+CellName[j]+"_tb_"+i.ToString().PadLeft(8,'0')).AddComponent<TextMeshProUGUI>();
  753. header.transform.localPosition=new Vector3(Vector3X[j],-70-(100*i),0);
  754. header.GetComponent<RectTransform>().sizeDelta = new Vector2(Vector3X[j+1]-Vector3X[j],100);
  755. header.AddComponent<Image>().type=Image.Type.Sliced;
  756. header.GetComponent<Image>().sprite=UIsprite;
  757. header.GetComponent<Image>().fillCenter=false;
  758. header.GetComponent<Image>().color = new Color(1f,1f,1f,1f);
  759. header.AddComponent<Button>().onClick.AddListener(() => { 按鈕事件(ele_text.name);});
  760. Color[] colorr =new Color[3]{new (0,0,0,0),new (0,0,0,1),new (1,1,1,1)};
  761. Color fontcolor=colorr[Global.系統主題];
  762. ele_text.transform.SetParent(header.transform, false);
  763. ele_text.transform.localPosition = new Vector3(Vector2X[j]/2f,-50f,0f);
  764. ele_text.rectTransform.sizeDelta = new Vector2(Vector2X[j], 100f);
  765. ele_text.font = myFont;
  766. ele_text.color=fontcolor;
  767. ele_text.alignment = TextAlignmentOptions.Center;
  768. ele_text.fontStyle = FontStyles.Bold;
  769. ele_text.fontSize=36;
  770. ele_text.margin = new Vector4(10, 5, 10, 5);
  771. ele_text.text=HeaderString[j];
  772. }
  773. }
  774. 簡易電表清單_ct.GetComponent<RectTransform>().sizeDelta = new Vector2(小電表清單_ct.GetComponent<RectTransform>().sizeDelta.x,100*Global.電表數量+70);
  775. }
  776. private void 載入主電表資料(){
  777. string 流水號="";string 電表編號="";string 電表迴路="";
  778. if(Global.資料來源=="PLC"){
  779. 流水號 = 電表編號_tb.text;
  780. }else{
  781. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  782. if(Global.電表資料清單.Rows[i][0].ToString().Contains("EL-00000001")){
  783. 流水號 = Global.電表資料清單.Rows[i][0].ToString();
  784. 電表編號 = Global.電表資料清單.Rows[i][3].ToString();
  785. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  786. 電表編號_tb.text = Global.電表資料清單.Rows[i][1].ToString();
  787. }
  788. }
  789. }
  790. Global.PA = 電表編號_tb.text;
  791. if(Global.主電表上次編號 != Global.PA){
  792. Global.主電表上次編號 = Global.PA ;
  793. Global.電表ID1 = Array.IndexOf(Global.電表名稱, Global.PA)+1;
  794. }
  795. if(Global.PHP_Load_End_電表即時路徑){
  796. 電表資料(Global.電表ID1,電表編號,電表迴路);
  797. //Debug.Log(Global.Vavg);Debug.Log(Global.Iavg);
  798. 平均電壓_tb.text = Global.Vavg + " V";
  799. 平均電流_tb.text = Global.Iavg + " A";
  800. 累計用電量_tb.text = Global.Etol + " GWh";
  801. }
  802. if(Global.paint_choice2){
  803. Global.paint_choice2=false;
  804. 繪圖(chart,流水號,電表編號,電表迴路);
  805. }
  806. }
  807. private void 載入副電表資料(){
  808. string 流水號;string 電表編號="";string 電表迴路="";
  809. if(Global.資料來源=="PLC"){
  810. 流水號=副電表編號_tb.text;
  811. }else{
  812. 流水號=取得流水號(副電表編號_tb.text);
  813. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  814. if(Global.電表資料清單.Rows[i][0].ToString().Contains(流水號)){
  815. 電表編號 = Global.電表資料清單.Rows[i][3].ToString();
  816. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  817. }
  818. }
  819. }
  820. Global.PA = 副電表編號_tb.text; //副電表編號_tb.text = Global.PA;
  821. if(Global.副電表上次編號 != Global.PA){
  822. Global.副電表上次編號 = Global.PA ;
  823. Global.電表ID2 = Array.IndexOf(Global.電表名稱, Global.PA)+1;
  824. }
  825. if(Global.PHP_Load_End_電表即時路徑){
  826. 電表資料(Global.電表ID2,電表編號,電表迴路);
  827. 副平均電壓_tb.text = Global.Vavg + " V";
  828. 副平均電流_tb.text = Global.Iavg + " A";
  829. 副累計用電量_tb.text = Global.Etol + " GWh";
  830. }
  831. if(Global.paint_choice3){
  832. Global.paint_choice3=false;
  833. 繪圖(chart2,流水號,電表編號,電表迴路);
  834. }
  835. }
  836. public void Open_detail(int num){
  837. 詳細電表_pl.SetActive(true);
  838. adMobManager.HideBanner();
  839. string 流水號, 電表編號="",電表迴路="";
  840. if(num==0){
  841. Global.詳細電表電表ID=Global.電表ID1;
  842. Global.PA=電表編號_tb.text;
  843. 流水號=電表編號_tb.text;
  844. }else{
  845. Global.詳細電表電表ID=Global.電表ID2;
  846. Global.PA=副電表編號_tb.text;
  847. 流水號=副電表編號_tb.text;
  848. }
  849. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  850. if(Global.電表資料清單.Rows[i][0].ToString().Contains(流水號)){
  851. 電表編號 = Global.電表資料清單.Rows[i][3].ToString();
  852. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  853. }
  854. }
  855. 載入詳細電表資料();
  856. 載入圖表上限();
  857. 三合一繪圖(流水號,電表編號,電表迴路);
  858. }
  859. public void close_detail(){
  860. 電能監控系統();
  861. }
  862. private void 載入詳細電表資料(){
  863. string 電表編號="";string 電表迴路="";
  864. if(Global.資料來源=="PLC" && Global.PHP_Load_End){
  865. 電表資料(Global.詳細電表電表ID,電表編號,電表迴路);
  866. 詳細平均電壓_tb.text=Global.Vavg + " V";
  867. 詳細平均電流_tb.text=Global.Iavg + " A";
  868. }else{
  869. string 流水號 = 取得流水號(Global.電表名稱[Global.詳細電表電表ID]);
  870. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  871. if(Global.電表資料清單.Rows[i][0].ToString().Contains(流水號)){
  872. 電表編號 = Global.電表資料清單.Rows[i][3].ToString();
  873. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  874. }
  875. }
  876. 電表資料(Global.詳細電表電表ID,電表編號,電表迴路);
  877. 詳細平均電壓_tb.text=Global.Vavg + " V";
  878. 詳細平均電流_tb.text=Global.Iavg + " A";
  879. }
  880. }
  881. private void 載入電表異常(){
  882. if(Global.資料來源=="PLC" && Global.PHP_Load_End2){
  883. string ele_code = Global.PHP_Report2;
  884. //Debug.Log(ele_code.Length);
  885. if(ele_code.Length > 1){
  886. for(int b=0;b<=Global.電表數量;b++){
  887. if(ele_code.Substring(2*b,1)=="1"){
  888. Global.電表異常BL[b+1]=true;
  889. 電表異常(b);
  890. if((b+1)==Global.電表ID1){
  891. if(主跑馬燈_pl.activeInHierarchy==false){
  892. 主跑馬燈_pl.SetActive(true);
  893. }
  894. if(主電力警報音效_bt.activeInHierarchy==false){
  895. 主電力警報音效_bt.SetActive(true);
  896. }
  897. }else if((b+1)==Global.電表ID2){
  898. Global.副電表有異常=true;
  899. if(副跑馬燈_pl.activeInHierarchy==false){
  900. 副跑馬燈_pl.SetActive(true);
  901. }
  902. if(副電力警報音效_bt.activeInHierarchy==false){
  903. 副電力警報音效_bt.SetActive(true);
  904. }
  905. if(Global.Ele_alarm_sound==true){
  906. Button bmt=副電力警報音效_bt.GetComponent<Button>();
  907. bmt.image.sprite=控件圖片[1];
  908. }else{
  909. Button bmt=副電力警報音效_bt.GetComponent<Button>();
  910. bmt.image.sprite=控件圖片[2];
  911. }
  912. }
  913. }else{
  914. Global.電表異常BL[b+1]=false;
  915. if((b+1)==Global.電表ID1){
  916. if(主跑馬燈_pl.activeInHierarchy==true){
  917. 主跑馬燈_pl.SetActive(false);
  918. }
  919. if(主電力警報音效_bt.activeInHierarchy==true){
  920. 主電力警報音效_bt.SetActive(false);
  921. }
  922. Global.主電表上次異常內容="";
  923. }else if((b+1)==Global.電表ID2){
  924. Global.副電表有異常=false;
  925. if(副跑馬燈_pl.activeInHierarchy==true){
  926. 副跑馬燈_pl.SetActive(false);
  927. }
  928. if(副電力警報音效_bt.activeInHierarchy==true){
  929. 副電力警報音效_bt.SetActive(false);
  930. }
  931. Global.副電表上次異常內容="";
  932. }
  933. foreach (Image pic in 小電表清單_ct.GetComponentsInChildren<Image>()){
  934. if(pic.name.Contains("R_"+(b).ToString())){
  935. pic.color=new Color(0.05633092f,0.745283f,0.02460841f,1f);
  936. }
  937. }
  938. foreach (Image pic in 小電表清單_ct.GetComponentsInChildren<Image>()){
  939. if(pic.name.Contains("S_"+(b).ToString())){
  940. pic.color=new Color(0.05633092f,0.745283f,0.02460841f,1f);
  941. }
  942. }
  943. foreach (Image pic in 小電表清單_ct.GetComponentsInChildren<Image>()){
  944. if(pic.name.Contains("T_"+(b).ToString())){
  945. pic.color=new Color(0.05633092f,0.745283f,0.02460841f,1f);
  946. }
  947. }
  948. }
  949. }
  950. }
  951. for(int k=1;k<=Global.電表數量;k++){
  952. if(Global.電表異常BL[k]==true && k!= Global.電表ID1 && k != Global.電表ID2){
  953. Global.PK= k.ToString();
  954. Global.PA=Global.電表名稱[k-1];
  955. 載入副電表資料();
  956. Global.paint_choice3 = true;
  957. }
  958. }
  959. }
  960. }
  961. private void 電表異常(int ele_num){
  962. //RDS M3100 20\r
  963. //StartCoroutine(PostRequest(8,"RDS M"+(3000+ele_num*100).ToString()+" 20\r"));
  964. //Debug.Log("ELE_DATAA:"+ele_data);
  965. }
  966. private void 載入簡易電表資料(){
  967. if(簡易電表_pl.activeInHierarchy==true){
  968. if(Global.資料來源=="PLC"){
  969. string[] PLC_data = new string[]{Global.PHP_Report,Global.PHP_Report3,Global.PHP_Report4,Global.PHP_Report5,Global.PHP_Report6,Global.PHP_Report7,Global.PHP_Report8};
  970. for(int i=0;i<=Global.電表數量-1;i++){
  971. string data1 =PLC_data[i];
  972. string a,b;
  973. a=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(114, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(108, 5)), 2).PadLeft(16, '0'));
  974. b=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(66, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(60, 5)), 2).PadLeft(16, '0'));
  975. TextMeshProUGUI ele_text=null,ele_text2=null,ele_text3=null;
  976. foreach (TextMeshProUGUI textComponent in 簡易電表_pl.GetComponentsInChildren<TextMeshProUGUI>()){
  977. if (textComponent.name=="easyChild_V_tb_"+i.ToString().PadLeft(8,'0')){
  978. ele_text = textComponent;
  979. break;
  980. }
  981. }
  982. if (ele_text != null){
  983. ele_text.text= a;
  984. }
  985. foreach (TextMeshProUGUI textComponent in 簡易電表_pl.GetComponentsInChildren<TextMeshProUGUI>()){
  986. if (textComponent.name=="easyChild_I_tb_"+i.ToString().PadLeft(8,'0')){
  987. ele_text2 = textComponent;
  988. break;
  989. }
  990. }
  991. if (ele_text2 != null){
  992. ele_text2.text= b;
  993. }
  994. foreach (TextMeshProUGUI textComponent in 簡易電表_pl.GetComponentsInChildren<TextMeshProUGUI>()){
  995. if (textComponent.name=="easyChild_Name_tb_"+i.ToString().PadLeft(8,'0')){
  996. ele_text3 = textComponent;
  997. break;
  998. }
  999. }
  1000. if (ele_text3 != null){
  1001. ele_text3.text= Global.電表名稱[i];
  1002. }
  1003. }
  1004. }else{
  1005. if(Global.PHP_Load_End_電表即時路徑){
  1006. for(int i=0;i<=Global.電表數量-1;i++){
  1007. string a,b;
  1008. string[] data1 = Global.電表即時資料字典[Global.電表資料清單.Rows[i][3].ToString()];
  1009. a=(float.Parse(data1[3])/10).ToString();
  1010. if( Global.電表資料清單.Rows[i][4].ToString()=="迴路1"){
  1011. b=(float.Parse(data1[4])/100 + float.Parse(data1[5])/100).ToString();
  1012. }else{
  1013. b=(float.Parse(data1[6])/100 + float.Parse(data1[7])/100).ToString();
  1014. }
  1015. TextMeshProUGUI ele_text=null,ele_text2=null,ele_text3=null;
  1016. foreach (TextMeshProUGUI textComponent in 簡易電表_pl.GetComponentsInChildren<TextMeshProUGUI>()){
  1017. if (textComponent.name=="easyChild_V_tb_"+i.ToString().PadLeft(8,'0')){
  1018. ele_text = textComponent;
  1019. break;
  1020. }
  1021. }
  1022. if (ele_text != null){
  1023. ele_text.text= a;
  1024. }
  1025. foreach (TextMeshProUGUI textComponent in 簡易電表_pl.GetComponentsInChildren<TextMeshProUGUI>()){
  1026. if (textComponent.name=="easyChild_I_tb_"+i.ToString().PadLeft(8,'0')){
  1027. ele_text2 = textComponent;
  1028. break;
  1029. }
  1030. }
  1031. if (ele_text2 != null){
  1032. ele_text2.text= b;
  1033. }
  1034. foreach (TextMeshProUGUI textComponent in 簡易電表_pl.GetComponentsInChildren<TextMeshProUGUI>()){
  1035. if (textComponent.name=="easyChild_Name_tb_"+i.ToString().PadLeft(8,'0')){
  1036. ele_text3 = textComponent;
  1037. break;
  1038. }
  1039. }
  1040. if (ele_text3 != null){
  1041. ele_text3.text= Global.電表名稱[i];
  1042. }
  1043. }
  1044. }
  1045. }
  1046. }
  1047. }
  1048. public void 切換簡易電表(){
  1049. if(簡易電表_pl.activeInHierarchy){
  1050. 簡易電表_pl.SetActive(false);
  1051. 小電表_pl.SetActive(true);
  1052. }else{
  1053. 簡易電表_pl.SetActive(true);
  1054. 小電表_pl.SetActive(false);
  1055. }
  1056. }
  1057. private void 電表資料(int num,string 電表編號,string 電表迴路){
  1058. if(Global.資料來源=="PLC" && Global.PHP_Load_End){
  1059. int index = num-1;
  1060. string[] PLC_data = new string[]{Global.PHP_Report,Global.PHP_Report3,Global.PHP_Report4,Global.PHP_Report5,Global.PHP_Report6,Global.PHP_Report7,Global.PHP_Report8};
  1061. string data1=PLC_data[index];
  1062. string[] EtolStr = new string[]{"5.83", "2.83", "1.02", "1.01", "0.54", "0.31", "0.12"};
  1063. Global.Etol = EtolStr[index];
  1064. if(data1.Length != 0){
  1065. Global.Vavg=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(114, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(108, 5)), 2).PadLeft(16, '0'));
  1066. Global.Iavg=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(66, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(60, 5)), 2).PadLeft(16, '0'));
  1067. if(詳細電表_pl.activeInHierarchy){
  1068. 詳細電流A相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(6, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(0, 5)), 2).PadLeft(16, '0'))+ " A";
  1069. 詳細電流B相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(18, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(12, 5)), 2).PadLeft(16, '0'))+ " A";
  1070. 詳細電流C相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(30, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(24, 5)), 2).PadLeft(16, '0'))+ " A";
  1071. 詳細電壓AB相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(78, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(72, 5)), 2).PadLeft(16, '0'))+ " V";
  1072. 詳細電壓BC相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(90, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(84, 5)), 2).PadLeft(16, '0'))+ " V";
  1073. 詳細電壓CA相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(102, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(96, 5)), 2).PadLeft(16, '0'))+ " V";
  1074. 詳細電流不平衡A相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(174, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(168, 5)), 2).PadLeft(16, '0'))+ " A";
  1075. 詳細電流不平衡B相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(186, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(180, 5)), 2).PadLeft(16, '0'))+ " A";
  1076. 詳細電流不平衡C相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(198, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(192, 5)), 2).PadLeft(16, '0'))+ " A";
  1077. 詳細電壓不平衡AB相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(222, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(216, 5)), 2).PadLeft(16, '0'))+ " V";
  1078. 詳細電壓不平衡BC相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(234, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(228, 5)), 2).PadLeft(16, '0')) + " V";
  1079. 詳細電壓不平衡CA相_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(246, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(240, 5)), 2).PadLeft(16, '0')) + " V";
  1080. 詳細平均有效功率_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(354, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(348, 5)), 2).PadLeft(16, '0'))+ " "+Global.電表功率單位[Global.詳細電表電表ID-1];
  1081. 詳細平均無效功率_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(402, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(396, 5)), 2).PadLeft(16, '0'))+ " "+Global.電表功率單位[Global.詳細電表電表ID-1];
  1082. 詳細平均視在功率_tb.text=Converter_we.BintoSng(Convert.ToString(Int32.Parse(data1.Substring(450, 5)), 2).PadLeft(16, '0') + Convert.ToString(Int32.Parse(data1.Substring(444, 5)), 2).PadLeft(16, '0'))+ " "+Global.電表功率單位[Global.詳細電表電表ID-1];
  1083. }
  1084. }else{
  1085. Global.Vavg="0";
  1086. Global.Iavg="0";
  1087. 詳細電流A相_tb.text="0";
  1088. 詳細電流B相_tb.text="0";
  1089. 詳細電流C相_tb.text="0";
  1090. 詳細電壓AB相_tb.text="0";
  1091. 詳細電壓BC相_tb.text="0";
  1092. 詳細電壓CA相_tb.text="0";
  1093. 詳細電流不平衡A相_tb.text="0";
  1094. 詳細電流不平衡B相_tb.text="0";
  1095. 詳細電流不平衡C相_tb.text="0";
  1096. 詳細電壓不平衡AB相_tb.text="0";
  1097. 詳細電壓不平衡BC相_tb.text="0";
  1098. 詳細電壓不平衡CA相_tb.text="0";
  1099. 詳細平均有效功率_tb.text="0";
  1100. 詳細平均無效功率_tb.text="0";
  1101. 詳細平均視在功率_tb.text="0";
  1102. }
  1103. }else{
  1104. if(Global.電表即時資料字典.ContainsKey(電表編號)){
  1105. string[] data1 = Global.電表即時資料字典[電表編號];
  1106. if(電表迴路=="迴路1"){
  1107. Global.Etol = data1[32] + " kWh";
  1108. Global.Vavg=(float.Parse(data1[3])/10).ToString();
  1109. //Debug.Log(data1[4]);Debug.Log(data1[5]);
  1110. Global.Iavg=(float.Parse(data1[4])/100 + float.Parse(data1[5])/100).ToString();
  1111. if(詳細電表_pl.activeInHierarchy){
  1112. 詳細電流A相_tb.text=(float.Parse(data1[4])/100).ToString()+ " A";
  1113. 詳細電流B相_tb.text=(float.Parse(data1[5])/100).ToString()+ " A";
  1114. 詳細電流C相_tb.text="0 A";
  1115. 詳細電壓AB相_tb.text=(float.Parse(data1[1])/10).ToString()+ " V";
  1116. 詳細電壓BC相_tb.text=(float.Parse(data1[2])/10).ToString()+ " V";
  1117. 詳細電壓CA相_tb.text="0 V";
  1118. 詳細電流不平衡A相_tb.text="0 V";
  1119. 詳細電流不平衡B相_tb.text="0 V";
  1120. 詳細電流不平衡C相_tb.text="0 V";
  1121. 詳細電壓不平衡AB相_tb.text="0 V";
  1122. 詳細電壓不平衡BC相_tb.text="0 V";
  1123. 詳細電壓不平衡CA相_tb.text="0 V";
  1124. }
  1125. }else{
  1126. Global.Etol = data1[34] + " kWh";
  1127. Global.Vavg=(float.Parse(data1[3])/10).ToString();
  1128. //Debug.Log(data1[4]);Debug.Log(data1[5]);
  1129. Global.Iavg=(float.Parse(data1[6])/100 + float.Parse(data1[7])/100).ToString();
  1130. if(詳細電表_pl.activeInHierarchy){
  1131. 詳細電流A相_tb.text=(float.Parse(data1[6])/100).ToString()+ " A";
  1132. 詳細電流B相_tb.text=(float.Parse(data1[7])/100).ToString()+ " A";
  1133. 詳細電流C相_tb.text="0 A";
  1134. 詳細電壓AB相_tb.text=(float.Parse(data1[1])/10).ToString()+ " V";
  1135. 詳細電壓BC相_tb.text=(float.Parse(data1[2])/10).ToString()+ " V";
  1136. 詳細電壓CA相_tb.text="0 V";
  1137. 詳細電流不平衡A相_tb.text="0 V";
  1138. 詳細電流不平衡B相_tb.text="0 V";
  1139. 詳細電流不平衡C相_tb.text="0 V";
  1140. 詳細電壓不平衡AB相_tb.text="0 V";
  1141. 詳細電壓不平衡BC相_tb.text="0 V";
  1142. 詳細電壓不平衡CA相_tb.text="0 V";
  1143. }
  1144. }
  1145. }else{
  1146. Global.Etol="0";Global.Vavg="0";Global.Iavg="0";詳細電流A相_tb.text="0";詳細電流B相_tb.text="0";詳細電流C相_tb.text="0";詳細電壓AB相_tb.text="0";
  1147. 詳細電壓BC相_tb.text="0";詳細電壓CA相_tb.text="0";詳細電流不平衡A相_tb.text="0";詳細電流不平衡B相_tb.text="0";詳細電流不平衡C相_tb.text="0";
  1148. 詳細電壓不平衡AB相_tb.text="0";詳細電壓不平衡BC相_tb.text="0";詳細電壓不平衡CA相_tb.text="0";詳細平均有效功率_tb.text="0";詳細平均無效功率_tb.text="0";
  1149. 詳細平均視在功率_tb.text="0";
  1150. }
  1151. }
  1152. }
  1153. private void 繪圖(BarChart barchart,string 電表流水號,string 電表編號,string 電表迴路){
  1154. DataSet ds1= new DataSet();
  1155. barchart.ClearData();
  1156. DateTime day2 = DateTime.Now.AddDays(-30);
  1157. string 開始時間= day2.ToString("yyyyMMdd");
  1158. string 結束時間= DateTime.Now.ToString("yyyyMMdd");
  1159. string SQL語法;
  1160. if(Global.資料來源=="PLC"){
  1161. SQL語法=" SELECT DISTINCT 時間_年 , 時間_月 , 時間_日 ,AVG(CONVERT(float,總平均功率)) FROM (";
  1162. if(day2.Year!=DateTime.Now.Year){
  1163. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1164. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1165. SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1166. WHERE (電表編號 LIKE N'" + 電表流水號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1167. UNION ALL";
  1168. }
  1169. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(day2.Year.ToString())){
  1170. SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1171. WHERE (電表編號 LIKE N'" + 電表流水號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1172. UNION ALL";
  1173. }
  1174. }
  1175. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1176. SQL語法 += ") AS all_data GROUP BY 時間_年, 時間_月, 時間_日 ORDER BY 時間_年, 時間_月, 時間_日";
  1177. }else{
  1178. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1179. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1180. SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1181. WHERE (電表編號 LIKE N'" + 電表流水號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1182. UNION ALL";
  1183. }
  1184. }
  1185. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1186. SQL語法 += ") AS all_data GROUP BY 時間_年, 時間_月, 時間_日 ORDER BY 時間_年, 時間_月, 時間_日";
  1187. }
  1188. }else{
  1189. string p;if(電表迴路=="迴路1"){p="P1";}else{p="P2";}
  1190. SQL語法=" SELECT CONVERT(VARCHAR(8), 上傳時間, 120) AS 日期, AVG(CAST("+p+" AS FLOAT)) AS 平均P1 FROM (";
  1191. if(day2.Year!=DateTime.Now.Year){
  1192. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1193. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1194. SQL語法 += "SELECT 上傳時間, "+p+" FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1195. WHERE (電表編號 LIKE N'" + 電表編號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1196. UNION ALL";
  1197. }
  1198. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(day2.Year.ToString())){
  1199. SQL語法 += "SELECT 上傳時間, "+p+" FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1200. WHERE (電表編號 LIKE N'" + 電表編號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1201. UNION ALL";
  1202. }
  1203. }
  1204. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1205. SQL語法 += ") AS 合併資料表 GROUP BY CONVERT(VARCHAR(8), 上傳時間, 120) ORDER BY 日期";
  1206. }else{
  1207. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1208. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1209. SQL語法 += "SELECT 上傳時間, "+p+" FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1210. WHERE (電表編號 LIKE N'" + 電表編號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1211. UNION ALL";
  1212. }
  1213. }
  1214. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1215. SQL語法 += ") AS 合併資料表 GROUP BY CONVERT(VARCHAR(8), 上傳時間, 120) ORDER BY 日期";
  1216. }
  1217. }
  1218. List<string> xAxisValue = new();
  1219. List<float> yAxisValue = new();
  1220. SQL_ele_sys.SQL_電表內容資料清單載入_月(SQL語法);
  1221. SQL_Module.da.Fill(ds1);
  1222. for(int i =0;i<=ds1.Tables[0].Rows.Count-1;i++){
  1223. if(Global.資料來源=="PLC"){
  1224. xAxisValue.Add(ds1.Tables[0].Rows[i][2].ToString());
  1225. yAxisValue.Add(float.Parse(ds1.Tables[0].Rows[i][3].ToString()));
  1226. }else{
  1227. xAxisValue.Add(ds1.Tables[0].Rows[i][0].ToString());
  1228. yAxisValue.Add(float.Parse(ds1.Tables[0].Rows[i][1].ToString()));
  1229. }
  1230. }
  1231. foreach (var xValue in xAxisValue) {
  1232. barchart.AddXAxisData(xValue);
  1233. }
  1234. foreach (float item in yAxisValue){
  1235. barchart.AddData(0, item);
  1236. }
  1237. }
  1238. private void 三合一繪圖(string 電表流水號,string 電表編號,string 電表迴路){
  1239. 電壓_barchart.ClearData();
  1240. 電流_barchart.ClearData();
  1241. 功率_barchart.ClearData();
  1242. List<string> xAxisValue = new();
  1243. List<float> yAxisValue = new();
  1244. List<float> yAxisValue2 = new();
  1245. List<float> yAxisValue3 = new();
  1246. DataSet ds1 = new();
  1247. DateTime day2=DateTime.Now.AddDays(-30);
  1248. string 開始時間= day2.ToString("yyyyMMdd");
  1249. string 結束時間= DateTime.Now.ToString("yyyyMMdd");
  1250. string SQL語法;
  1251. if(Global.資料來源=="PLC"){
  1252. SQL語法="SELECT DISTINCT 時間_年 , 時間_月 , 時間_日 , AVG(CONVERT(float,電壓L_L_Avg)),AVG(CONVERT(float,電流Avg )),AVG(CONVERT(float,總平均功率 )) FROM (";
  1253. if(day2.Year!=DateTime.Now.Year){
  1254. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1255. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1256. SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1257. WHERE (電表編號 LIKE N'" + 電表流水號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1258. UNION ALL";
  1259. }
  1260. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(day2.Year.ToString())){
  1261. SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1262. WHERE (電表編號 LIKE N'" + 電表流水號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1263. UNION ALL";
  1264. }
  1265. }
  1266. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1267. SQL語法 += ") AS all_data GROUP BY 時間_年, 時間_月, 時間_日 ORDER BY 時間_年, 時間_月, 時間_日";
  1268. }else{
  1269. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1270. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1271. SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1272. WHERE (電表編號 LIKE N'" + 電表流水號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1273. UNION ALL";
  1274. }
  1275. }
  1276. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1277. SQL語法 += ") AS all_data GROUP BY 時間_年, 時間_月, 時間_日 ORDER BY 時間_年, 時間_月, 時間_日";
  1278. }
  1279. }else{
  1280. string p,a;if(電表迴路=="迴路1"){p="P1";a="I1";}else{p="P2";a="I2";}
  1281. SQL語法="SELECT CONVERT(VARCHAR(8), 上傳時間, 120) AS 日期, AVG(CAST(P1 AS FLOAT)) AS 平均P1, AVG(CAST(Vab AS FLOAT)) AS 平均V,AVG(CAST(I1 AS FLOAT)) AS 平均I FROM (";
  1282. if(day2.Year!=DateTime.Now.Year){
  1283. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1284. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1285. SQL語法 += "SELECT 上傳時間, " + p + ",Vab," + a + " FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1286. WHERE (電表編號 LIKE N'" + 電表編號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1287. UNION ALL";
  1288. }
  1289. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(day2.Year.ToString())){
  1290. SQL語法 += "SELECT 上傳時間, " + p + ",Vab," + a + " FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1291. WHERE (電表編號 LIKE N'" + 電表編號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1292. UNION ALL";
  1293. }
  1294. }
  1295. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1296. SQL語法 += ") AS 合併資料表 GROUP BY CONVERT(VARCHAR(8), 上傳時間, 120) ORDER BY 日期";
  1297. }else{
  1298. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1299. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(DateTime.Now.Year.ToString())){
  1300. SQL語法 += "SELECT 上傳時間, " + p + ",Vab," + a + " FROM [" + Global.電表資料資料庫清單.Rows[i][0] + @"].dbo.電表資料表
  1301. WHERE (電表編號 LIKE N'" + 電表編號 + "') AND (上傳時間 BETWEEN '" + 開始時間 + @"000000' AND '" + 結束時間 + @"235959')
  1302. UNION ALL";
  1303. //SQL語法 += "SELECT * FROM [" + Global.電表資料資料庫清單.Rows[i][0] + "].dbo.電表資料表 WHERE 電表編號 LIKE N'" + 電表流水號 + "' AND (上傳時間 BETWEEN '" + 開始時間 + "000000' AND '" + 結束時間 + @"235959')
  1304. // UNION ALL";
  1305. }
  1306. }
  1307. SQL語法 = SQL語法[..^"UNION ALL".Length];
  1308. SQL語法 += ") AS 合併資料表 GROUP BY CONVERT(VARCHAR(8), 上傳時間, 120) ORDER BY 日期";
  1309. }
  1310. }
  1311. SQL_ele_sys.SQL_電表內容資料詳細載入_月(SQL語法);
  1312. if(Global.SQL_S){SQL_Module.da.Fill(ds1);}
  1313. for(int i =0;i<=ds1.Tables[0].Rows.Count-1;i++){
  1314. xAxisValue.Add(ds1.Tables[0].Rows[i]["時間_日"].ToString());
  1315. yAxisValue.Add(float.Parse(ds1.Tables[0].Rows[i][3].ToString()));
  1316. yAxisValue2.Add(float.Parse(ds1.Tables[0].Rows[i][4].ToString()));
  1317. yAxisValue3.Add(float.Parse(ds1.Tables[0].Rows[i][5].ToString()));
  1318. }
  1319. for (int i = 0; i < xAxisValue.Count; i++){
  1320. 電壓_barchart.AddXAxisData(xAxisValue[i]);
  1321. 電流_barchart.AddXAxisData(xAxisValue[i]);
  1322. 功率_barchart.AddXAxisData(xAxisValue[i]);
  1323. }
  1324. foreach (float item in yAxisValue){
  1325. 電壓_barchart.AddData(0, item);
  1326. }
  1327. foreach (float item in yAxisValue2){
  1328. 電流_barchart.AddData(0, item);
  1329. }
  1330. foreach (float item in yAxisValue3){
  1331. 功率_barchart.AddData(0, item);
  1332. }
  1333. }
  1334. public void open_right(){
  1335. 右側按鈕_pl.SetActive(true);
  1336. }
  1337. public void close_right(){
  1338. 右側按鈕_pl.SetActive(false);
  1339. }
  1340. //=======電費試算表===========================
  1341. public void Open_calculator(){
  1342. if(電費試算表_pl.activeInHierarchy){電費試算表_pl.SetActive(false);}else{
  1343. 電費試算表_pl.SetActive(true);
  1344. //試算_電表編號_tb.text=Global.PA;
  1345. if(!Global.載入電表名稱){
  1346. 試算_電表名稱_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1347. 試算_電表名稱_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.電表名稱Option);
  1348. 試算_電表名稱_cb.GetComponent<TMP_Dropdown>().value=0;
  1349. Global.載入電表名稱=true;
  1350. }
  1351. /*if(Global.管理權限){
  1352. 試算_幣別_tb.SetActive(true);
  1353. 試算_幣別_cb.SetActive(true);
  1354. }*/
  1355. if(!Global.載入年度){
  1356. 試算_開始年_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1357. 試算_結束年_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1358. 試算_開始年_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.年度Options);
  1359. 試算_結束年_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.年度Options);
  1360. 試算_開始年_cb.GetComponent<TMP_Dropdown>().value=Global.年度Options.IndexOf(DateTime.Now.Year.ToString());
  1361. 試算_結束年_cb.GetComponent<TMP_Dropdown>().value=Global.年度Options.IndexOf(DateTime.Now.Year.ToString());
  1362. Global.載入年度=true;
  1363. }
  1364. if(!Global.載入月份){
  1365. 試算_開始月_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1366. 試算_結束月_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1367. 試算_開始月_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.月份Options_中);
  1368. 試算_結束月_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.月份Options_中);
  1369. 試算_開始月_cb.GetComponent<TMP_Dropdown>().value=DateTime.Now.Month-1;
  1370. 試算_結束月_cb.GetComponent<TMP_Dropdown>().value=DateTime.Now.Month-1;
  1371. Global.載入月份=true;
  1372. Moudle.載入日期(1,試算_開始年_cb,試算_開始月_cb,試算_開始日_cb);
  1373. 試算_Set_電表資料();
  1374. }
  1375. }
  1376. }
  1377. public void 觸發載入日期(){
  1378. if(Global.載入月份){
  1379. Moudle.載入日期(1,試算_開始年_cb,試算_開始月_cb,試算_開始日_cb);
  1380. 試算_Set_電表資料();
  1381. }
  1382. }
  1383. public void 試算_Set_電表資料(){
  1384. int N_year = Int32.Parse(試算_開始年_cb.GetComponent<TMP_Dropdown>().options[試算_開始年_cb.GetComponent<TMP_Dropdown>().value].text);
  1385. int N_month = 試算_開始月_cb.GetComponent<TMP_Dropdown>().value+1;
  1386. int N_day = 試算_開始日_cb.GetComponent<TMP_Dropdown>().value+1;
  1387. int E_year = Int32.Parse(試算_結束年_cb.GetComponent<TMP_Dropdown>().options[試算_結束年_cb.GetComponent<TMP_Dropdown>().value].text);
  1388. int E_month = 試算_結束月_cb.GetComponent<TMP_Dropdown>().value+1;
  1389. int E_day = 試算_結束日_cb.GetComponent<TMP_Dropdown>().value+1;
  1390. if(E_year <= DateTime.Now.Year && E_month <= DateTime.Now.Month && E_day <= DateTime.Now.Day && N_year <= DateTime.Now.Year && N_month <= DateTime.Now.Month && N_day <= DateTime.Now.Day){
  1391. Global.試算_開始時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0');
  1392. Global.試算_結束時間=E_year.ToString().PadLeft(4,'0')+E_month.ToString().PadLeft(2,'0')+E_day.ToString().PadLeft(2,'0');
  1393. Global.PA = 試算_電表名稱_cb.GetComponent<TMP_Dropdown>().options[試算_電表名稱_cb.GetComponent<TMP_Dropdown>().value].text;
  1394. SQL_ele_sys.SQL_取得電費試算資料();
  1395. if(Global.SQL_S){
  1396. if(SQL_Module.dr.Read()){
  1397. if(!SQL_Module.dr.IsDBNull(0)){
  1398. 試算_平均電壓_tb.text = String.Format("{0:###,###.###}",SQL_Module.dr[0]) + " V";
  1399. 試算_平均電流_tb.text = String.Format("{0:###,###.###}",SQL_Module.dr[1]) + " A";
  1400. 試算_平均功率_tb.text = String.Format("{0:###,###.###}",SQL_Module.dr[2]) + " kW";
  1401. 試算_總消耗功率_tb.text = String.Format("{0:###,###.###}",SQL_Module.dr[2]) + " kWh";
  1402. DateTime day3 = new DateTime(N_year,N_month,N_day);
  1403. DateTime day4 = new DateTime(E_year,E_month,E_day);
  1404. if(E_year==DateTime.Now.Year && E_month==DateTime.Now.Month && E_day==DateTime.Now.Day){
  1405. day4=day4.AddHours(DateTime.Now.Hour+Global.Zoneoffset);
  1406. }else{
  1407. day4=day4.AddDays(1);
  1408. }
  1409. TimeSpan day2 = day4.Subtract(day3);
  1410. 試算_總消耗能量_tb.text = String.Format("{0:###,###.###}",Single.Parse(試算_總消耗功率_tb.text.Substring(0, 試算_總消耗功率_tb.text.Length - 4)) * day2.TotalHours) + " kWh";
  1411. if(Global.幣別=="印尼盾"){
  1412. 試算_電費試算_tb.text = String.Format("{0:###,###}",(int)Single.Parse(試算_總消耗能量_tb.text.Substring(0, 試算_總消耗能量_tb.text.Length - 4)) * 1114) + " Rp";
  1413. }else{
  1414. 試算_電費試算_tb.text = String.Format("{0:###,###}",(int)Single.Parse(試算_總消耗能量_tb.text.Substring(0, 試算_總消耗能量_tb.text.Length - 4)) * 1114/500) + " NTD";
  1415. }
  1416. }else{
  1417. 試算_平均電壓_tb.text="0";
  1418. 試算_平均電流_tb.text="0";
  1419. 試算_平均功率_tb.text="0";
  1420. 試算_總消耗功率_tb.text="0";
  1421. 試算_總消耗能量_tb.text="0";
  1422. 試算_電費試算_tb.text = "0";
  1423. }
  1424. }
  1425. }
  1426. }else{
  1427. 試算_平均電壓_tb.text="0";
  1428. 試算_平均電流_tb.text="0";
  1429. 試算_平均功率_tb.text="0";
  1430. 試算_總消耗功率_tb.text="0";
  1431. 試算_總消耗能量_tb.text="0";
  1432. 試算_電費試算_tb.text = "0";
  1433. //MsgBox("TimeError!");
  1434. }
  1435. }
  1436. /*public void 幣別轉換(){
  1437. if(試算_幣別_cb.GetComponent<TMP_Dropdown>().value==0){
  1438. Global.幣別="印尼盾";
  1439. }else{
  1440. Global.幣別="台幣";
  1441. }
  1442. }*/
  1443. public void close_calculator(){
  1444. 電費試算表_pl.SetActive(false);
  1445. }
  1446. //===============電能報表===================
  1447. public void open_report(){
  1448. 電能報表_pl.SetActive(true);電能監控系統_pl.SetActive(false);
  1449. if(!載入完畢){
  1450. Global.電能報表區間時間選擇="月";Global.電能報表電費時間選擇="月";載入cb();
  1451. Moudle.載入日期(2,區間_開始_年_cb,區間_開始_月_cb,區間_開始_日_cb);
  1452. //Moudle.載入日期(3,電費_開始_年_cb,電費_結束_年_cb,電費_開始_月_cb,電費_結束_月_cb,電費_開始_日_cb,電費_結束_日_cb);
  1453. 建立年度表格();
  1454. 建立區間表格();
  1455. //建立電費表格();
  1456. 載入完畢=true;
  1457. }
  1458. }
  1459. private void 載入cb(){
  1460. DateTime day2 = DateTime.Now.AddDays(-(DateTime.Now.Day - 1));
  1461. day2 = day2.AddMonths(-1);
  1462. 電表編號_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1463. 電表編號_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.電表名稱Option);
  1464. 電表編號_cb.GetComponent<TMP_Dropdown>().value=0;
  1465. 區間_開始_年_cb.ClearOptions();
  1466. 區間_開始_月_cb.ClearOptions();
  1467. 區間_開始_日_cb.ClearOptions();
  1468. 區間_開始_年_cb.AddOptions(Main.Global.年度Options);
  1469. 區間_開始_年_cb.value=Main.Global.年度Options.IndexOf(day2.Year.ToString());
  1470. List<string> 月份 = new List<string> { "","一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月" };
  1471. 區間_開始_月_cb.AddOptions(月份);
  1472. 區間_開始_月_cb.value= 0;
  1473. //===============================
  1474. 開始時間_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1475. 開始時間_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.年度Options);
  1476. 開始時間_cb.GetComponent<TMP_Dropdown>().value=1;
  1477. 結束時間_cb.GetComponent<TMP_Dropdown>().ClearOptions();
  1478. 結束時間_cb.GetComponent<TMP_Dropdown>().AddOptions(Global.年度Options);
  1479. 結束時間_cb.GetComponent<TMP_Dropdown>().value=Global.年度Options.IndexOf(DateTime.Now.Year.ToString());
  1480. //============================
  1481. 電費_開始_年_cb.ClearOptions();
  1482. 電費_開始_月_cb.ClearOptions();
  1483. 電費_開始_小時_cb.ClearOptions();
  1484. 電費_結束_年_cb.ClearOptions();
  1485. 電費_結束_月_cb.ClearOptions();
  1486. 電費_結束_小時_cb.ClearOptions();
  1487. 電費_開始_年_cb.AddOptions(Global.年度Options);
  1488. 電費_開始_年_cb.value=Global.年度Options.IndexOf(day2.Year.ToString());
  1489. 電費_結束_年_cb.AddOptions(Global.年度Options);
  1490. 電費_結束_年_cb.value=Global.年度Options.IndexOf(DateTime.Now.Year.ToString());
  1491. 電費_開始_月_cb.AddOptions(Global.月份Options_中);
  1492. 電費_結束_月_cb.AddOptions(Global.月份Options_中);
  1493. 電費_開始_月_cb.value= day2.Month-1;
  1494. 電費_結束_月_cb.value= DateTime.Now.Month-1;
  1495. 電費_開始_小時_cb.AddOptions(Global.小時Options);
  1496. 電費_開始_小時_cb.value=0;
  1497. 電費_結束_小時_cb.AddOptions(Global.小時Options);
  1498. 電費_結束_小時_cb.value=Global.小時Options.IndexOf((DateTime.Now.Hour-Global.Zoneoffset).ToString());
  1499. Global.報表載入月份=true;
  1500. }
  1501. private void 建立年度表格(){
  1502. string 電表編號= 電表編號_cb.GetComponent<TMP_Dropdown>().options[電表編號_cb.GetComponent<TMP_Dropdown>().value].text;
  1503. DataTable ds1 = new();
  1504. ds1.Columns.Add("年份",typeof(string));
  1505. for(int i=0;i<=Global.月份Options_中.Count-1;i++){ds1.Columns.Add(Global.月份Options_中[i],typeof(string));}
  1506. int 開始年 = int.Parse(開始時間_cb.GetComponent<TMP_Dropdown>().options[開始時間_cb.GetComponent<TMP_Dropdown>().value].text);
  1507. int 結束年 =int.Parse(結束時間_cb.GetComponent<TMP_Dropdown>().options[結束時間_cb.GetComponent<TMP_Dropdown>().value].text);
  1508. if(結束年-開始年>=0){
  1509. for(int g=0;g<=結束年-開始年;g++){
  1510. DataRow row = ds1.NewRow();
  1511. row["年份"] = 開始年+g;
  1512. string 流水號=取得流水號(電表編號);string 電表編號改="";string 電表迴路="";
  1513. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  1514. if(Global.電表資料清單.Rows[i][0].ToString().Contains(流水號)){
  1515. 電表編號改 = Global.電表資料清單.Rows[i][3].ToString();
  1516. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  1517. }
  1518. }
  1519. bool 有無 = 資料庫判斷((開始年+g).ToString());
  1520. if(有無){
  1521. List<string> 清單 = 資料庫明細((開始年+g).ToString());
  1522. for(int j=0;j<=清單.Count-1;j++){
  1523. string SQL語法="SELECT ";
  1524. for(int n=0;n<=Global.月份Options_中.Count-1;n++){
  1525. string 開始時間=(開始年+g).ToString()+(n+1).ToString().PadLeft(2,'0')+"01000000";
  1526. string 結束時間=(開始年+g).ToString()+(n+1).ToString().PadLeft(2,'0')+"31235959";
  1527. if(流水號!=null){
  1528. if(Global.資料來源=="PLC"){
  1529. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  1530. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString()+@"
  1531. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1532. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString()+") AS 總P"+n.ToString()+",";
  1533. }else{
  1534. string p;if(電表迴路=="迴路1"){p="P1";}else{p="P2";}
  1535. SQL語法+="(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p+@" AS FLOAT)) AS 度
  1536. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString()+@"
  1537. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1538. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString()+") AS 總P"+n.ToString()+",";
  1539. }
  1540. }
  1541. }
  1542. SQL語法 = SQL語法[..^",".Length];
  1543. SQL_ele_sys.SQL_載入年度電費表格_改(SQL語法);
  1544. if(SQL_Module.dr.Read()){
  1545. for(int i=0;i<=Global.月份Options_中.Count-1;i++){
  1546. if(SQL_Module.dr[i].ToString()==""){
  1547. row[Global.月份Options_中[i]]="0";
  1548. }else{
  1549. if(Global.電表功率單位[電表編號_cb.GetComponent<TMP_Dropdown>().value] == "W"){
  1550. float data = float.Parse(SQL_Module.dr[i].ToString())/1000;
  1551. row[Global.月份Options_中[i]]= data.ToString("#,##0.##");
  1552. }else{
  1553. float data = float.Parse(SQL_Module.dr[i].ToString());
  1554. row[Global.月份Options_中[i]]= data.ToString("#,##0");
  1555. }
  1556. }
  1557. }
  1558. }else{
  1559. for(int i=0;i<=Global.月份Options_中.Count-1;i++){row[Global.月份Options_中[i]]="0";}
  1560. }
  1561. }
  1562. }else{
  1563. for(int i=0;i<=Global.月份Options_中.Count-1;i++){row[Global.月份Options_中[i]]="0";}
  1564. }
  1565. ds1.Rows.Add(row);
  1566. }
  1567. //====================
  1568. Moudle.載入表格("年度",ds1,年用電清單_tp,年用電清單_rpf,年用電清單_ct,myFont,UIsprite,年用電清單_lpf,true);
  1569. Global.年度表格=ds1;
  1570. 年用電_chart.RemoveData();
  1571. List<string> xAxisValue = new List<string>();
  1572. for(int j=1;j<=12;j++){
  1573. xAxisValue.Add(j.ToString());
  1574. }
  1575. for (int h = 0; h < xAxisValue.Count; h++){
  1576. 年用電_chart.AddXAxisData(xAxisValue[h]);
  1577. }
  1578. for(int i=int.Parse(開始時間_cb.GetComponent<TMP_Dropdown>().options[開始時間_cb.GetComponent<TMP_Dropdown>().value].text);i<= int.Parse(結束時間_cb.GetComponent<TMP_Dropdown>().options[結束時間_cb.GetComponent<TMP_Dropdown>().value].text);i++){
  1579. 年用電_chart.AddSerie<Line>(i.ToString());
  1580. for(int m=0;m<=ds1.Rows.Count-1;m++){
  1581. List<float> yAxisValue = new List<float>();
  1582. if(i== int.Parse(ds1.Rows[m][0].ToString())){
  1583. for(int j=1;j<=12;j++){
  1584. yAxisValue.Add(float.Parse(ds1.Rows[m][j].ToString()));
  1585. }
  1586. }
  1587. foreach (float item in yAxisValue){
  1588. 年用電_chart.AddData(m, item);
  1589. }
  1590. }
  1591. }
  1592. 年用電_chart.GetSerie<Line>(0).itemStyle.color=new Color(0.97f, 0.48f, 0.99f, 1f);
  1593. foreach (var series in 年用電_chart.series)
  1594. {
  1595. series.symbol.type = SymbolType.Circle;
  1596. }
  1597. }
  1598. }
  1599. private string 取得流水號(string 電表編號){
  1600. for(int f=0;f<=Global.電表資料清單.Rows.Count-1;f++){
  1601. if(電表編號 == Global.電表資料清單.Rows[f][1].ToString()){
  1602. return Global.電表資料清單.Rows[f][0].ToString();
  1603. }
  1604. }
  1605. return null;
  1606. }
  1607. private bool 資料庫判斷(string 資料庫名稱){
  1608. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(資料庫名稱)){return true;}}
  1609. return false;
  1610. }
  1611. private List<string> 資料庫明細(string 資料庫名稱){
  1612. List<string> 清單 = new();
  1613. for(int i=0;i<=Global.電表資料資料庫清單.Rows.Count-1;i++){
  1614. if(Global.電表資料資料庫清單.Rows[i][0].ToString().Contains(資料庫名稱)){
  1615. 清單.Add(Global.電表資料資料庫清單.Rows[i][0].ToString());
  1616. }
  1617. }
  1618. return 清單;
  1619. }
  1620. private void 建立區間表格(){
  1621. 讀取_pl.SetActive(true);
  1622. string 電表編號= 電表編號_cb.GetComponent<TMP_Dropdown>().options[電表編號_cb.GetComponent<TMP_Dropdown>().value].text;
  1623. string 流水號=取得流水號(電表編號);string 電表編號改="";string 電表迴路="";
  1624. for(int i=0;i<=Global.電表資料清單.Rows.Count-1;i++){
  1625. if(Global.電表資料清單.Rows[i][0].ToString().Contains(流水號)){
  1626. 電表編號改 = Global.電表資料清單.Rows[i][3].ToString();
  1627. 電表迴路 = Global.電表資料清單.Rows[i][4].ToString();
  1628. }
  1629. }
  1630. string p;if(電表迴路=="迴路1"){p="P1";}else{p="P2";}
  1631. int N_year =int.Parse(區間_開始_年_cb.options[區間_開始_年_cb.value].text);
  1632. int N_month = 區間_開始_月_cb.GetComponent<TMP_Dropdown>().value;
  1633. int N_day = 區間_開始_日_cb.GetComponent<TMP_Dropdown>().value;
  1634. List<string> TimeData = new(){"01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","24","25","26","27","28","29","30","31"};
  1635. Global.區間_總和=0;
  1636. DataTable 區間表格_tabel;
  1637. DataTable ds3 = new();
  1638. if(Global.電能報表區間時間選擇=="小時"){
  1639. ds3.Columns.Add("小時",typeof(string));ds3.Columns.Add("度數",typeof(string));
  1640. }else if(Global.電能報表區間時間選擇=="日"){
  1641. ds3.Columns.Add("日期",typeof(string));ds3.Columns.Add("度數",typeof(string));
  1642. }else{
  1643. ds3.Columns.Add("月份",typeof(string));ds3.Columns.Add("度數",typeof(string));
  1644. }
  1645. bool 有無 = 資料庫判斷(N_year.ToString());
  1646. if(有無 && 流水號!=null){
  1647. List<string> 清單 = 資料庫明細(N_year.ToString());
  1648. string SQL語法="SELECT ";
  1649. if(Global.電能報表區間時間選擇=="小時"){
  1650. for(int n=0;n<=23;n++){
  1651. string 開始時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"0000";
  1652. string 結束時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"5959";
  1653. for(int j=0;j<=清單.Count-1;j++){
  1654. if(Global.資料來源=="PLC"){
  1655. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  1656. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  1657. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1658. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  1659. }else{
  1660. SQL語法+="(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p +@" AS FLOAT)) AS 度
  1661. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  1662. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1663. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  1664. }
  1665. }
  1666. }
  1667. }else if(Global.電能報表區間時間選擇=="日"){
  1668. for(int n=1;n<=DateTime.DaysInMonth(N_year,N_month);n++){
  1669. string 開始時間=N_year.ToString()+N_month.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"000000";
  1670. string 結束時間=N_year.ToString()+N_month.ToString().PadLeft(2,'0')+n.ToString().PadLeft(2,'0')+"235959";
  1671. for(int j=0;j<=清單.Count-1;j++){
  1672. if(Global.資料來源=="PLC"){
  1673. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  1674. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  1675. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1676. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  1677. }else{
  1678. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p +@" AS FLOAT)) AS 度
  1679. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  1680. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1681. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  1682. }
  1683. }
  1684. }
  1685. }else{
  1686. for(int n=0;n<=Global.月份Options_中.Count-1;n++){
  1687. string 開始時間=N_year.ToString()+(n+1).ToString().PadLeft(2,'0')+"01000000";
  1688. string 結束時間=N_year.ToString()+(n+1).ToString().PadLeft(2,'0')+"31235959";
  1689. for(int j=0;j<=清單.Count-1;j++){
  1690. if(Global.資料來源=="PLC"){
  1691. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST(總平均功率 AS FLOAT)) AS 度
  1692. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  1693. WHERE (電表編號 LIKE N'"+電表編號+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1694. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  1695. }else{
  1696. SQL語法+=@"(SELECT SUM(度) AS Expr1 FROM (SELECT CONVERT(VARCHAR(10), 上傳時間, 120) AS 日期, AVG(CAST("+p +@" AS FLOAT)) AS 度
  1697. FROM ["+清單[j]+"].dbo.電表資料表 AS 電表資料表_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+@"
  1698. WHERE (電表編號 LIKE N'"+電表編號改+ "') AND (上傳時間 BETWEEN '"+開始時間+"' AND '"+結束時間+@"')
  1699. GROUP BY CONVERT(VARCHAR(10), 上傳時間, 120)) AS DailyAverages_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+") AS 總P_"+n.ToString().PadLeft(2,'0')+"_"+j.ToString().PadLeft(2,'0')+",";
  1700. }
  1701. }
  1702. }
  1703. }
  1704. SQL語法 = SQL語法[..^",".Length];
  1705. SQL_ele_sys.SQL_載入區間表格_月_改(SQL語法);
  1706. if(SQL_Module.dr.Read()){
  1707. if(Global.電能報表區間時間選擇=="小時"){
  1708. for(int n=0;n<=23;n++){
  1709. DataRow row = ds3.NewRow();
  1710. row["小時"] =n.ToString().PadLeft(2,'0');
  1711. float 度數=0;
  1712. for(int s=0;s<=SQL_Module.dr.FieldCount-1;s++){
  1713. string colname = SQL_Module.dr.GetName(s);
  1714. if(int.Parse(colname.Substring(3,2))==n){
  1715. if(SQL_Module.dr[s].ToString()!=""){
  1716. 度數 += float.Parse(SQL_Module.dr[s].ToString());
  1717. }
  1718. }
  1719. }
  1720. if(Global.電表功率單位[電表編號_cb.GetComponent<TMP_Dropdown>().value] == "W"){
  1721. row["度數"] = (度數 / 1000).ToString("#,##0.##");
  1722. Global.區間_總和 += 度數 / 1000;
  1723. }else{
  1724. row["度數"] = 度數.ToString("#,##0.##");
  1725. Global.區間_總和 += 度數;
  1726. }
  1727. ds3.Rows.Add(row);
  1728. }
  1729. }else if(Global.電能報表區間時間選擇=="日"){
  1730. for(int n=0;n<=DateTime.DaysInMonth(N_year,N_month)-1;n++){
  1731. DataRow row = ds3.NewRow();
  1732. row["日期"] =TimeData[n];
  1733. float 度數=0;
  1734. for(int s=0;s<=SQL_Module.dr.FieldCount-1;s++){
  1735. string colname = SQL_Module.dr.GetName(s);
  1736. if(int.Parse(colname.Substring(3,2))==n+1){
  1737. if(SQL_Module.dr[s].ToString()!=""){
  1738. 度數 += float.Parse(SQL_Module.dr[s].ToString());
  1739. }
  1740. }
  1741. }
  1742. if(Global.電表功率單位[電表編號_cb.GetComponent<TMP_Dropdown>().value] == "W"){
  1743. row["度數"] = (度數 / 1000).ToString("#,##0.##");
  1744. Global.區間_總和 += 度數 / 1000;
  1745. }else{
  1746. row["度數"] = 度數.ToString("#,##0.##");
  1747. Global.區間_總和 += 度數;
  1748. }
  1749. ds3.Rows.Add(row);
  1750. }
  1751. }else{
  1752. for(int n=0;n<=Global.月份Options_中.Count-1;n++){
  1753. DataRow row = ds3.NewRow();
  1754. row["月份"] = Global.月份Options_中[n];
  1755. float 度數=0;
  1756. for(int s=0;s<=SQL_Module.dr.FieldCount-1;s++){
  1757. string colname = SQL_Module.dr.GetName(s);
  1758. if(int.Parse(colname.Substring(3,2))==n){
  1759. if(SQL_Module.dr[s].ToString()!=""){
  1760. 度數 += float.Parse(SQL_Module.dr[s].ToString());
  1761. }
  1762. }
  1763. }
  1764. if(Global.電表功率單位[電表編號_cb.GetComponent<TMP_Dropdown>().value] == "W"){
  1765. row["度數"] = (度數 / 1000).ToString("#,##0.##");
  1766. Global.區間_總和 += 度數 / 1000;
  1767. }else{
  1768. row["度數"] = 度數.ToString("#,##0.##");
  1769. Global.區間_總和 += 度數;
  1770. }
  1771. ds3.Rows.Add(row);
  1772. }
  1773. }
  1774. }
  1775. }
  1776. 區間表格_tabel = ds3;
  1777. Moudle.載入表格("區間",區間表格_tabel,度數清單_tp,度數清單_rpf,度數清單_ct,myFont,UIsprite,度數清單_lpf,false);
  1778. 區間總和_tb.text = string.Format("{0:###,##0.##}",Global.區間_總和)+" kWh";
  1779. Global.區間表格=區間表格_tabel;
  1780. //===================================================
  1781. 度數_chart.RemoveData();
  1782. if(Global.電能報表區間時間選擇=="小時"){
  1783. List<string> xAxisValue = new(){"00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23"};
  1784. for (int h = 0; h < xAxisValue.Count; h++){度數_chart.AddXAxisData(xAxisValue[h]);}
  1785. int k =0;
  1786. 度數_chart.AddSerie<Bar>(區間_開始_日_cb.options[區間_開始_日_cb.value].text);
  1787. List<float> yAxisValue = new();
  1788. for(int g=0;g<=23;g++){
  1789. if(k<=區間表格_tabel.Rows.Count-1){
  1790. if(區間表格_tabel.Rows[k][0].ToString().PadLeft(2,'0') == xAxisValue[g]){
  1791. yAxisValue.Add(float.Parse(區間表格_tabel.Rows[k][1].ToString()));
  1792. k++;
  1793. }else{
  1794. yAxisValue.Add(0f);
  1795. }
  1796. }else{
  1797. yAxisValue.Add(0f);
  1798. }
  1799. }
  1800. foreach (float item in yAxisValue){
  1801. 度數_chart.AddData(0, item);
  1802. }
  1803. }else if(Global.電能報表區間時間選擇=="日"){
  1804. List<string> xAxisValue = new(){"01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","24","25","26","27","28","29","30","31"};
  1805. for (int h = 0; h < xAxisValue.Count; h++){度數_chart.AddXAxisData(xAxisValue[h]);}
  1806. int k =0;
  1807. 度數_chart.AddSerie<Bar>(區間_開始_日_cb.options[區間_開始_日_cb.value].text);
  1808. List<float> yAxisValue = new();
  1809. for(int g=0;g<=DateTime.DaysInMonth(N_year,N_month)-1;g++){
  1810. if(k<=區間表格_tabel.Rows.Count-1){
  1811. if(區間表格_tabel.Rows[k][0].ToString().PadLeft(2,'0') == xAxisValue[g]){
  1812. yAxisValue.Add(float.Parse(區間表格_tabel.Rows[k][1].ToString()));
  1813. k++;
  1814. }else{
  1815. yAxisValue.Add(0f);
  1816. }
  1817. }else{
  1818. yAxisValue.Add(0f);
  1819. }
  1820. }
  1821. foreach (float item in yAxisValue){
  1822. 度數_chart.AddData(0, item);
  1823. }
  1824. }else{
  1825. List<string> xAxisValue = Global.月份Options_中;
  1826. for (int h = 0; h < xAxisValue.Count; h++){
  1827. 度數_chart.AddXAxisData(xAxisValue[h]);
  1828. }
  1829. int k=0;
  1830. 度數_chart.AddSerie<Bar>(區間_開始_年_cb.options[區間_開始_年_cb.value].text);
  1831. List<float> yAxisValue = new();
  1832. for(int g=0;g<=11;g++){
  1833. if(k<=區間表格_tabel.Rows.Count-1){
  1834. if(區間表格_tabel.Rows[k][0].ToString().PadLeft(2,'0') == xAxisValue[g]){
  1835. yAxisValue.Add(float.Parse(區間表格_tabel.Rows[k][1].ToString()));
  1836. k++;
  1837. }else{
  1838. yAxisValue.Add(0f);
  1839. }
  1840. }else{
  1841. yAxisValue.Add(0f);
  1842. }
  1843. }
  1844. foreach (float item in yAxisValue){
  1845. 度數_chart.AddData(0, item);
  1846. }
  1847. }
  1848. 度數_chart.GetSerie<Bar>(0).itemStyle.color=new Color(0.97f, 0.48f, 0.99f, 1f);
  1849. foreach (var series in 度數_chart.series)
  1850. {
  1851. series.symbol.type = SymbolType.Circle;
  1852. }
  1853. Global.第一區間表格完畢=true;讀取_pl.SetActive(false);
  1854. }
  1855. private void 建立電費表格(){
  1856. Global.PA7= 電表編號_cb.GetComponent<TMP_Dropdown>().options[電表編號_cb.GetComponent<TMP_Dropdown>().value].text;
  1857. int N_year = int.Parse(電費_開始_年_cb.GetComponent<TMP_Dropdown>().options[電費_開始_年_cb.GetComponent<TMP_Dropdown>().value].text);
  1858. int N_month = 電費_開始_月_cb.GetComponent<TMP_Dropdown>().value+1;
  1859. int N_day = 電費_開始_日_cb.GetComponent<TMP_Dropdown>().value+1;
  1860. int N_hour = 電費_開始_小時_cb.GetComponent<TMP_Dropdown>().value+1;
  1861. int E_year = int.Parse(電費_結束_年_cb.GetComponent<TMP_Dropdown>().options[電費_結束_年_cb.GetComponent<TMP_Dropdown>().value].text);
  1862. int E_month = 電費_結束_月_cb.GetComponent<TMP_Dropdown>().value+1;
  1863. int E_day = 電費_結束_日_cb.GetComponent<TMP_Dropdown>().value+1;
  1864. int E_hour = 電費_結束_小時_cb.GetComponent<TMP_Dropdown>().value+1;
  1865. DateTime N_Time=new DateTime(N_year,N_month,N_day);
  1866. DateTime E_Time=new DateTime(E_year,E_month,E_day);
  1867. TimeSpan Totalday = E_Time-N_Time;
  1868. Main.Global.電費_總和=0;
  1869. DataSet ds1 = new();
  1870. if(Main.Global.電能報表電費時間選擇=="小時"){
  1871. Main.Global.區間_開始時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0')+N_hour.ToString().PadLeft(2,'0');
  1872. Main.Global.區間_結束時間=E_year.ToString().PadLeft(4,'0')+E_month.ToString().PadLeft(2,'0')+E_day.ToString().PadLeft(2,'0')+E_hour.ToString().PadLeft(2,'0');
  1873. SQL_ele_sys.SQL_載入電費表格_小時();
  1874. SQL_Module.da.Fill(ds1);
  1875. for(int j=0;j<=ds1.Tables[0].Rows.Count-1;j++){
  1876. ds1.Tables[0].Rows[j][4] = String.Format("{0:###,##0}",Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][4].ToString())));
  1877. ds1.Tables[0].Rows[j][5] = String.Format("{0:###,##0}",Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][4].ToString()))*1114f);
  1878. Main.Global.電費_總和 += Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][4].ToString()))*1114;
  1879. }
  1880. }else if(Main.Global.電能報表電費時間選擇=="日"){
  1881. Main.Global.區間_開始時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0');
  1882. Main.Global.區間_結束時間=E_year.ToString().PadLeft(4,'0')+E_month.ToString().PadLeft(2,'0')+E_day.ToString().PadLeft(2,'0');
  1883. SQL_ele_sys.SQL_載入電費表格_日();
  1884. SQL_Module.da.Fill(ds1);
  1885. for(int j=0;j<=ds1.Tables[0].Rows.Count-1;j++){
  1886. ds1.Tables[0].Rows[j][3] = String.Format("{0:###,##0}",Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][3].ToString())));
  1887. ds1.Tables[0].Rows[j][4] = String.Format("{0:###,##0}",Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][3].ToString()))*1114f);
  1888. Main.Global.電費_總和 += Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][3].ToString()))*1114;
  1889. }
  1890. }else{
  1891. Main.Global.區間_開始時間=N_year.ToString().PadLeft(4,'0')+N_month.ToString().PadLeft(2,'0')+N_day.ToString().PadLeft(2,'0');
  1892. Main.Global.區間_結束時間=E_year.ToString().PadLeft(4,'0')+E_month.ToString().PadLeft(2,'0')+E_day.ToString().PadLeft(2,'0');
  1893. SQL_ele_sys.SQL_載入電費表格_月();
  1894. SQL_Module.da.Fill(ds1);
  1895. for(int j=0;j<=ds1.Tables[0].Rows.Count-1;j++){
  1896. ds1.Tables[0].Rows[j][2] = String.Format("{0:###,###}",Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][2].ToString())*DateTime.DaysInMonth(Int32.Parse(ds1.Tables[0].Rows[j][0].ToString()),Int32.Parse(ds1.Tables[0].Rows[j][1].ToString()))*24f));
  1897. ds1.Tables[0].Rows[j][3] = String.Format("{0:###,###}",Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][2].ToString())*DateTime.DaysInMonth(Int32.Parse(ds1.Tables[0].Rows[j][0].ToString()),Int32.Parse(ds1.Tables[0].Rows[j][1].ToString()))*24f)*1114f);
  1898. Main.Global.電費_總和 += Mathf.RoundToInt(Single.Parse(ds1.Tables[0].Rows[j][2].ToString()))*1114;
  1899. }
  1900. }
  1901. Moudle.載入表格("電費",ds1.Tables[0],電費清單_tp,電費清單_rpf,電費清單_ct,myFont,UIsprite,電費清單_lpf,false);
  1902. 電費總和_tb.text = String.Format("{0:###,###}",Main.Global.電費_總和)+" Rp";
  1903. Main.Global.電費表格=ds1.Tables[0];
  1904. //===================================================
  1905. 電費_chart.RemoveData();
  1906. if(Main.Global.電能報表電費時間選擇=="小時"){
  1907. List<string> xAxisValue = new List<string>();
  1908. for(int h=0;h<=23;h++){xAxisValue.Add(h.ToString().PadLeft(2,'0'));電費_chart.AddXAxisData(xAxisValue[h]);}
  1909. int k=0;
  1910. for(int s=0;s<=Totalday.Days;s++){
  1911. DateTime localTime = new DateTime(N_year,N_month,N_day);
  1912. DateTime day2 = localTime.AddDays(s);
  1913. 電費_chart.AddSerie<Line>(day2.Day.ToString());
  1914. List<float> yAxisValue = new List<float>();
  1915. for(int g=0;g<=23;g++){
  1916. if(k<=ds1.Tables[0].Rows.Count-1){
  1917. if(ds1.Tables[0].Rows[k][3].ToString().PadLeft(2,'0') == xAxisValue[g]){
  1918. yAxisValue.Add(Single.Parse(ds1.Tables[0].Rows[k][4].ToString()));
  1919. k++;
  1920. }else{
  1921. yAxisValue.Add(0f);
  1922. }
  1923. }else{
  1924. yAxisValue.Add(0f);
  1925. }
  1926. }
  1927. foreach (float item in yAxisValue){
  1928. 電費_chart.AddData(s, item);
  1929. }
  1930. }
  1931. }else if(Main.Global.電能報表電費時間選擇=="日"){
  1932. List<string> xAxisValue = new List<string>(){"01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","24","25","26","27","28","29","30","31"};
  1933. for (int h = 0; h < xAxisValue.Count; h++){電費_chart.AddXAxisData(xAxisValue[h]);}
  1934. int k =0;
  1935. for(int s=0;s<=Math.Abs((E_year - N_year) * 12 + E_month - N_month);s++){
  1936. DateTime localTime = new DateTime(N_year,N_month,N_day);
  1937. DateTime day2 = localTime.AddMonths(s);
  1938. 電費_chart.AddSerie<Line>(day2.Month.ToString());
  1939. List<float> yAxisValue = new List<float>();
  1940. for(int g=0;g<=DateTime.DaysInMonth(day2.Year,day2.Month)-1;g++){
  1941. if(k<=ds1.Tables[0].Rows.Count-1){
  1942. if(ds1.Tables[0].Rows[k][2].ToString().PadLeft(2,'0') == xAxisValue[g]){
  1943. yAxisValue.Add(Single.Parse(ds1.Tables[0].Rows[k][3].ToString()));
  1944. k++;
  1945. }else{
  1946. yAxisValue.Add(0f);
  1947. }
  1948. }else{
  1949. yAxisValue.Add(0f);
  1950. }
  1951. }
  1952. foreach (float item in yAxisValue){
  1953. 電費_chart.AddData(s, item);
  1954. }
  1955. }
  1956. }else{
  1957. List<string> xAxisValue = new List<string>(){"01","02","03","04","05","06","07","08","09","10","11","12"};
  1958. for (int h = 0; h < xAxisValue.Count; h++){
  1959. 電費_chart.AddXAxisData(xAxisValue[h]);
  1960. }
  1961. int k=0;
  1962. for(int s=0;s<=E_year-N_year;s++){
  1963. DateTime localTime = new DateTime(N_year,N_month,N_day);
  1964. DateTime day2 = localTime.AddYears(s);
  1965. 電費_chart.AddSerie<Line>(day2.Year.ToString());
  1966. List<float> yAxisValue = new List<float>();
  1967. for(int g=0;g<=11;g++){
  1968. if(k<=ds1.Tables[0].Rows.Count-1){
  1969. if(ds1.Tables[0].Rows[k][1].ToString().PadLeft(2,'0') == xAxisValue[g]){
  1970. yAxisValue.Add(Single.Parse(ds1.Tables[0].Rows[k][2].ToString()));
  1971. k++;
  1972. }else{
  1973. yAxisValue.Add(0f);
  1974. }
  1975. }else{
  1976. yAxisValue.Add(0f);
  1977. }
  1978. }
  1979. foreach (float item in yAxisValue){
  1980. 電費_chart.AddData(s, item);
  1981. }
  1982. }
  1983. }
  1984. 電費_chart.GetSerie<Line>(0).itemStyle.color=new Color(0.97f, 0.48f, 0.99f, 1f);
  1985. foreach (var series in 電費_chart.series)
  1986. {
  1987. series.symbol.type = SymbolType.Circle;
  1988. }
  1989. }
  1990. public void 切換區間時間(){
  1991. if(Global.第一區間表格完畢){
  1992. 讀取_pl.SetActive(true);
  1993. if(區間_開始_月_cb.value==0 && 區間_開始_日_cb.value==0){
  1994. Global.電能報表區間時間選擇="月";
  1995. }else if(區間_開始_月_cb.value !=0 && 區間_開始_日_cb.value==0){
  1996. Global.電能報表區間時間選擇="日";
  1997. }else if(區間_開始_月_cb.value !=0 && 區間_開始_日_cb.value!=0){
  1998. Global.電能報表區間時間選擇="小時";
  1999. }
  2000. Moudle.載入日期(2,區間_開始_年_cb,區間_開始_月_cb,區間_開始_日_cb);
  2001. 建立區間表格();
  2002. }
  2003. }
  2004. public void 切換電費時間(int num){
  2005. if(num==1){
  2006. 電費_開始_小時_cb.interactable=true;
  2007. 電費_結束_小時_cb.interactable=true;
  2008. Main.Global.電能報表電費時間選擇="小時";
  2009. }else if(num==2){
  2010. 電費_開始_小時_cb.interactable=false;
  2011. 電費_結束_小時_cb.interactable=false;
  2012. Main.Global.電能報表電費時間選擇="日";
  2013. }else{
  2014. 電費_開始_小時_cb.interactable=false;
  2015. 電費_結束_小時_cb.interactable=false;
  2016. Main.Global.電能報表電費時間選擇="月";
  2017. }
  2018. 建立電費表格();
  2019. }
  2020. public void 觸發刷新表格(int num){
  2021. if(載入完畢){
  2022. if(num==1){
  2023. 建立年度表格();
  2024. }else if(num==2){
  2025. 建立區間表格();
  2026. }else{
  2027. 建立電費表格();
  2028. }
  2029. }
  2030. }
  2031. //====================================================
  2032. public void 按鈕事件(string text){
  2033. if(int.Parse(text[^8..])>=-1){
  2034. int index = int.Parse(text[^8..]);
  2035. 副電表編號_tb.text = Global.電表名稱[index].ToString();
  2036. Global.paint_choice3=true;
  2037. if(PlayerPrefs.HasKey("副電表編號")){
  2038. PlayerPrefs.DeleteKey("副電表編號");
  2039. }
  2040. PlayerPrefs.SetString("副電表編號",副電表編號_tb.text);
  2041. 載入副電表資料();
  2042. 載入圖表上限();
  2043. 切換排碳時間();
  2044. }
  2045. }
  2046. public static void 按鈕事件2(GameObject item){
  2047. }
  2048. public void OnButtonPress(int num){
  2049. if (Time.time - lastButtonPressTime > maxButtonPressInterval)
  2050. {
  2051. buttonPressCount = 0;
  2052. }
  2053. else
  2054. {
  2055. buttonPressCount++;
  2056. }
  2057. lastButtonPressTime = Time.time;
  2058. if (buttonPressCount >= requiredButtonPressCount)
  2059. {
  2060. // 触发你想要的事件
  2061. Debug.Log("连点触发:"+num);
  2062. Main.Global.連點[num]=true;
  2063. buttonPressCount = 0; // 重置计数器
  2064. }
  2065. }
  2066. //=================更新數值===========================
  2067. public static void 更新SQL成功(){
  2068. Global.SQL成功+=1;
  2069. }
  2070. public static void 更新SQL失敗(){
  2071. Global.SQL失敗+=1;
  2072. }
  2073. //==================================================
  2074. public void 測試按鈕(){
  2075. //StartCoroutine(PostRequest(0,"123"));
  2076. }
  2077. IEnumerator PostRequest(int num,string comm,string data){
  2078. string Url = Global.PHP路徑;
  2079. WWWForm form = new();
  2080. form.AddField("comm", comm);
  2081. form.AddField("data", data);
  2082. UnityWebRequest www = UnityWebRequest.Post(Url, form);
  2083. yield return www.SendWebRequest();
  2084. if (www.result == UnityWebRequest.Result.Success){
  2085. if(num==10){
  2086. Debug.Log(www.downloadHandler.text);
  2087. SQL_CommString.SQL_連線字串_正式_電控SQL(www.downloadHandler.text);
  2088. //SQL_CommString.SQL_連線字串_電控資料SQL(www.downloadHandler.text,DateTime.Now.Year.ToString().PadLeft(4,'0'),Global.客戶代號);
  2089. Global.PHP_Load_End_取得資料庫路徑=true;
  2090. }else if(num==11){
  2091. Debug.Log(www.downloadHandler.text);
  2092. Global.電表即時路徑=www.downloadHandler.text;
  2093. Global.PHP_Load_End_電表即時路徑=true;
  2094. }else if(num==12){
  2095. //Debug.Log(www.downloadHandler.text);
  2096. if(www.downloadHandler.text=="true"){
  2097. Global.資料來源="PLC";
  2098. 提供的有效電能_tb.text="0 GWh";接收的有效電能_tb.text="0 GWh";提供加接收的有效電能_tb.text="0 GWh";提供減接收的有效電能_tb.text="0 GWh";
  2099. 提供的無效電能_tb.text="0 GWh";接收的無效電能_tb.text="0 GWh";提供加接收的無效電能_tb.text="0 GWh";提供減接收的無效電能_tb.text="0 GWh";
  2100. 提供的視在電能_tb.text="0 GWh";接收的視在電能_tb.text="0 GWh";提供加接收的視在電能_tb.text="0 GWh";提供減接收的視在電能_tb.text="0 GWh";
  2101. }else{
  2102. Global.資料來源="pi";
  2103. 提供的有效電能_tb.text="0 GWh";接收的有效電能_tb.text="0 GWh";提供加接收的有效電能_tb.text="0 GWh";提供減接收的有效電能_tb.text="0 GWh";
  2104. 提供的無效電能_tb.text="0 GWh";接收的無效電能_tb.text="0 GWh";提供加接收的無效電能_tb.text="0 GWh";提供減接收的無效電能_tb.text="0 GWh";
  2105. 提供的視在電能_tb.text="0 GWh";接收的視在電能_tb.text="0 GWh";提供加接收的視在電能_tb.text="0 GWh";提供減接收的視在電能_tb.text="0 GWh";
  2106. }
  2107. Debug.Log("資料來源:"+Global.資料來源);
  2108. }
  2109. }else{
  2110. Debug.LogError("POST 請求失敗:" + www.error);
  2111. if(num==0){
  2112. Global.PHP_Report=www.error;
  2113. }else if(num==10){
  2114. 讀取_pl.SetActive(false);
  2115. 彈跳_pl.SetActive(true);
  2116. 彈跳文字_tb.text = "伺服器讀取資料異常\n請稍後在試!";
  2117. Global.彈跳狀態="伺服器異常";
  2118. }
  2119. }
  2120. www.Dispose();
  2121. }
  2122. IEnumerator PostRequest_電表資料PLC(int num,string data){
  2123. string Url = Global.電表即時路徑;
  2124. WWWForm form = new();
  2125. form.AddField("data", data);
  2126. UnityWebRequest www = UnityWebRequest.Post(Url, form);
  2127. yield return www.SendWebRequest();
  2128. if (www.result == UnityWebRequest.Result.Success){
  2129. if(num==0){
  2130. Global.PHP_Report=www.downloadHandler.text;
  2131. Global.PHP_Load_End=true;
  2132. }else if(num==1){
  2133. Global.PHP_Report2=www.downloadHandler.text;
  2134. Global.PHP_Load_End2=true;
  2135. }else if(num==2){
  2136. Global.PHP_Report3=www.downloadHandler.text;
  2137. Global.PHP_Load_End3=true;
  2138. }else if(num==3){
  2139. Global.PHP_Report4=www.downloadHandler.text;
  2140. Global.PHP_Load_End4=true;
  2141. }else if(num==4){
  2142. Global.PHP_Report5=www.downloadHandler.text;
  2143. Global.PHP_Load_End5=true;
  2144. }else if(num==5){
  2145. Global.PHP_Report6=www.downloadHandler.text;
  2146. Global.PHP_Load_End6=true;
  2147. }else if(num==6){
  2148. Global.PHP_Report7=www.downloadHandler.text;
  2149. Global.PHP_Load_End7=true;
  2150. }else if(num==7){
  2151. Global.PHP_Report8=www.downloadHandler.text;
  2152. Global.PHP_Load_End8=true;
  2153. }else if(num==8){
  2154. Global.電表異常num=int.Parse(data.Substring(6,1));
  2155. Global.PHP_Report9=www.downloadHandler.text;
  2156. Global.PHP_Load_End9=true;
  2157. }else if(num==9){
  2158. Global.PHP_Report10=www.downloadHandler.text;
  2159. Global.PHP_Load_End10=true;
  2160. }
  2161. }else{
  2162. Debug.LogError("POST 請求失敗:" + www.error);
  2163. if(num==0){
  2164. Global.PHP_Report=www.error;
  2165. }
  2166. }
  2167. www.Dispose();
  2168. }
  2169. IEnumerator PostRequest_電表資料(string 電表流水號){
  2170. string Url = Global.電表即時路徑;
  2171. WWWForm form = new();
  2172. form.AddField("comm", 電表流水號);
  2173. UnityWebRequest www = UnityWebRequest.Post(Url, form);
  2174. yield return www.SendWebRequest();
  2175. if (www.result == UnityWebRequest.Result.Success){
  2176. string[] dataStringArray = www.downloadHandler.text.Split(',');
  2177. if(Global.電表即時資料字典.ContainsKey(電表流水號)){
  2178. Global.電表即時資料字典.Remove(電表流水號);
  2179. }
  2180. Global.電表即時資料字典.Add(電表流水號,dataStringArray);
  2181. }else{
  2182. Debug.LogError("POST 請求失敗:" + www.error);
  2183. Global.PHP_Report=www.error;
  2184. }
  2185. www.Dispose();
  2186. }
  2187. public void close_sys(){
  2188. #if UNITY_EDITOR
  2189. UnityEditor.EditorApplication.isPlaying = false;
  2190. #else
  2191. Application.Quit();
  2192. #endif
  2193. }
  2194. IEnumerator AnimateText(){
  2195. string qqq = 讀取_tb.text.ToString();
  2196. while (true){
  2197. yield return new WaitForSeconds(0.5f);
  2198. if (dotCount < 3){
  2199. loadingText += ".";
  2200. dotCount++;
  2201. }else{
  2202. loadingText = "";
  2203. dotCount = 0;
  2204. }
  2205. 讀取_tb.text = qqq+loadingText;
  2206. }
  2207. }
  2208. //==========Mute SOund=======================
  2209. public void Mute_Sound(Button but){
  2210. if(Global.Ele_alarm_sound==true){
  2211. Global.Ele_alarm_sound=false;
  2212. but.image.sprite=控件圖片[2];
  2213. }else{
  2214. Global.Ele_alarm_sound=true;
  2215. but.image.sprite=控件圖片[1];
  2216. }
  2217. }
  2218. public void OpenWebsite(){
  2219. string websiteURL = "https://gcm-smart.com/";
  2220. // 在瀏覽器中打開指定的網站
  2221. Application.OpenURL(websiteURL);
  2222. }
  2223. public void 截圖(){
  2224. string fileName = string.Format("{0}/screenshot_{1}.png", Application.persistentDataPath, System.DateTime.Now.ToString("yyyyMMdd_HHmmss"));
  2225. ScreenCapture.CaptureScreenshot(fileName);
  2226. }
  2227. public static class Global{
  2228. public static string 客戶代號="GCM",年="2024",區間_開始時間,區間_結束時間,系統選擇,資料來源="PLC",彈跳狀態,PHP路徑="",電表即時路徑="";
  2229. public static string 主電表上次編號,Vavg,Iavg,Etol,副電表上次編號,PHP_Report_PLC_ALARM_DATA,主電表上次異常內容,副電表上次異常內容,幣別="台幣",試算_開始時間,試算_結束時間;
  2230. public static string 電能報表區間時間選擇,電能報表電費時間選擇,Vab,Vbc,Vca,NVab,NVbc,NVca,Ia,Ib,Ic,NIa,NIb,NIc;
  2231. public static string PHP_Report,PHP_Report2,PHP_Report3,PHP_Report4,PHP_Report5,PHP_Report6,PHP_Report7,PHP_Report8,PHP_Report9,PHP_Report10;
  2232. public static string PHP_Report_資料庫路徑,PHP_Report_電表即時路徑;
  2233. public static bool PHP_Load_End=false,PHP_Load_End2=false,PHP_Load_End3=false,PHP_Load_End4=false,PHP_Load_End5=false,PHP_Load_End6=false,PHP_Load_End7=false,PHP_Load_End8=false,PHP_Load_End9=false,PHP_Load_End10=false;
  2234. public static bool PHP_Load_End_取得資料庫路徑=false,PHP_Load_End_電表即時路徑=false;
  2235. public static int 功率因素數值=98,副功率因素數值=98,詳細功率因素數值=98,上次功率因素數值=0,上次副功率因素數值=0,Zoneoffset=0,上次更新天數,SQL成功,SQL失敗,電表數量=0;
  2236. public static int 系統主題=2,電表ID1,電表ID2,消防異常page=1,上次消防異常ID,電費_總和,詳細電表電表ID,電表異常num,上限電表ID1,上限電表ID2;
  2237. public static float deleytime=0f,區間_總和=0f;
  2238. public static bool 初次載入主畫面=true,SQL_S=false,內網=false,載入電表名稱Option=true,paint_choice=true,paint_choice2=true,paint_choice3=true;
  2239. public static bool 副電表有異常=false,Ele_alarm_sound=true,風格切換_cos主=false,風格切換_cos副=false;
  2240. public static bool 載入電表名稱=false,載入年度=false,載入月份=false,報表載入月份=false,長案=false,第一區間表格完畢=false;
  2241. public static string[] 電表名稱 = new string[999];
  2242. public static string[] 電表功率單位 = new string[999];
  2243. public static string[] 圖表最大電壓 = new string[999];
  2244. public static string[] 圖表最大電流 = new string[999];
  2245. public static string[] 圖表最大功率 = new string[999];
  2246. public static string[] 目前開始月份 = new string[50],上次開始月份 = new string[50],目前結束月份 = new string[50],上次結束月份 = new string[50];
  2247. public static string[] 目前開始年度 = new string[50],上次開始年度 = new string[50],目前結束年度 = new string[50],上次結束年度 = new string[50];
  2248. public static List<string> 電表名稱Option = new List<string>();
  2249. public static List<string> 年度Options = new List<string> { "2023","2024","2025","2026","2027","2028","2029","2030","2031","2032","2033","2034","2035","2036","2037","2038","2039","2040","2041","2042","2043","2044","2045","2046","2047","2048","2049","2050","2051"};
  2250. public static List<string> 月份Options_中 = new List<string> { "一月","二月","三月","四月","五月","六月","七月","八月","九月","十月","十一月","十二月" };
  2251. public static List<string> 小時Options = new List<string> { "","00","01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23"};
  2252. public static TimeSpan 運行天數;
  2253. public static DataTable 電表資料清單,電表資料資料庫清單,年度表格,區間表格,電費表格,排碳係數表;
  2254. //public static List<string> 電表資料資料庫名稱 = new() {};
  2255. //==========系統語言轉換必要變數================
  2256. public static string[] 系統語言資料;
  2257. //public static Dictionary<string, string> 系統語言字典 = new Dictionary<string, string>(){ };
  2258. public static Dictionary<string, string[]> 電表即時資料字典 = new (){ };
  2259. //============================================
  2260. public static string PA, PB, PC, PD, PE, PF, PG, PH, PI, PJ, PK, PA1, PA2, PA3, PA4, PA5, PA6, PA9, PA20, PA7;
  2261. public static string[] 表頭 = new string[50];
  2262. public static bool[] 電表異常BL = new bool[100],連點 = new bool[5];
  2263. public static Sprite[] Wnum;public static Sprite sprite_check,sprite_box;
  2264. }
  2265. }