暂无描述
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

Main.cs 145KB

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