From 9c33e4ccb90fae87a614abd2ed1ab034d3b7a13d Mon Sep 17 00:00:00 2001 From: JLChen <551775569@qq.com> Date: 星期五, 26 三月 2021 11:26:01 +0800 Subject: [PATCH] 2021-03-26 1.对接接口优化。 --- HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/PirMain.cs | 312 +++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 226 insertions(+), 86 deletions(-) diff --git a/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/PirMain.cs b/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/PirMain.cs index 98c3e74..b4a9f34 100644 --- a/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/PirMain.cs +++ b/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/PirMain.cs @@ -1,5 +1,6 @@ 锘縰sing System; using System.Collections.Generic; +using System.Text; using HDL_ON.Entity; using HDL_ON.UI.UI2.Intelligence.Automation.LogicView; using Shared; @@ -10,6 +11,7 @@ public PirMain() { Tag = "PirMain"; + } /// <summary> /// 涓存椂鍌ㄥ瓨璁惧绫诲瀷鍒楄〃 @@ -178,6 +180,11 @@ Text = "mini鏅鸿兘閬ユ帶鍣�", }; deviceListFLayout.AddChidren(deviceNameBtn); + if (Pir.pirDeviceList.Count != 0) + { + deviceNameBtn.Text = Pir.pirDeviceList[0].name; + Pir.currPir = Pir.pirDeviceList[0]; + } //涓嬫媺鍥炬爣 var dropdownIconBtn = new Button @@ -204,7 +211,7 @@ fLayout.RemoveFromParent(); }; - FrameLayout iconFLyout = new FrameLayout + FrameLayout iconFLyout = new FrameLayout { X = Application.GetRealWidth(205), Y = Application.GetRealHeight(314), @@ -214,23 +221,22 @@ }; fLayout.AddChidren(iconFLyout); - FrameLayout textFLyout = new FrameLayout + FrameLayout textFLyout = new FrameLayout { X = Application.GetRealWidth(8), Y = Application.GetRealHeight(14), Width = Application.GetRealWidth(144), Height = Application.GetRealHeight(44), }; - VerticalScrolViewLayout vv = new VerticalScrolViewLayout + VerticalScrolViewLayout vv = new VerticalScrolViewLayout { X = Application.GetRealWidth(8), Y = Application.GetRealHeight(14), Width = Application.GetRealWidth(144), Height = Application.GetRealHeight(44 * 4), }; - var pirDeviceList = new List<int> { 1, 2, 3,4,5,6, }; - if (pirDeviceList.Count >4) + if (Pir.pirDeviceList.Count > 4) { iconFLyout.Height = Application.GetRealHeight(21 + 44 * 4); iconFLyout.AddChidren(vv); @@ -240,17 +246,17 @@ { iconFLyout.AddChidren(textFLyout); - iconFLyout.Height = Application.GetRealHeight(21 + 44 * pirDeviceList.Count); - textFLyout.Height = Application.GetRealHeight(44 * pirDeviceList.Count); - iconFLyout.BackgroundImagePath = $"PirIcon/{pirDeviceList.Count}.png"; + iconFLyout.Height = Application.GetRealHeight(21 + 44 * Pir.pirDeviceList.Count); + textFLyout.Height = Application.GetRealHeight(44 * Pir.pirDeviceList.Count); + iconFLyout.BackgroundImagePath = $"PirIcon/{Pir.pirDeviceList.Count}.png"; } #endregion - for (int i = 0; i < pirDeviceList.Count; i++) + for (int i = 0; i < Pir.pirDeviceList.Count; i++) { - var room = pirDeviceList[i]; - View.PirNameView pirNameView = new View.PirNameView(); - if (pirDeviceList.Count > 4) + var pirJson = Pir.pirDeviceList[i]; + View.PirNameView pirNameView = new View.PirNameView(); + if (Pir.pirDeviceList.Count > 4) { vv.AddChidren(pirNameView.FLayoutView()); } @@ -259,14 +265,16 @@ pirNameView.frameLayout.Y = Application.GetRealHeight(i * 44); textFLyout.AddChidren(pirNameView.FLayoutView()); } - pirNameView.btnName.Text = room.ToString(); - pirNameView.btnClick.Tag = room; + pirNameView.btnName.Text = pirJson.name; + pirNameView.btnClick.Tag = pirJson; pirNameView.btnClick.MouseUpEventHandler += (sender2, e2) => { fLayout.RemoveFromParent(); - + deviceNameBtn.Text = pirJson.name; + Pir.currPir = pirJson; + }; - if (pirDeviceList.Count - 1 == i) + if (Pir.pirDeviceList.Count - 1 == i) { ///鏀瑰彉鏈�鍚庨偅鏉′竴涓嚎鐨勯鑹�,鐣岄潰鏄剧ず鏁堟灉浣滅敤; pirNameView.btnLine.BackgroundColor = CSS.CSS_Color.view; @@ -318,12 +326,14 @@ GetIconAndText(i, deviceIconBtn, iconNameBtn); clickBtn.MouseUpEventHandler += (sender, e) => { + //1=绌鸿皟;2=鐢佃;3=椋庢墖;4=鏈洪《鐩�;5=DVD/EVD/VCD;6=鎶曞奖浠�;7=鑷畾涔�; int if_value = int.Parse(clickBtn.Tag.ToString()); if (if_value == 7) { Method method = new Method(); - method.AddControl(this,(control) => { + method.AddControl(this, (control) => + { AddButton addButton = new AddButton(); MainPage.BasePageView.AddChidren(addButton); addButton.Show(control); @@ -340,35 +350,209 @@ } GetBrandList(jobDeviceType.id, (brandList) => { - var brandSupportStrList= GetBrandSupport(if_value); + var brandSupportStrList = GetBrandSupport(if_value); var strList = new List<string>(); for (int str = 0; str < brandList.Count; str++) { string s = brandList[str].brandName; - var bool_if = brandSupportStrList.Find((c)=>s.Contains(c)); - if (bool_if!=null) - { - strList.Add(s); - } + //var bool_if = brandSupportStrList.Find((c) => s.Contains(c)); + //if (bool_if != null) + //{ + // strList.Add(s); + //} + strList.Add(s); } - Application.RunOnMainThread(()=> { - BrandList brandObj = new BrandList(); - MainPage.BasePageView.AddChidren(brandObj); - brandObj.Show(brandList, strList, strings[1]); - MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; - }); - + //Application.RunOnMainThread(() => + //{ + // BrandList brandObj = new BrandList(); + // MainPage.BasePageView.AddChidren(brandObj); + // brandObj.Show(brandList, strList, strings[1]); + // MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; + + //}); + + GoToShowSortSelection(strList); + }); - + } - + }; } GetDeviceTypeList(); + } + + void GoToShowSortSelection(List<string> dataList) + { + Dictionary<string, List<string>> dict = new Dictionary<string, List<string>>(); + + foreach (var data in dataList) + { + //鎻愬彇瀛楃涓茬涓�浣� + //string s = data.Substring(0, 1); + var key = GetCharSpellCode(data); + + if (dict.ContainsKey(key)) + { + var value = dict[key]; + if (value == null) + { + value = new List<string>(); + } + value.Add(data); + + + } + else + { + var value = new List<string>(); + value.Add(data); + dict.Add(key, value); + } + + + } + + + Application.RunOnMainThread(() => + { + JLCountrycode.CountryCodeView.Current.ShowSortSelection("閫夋嫨绾㈠鍝佺墝", dict, (countryName) => + { + //Console.WriteLine("countryName: " + countryName); + Utlis.ShowTip("閫変腑浜�:" + countryName); + + + }); + }); + } + + /// <summary> + /// 鑾峰彇姹夊瓧棣栧瓧姣� + /// </summary> + /// <param name="textValue"></param> + /// <returns></returns> + private string GetCharSpellCode(string textValue) + { + long iCnChar; + + byte[] ZW = Encoding.GetEncoding("gb2312").GetBytes(textValue); + + //濡傛灉鏄瓧姣嶏紝鍒欑洿鎺ヨ繑鍥� + if (ZW.Length == 1) + { + return textValue.ToUpper(); + } + else + { + // get the array of byte from the single char + int i1 = (short)(ZW[0]); + int i2 = (short)(ZW[1]); + iCnChar = i1 * 256 + i2; + } + + + + // iCnChar match the constant + if ((iCnChar >= 45217) && (iCnChar <= 45252)) + { + return "A"; + } + else if ((iCnChar >= 45253) && (iCnChar <= 45760)) + { + return "B"; + } + else if ((iCnChar >= 45761) && (iCnChar <= 46317)) + { + return "C"; + } + else if ((iCnChar >= 46318) && (iCnChar <= 46825)) + { + return "D"; + } + else if ((iCnChar >= 46826) && (iCnChar <= 47009)) + { + return "E"; + } + else if ((iCnChar >= 47010) && (iCnChar <= 47296)) + { + return "F"; + } + else if ((iCnChar >= 47297) && (iCnChar <= 47613)) + { + return "G"; + } + else if ((iCnChar >= 47614) && (iCnChar <= 48118)) + { + return "H"; + } + else if ((iCnChar >= 48119) && (iCnChar <= 49061)) + { + return "J"; + } + else if ((iCnChar >= 49062) && (iCnChar <= 49323)) + { + return "K"; + } + else if ((iCnChar >= 49324) && (iCnChar <= 49895)) + { + return "L"; + } + else if ((iCnChar >= 49896) && (iCnChar <= 50370)) + { + return "M"; + } + + else if ((iCnChar >= 50371) && (iCnChar <= 50613)) + { + return "N"; + } + else if ((iCnChar >= 50614) && (iCnChar <= 50621)) + { + return "O"; + } + else if ((iCnChar >= 50622) && (iCnChar <= 50905)) + { + return "P"; + } + else if ((iCnChar >= 50906) && (iCnChar <= 51386)) + { + return "Q"; + } + else if ((iCnChar >= 51387) && (iCnChar <= 51445)) + { + return "R"; + } + else if ((iCnChar >= 51446) && (iCnChar <= 52217)) + { + return "S"; + } + else if ((iCnChar >= 52218) && (iCnChar <= 52697)) + { + return "T"; + } + else if ((iCnChar >= 52698) && (iCnChar <= 52979)) + { + return "W"; + } + else if ((iCnChar >= 52980) && (iCnChar <= 53640)) + { + return "X"; + } + else if ((iCnChar >= 53689) && (iCnChar <= 54480)) + { + return "Y"; + } + else if ((iCnChar >= 54481) && (iCnChar <= 55289)) + { + return "Z"; + } + else return (""); + } + /// <summary> /// 鑾峰彇鍝佺墝鏀寔 /// </summary> @@ -417,7 +601,7 @@ { } break; - + } return strList; @@ -434,13 +618,13 @@ case 1: { //绌鸿皟 - type = "ac-"+SPK.AcIr; + type = "ac-" + SPK.AcIr; } break; case 2: { //鐢佃 - type = "tv-"+SPK.ElectricTV; + type = "tv-" + SPK.ElectricTV; } break; case 3: @@ -452,22 +636,22 @@ case 4: { //鏈洪《鐩� - // type = "set_top_box-" + SPK.ElectricTV; + // type = "set_top_box-" + SPK.ElectricTV; } break; case 5: { - //褰辩鏈� - // type = "dvd-" + SPK.ElectricTV; + //褰辩鏈� + // type = "dvd-" + SPK.ElectricTV; } break; case 6: { //鎶曞奖浠� - // type = "projector-" + SPK.ElectricTV; + // type = "projector-" + SPK.ElectricTV; } break; - + } return type; @@ -565,11 +749,10 @@ } }, "", "璁惧绫诲瀷鍒楄〃"); } - /// <summary> /// 璇诲彇绾㈠璁惧绫诲瀷鐨勫搧鐗屽垪琛� /// </summary> - private void GetBrandList(string id,Action<List<Brand>> actionBrand) + private void GetBrandList(string id, Action<List<Brand>> actionBrand) { List<Brand> brandList = new List<Brand>(); PirSend.GetDeviceTypesList(this, (responsePackNew) => @@ -602,49 +785,6 @@ } }, id, "鍝佺墝鍒楄〃"); } - - - /// <summary> - /// 鑾峰彇绾㈠璁惧鍒楄〃 - /// </summary> - private void GetPirDeviceList( ) - { - - //鍔犺浇log - Loading loading = new Loading(); - this.AddChidren(loading); - HDL_ON.DAL.Server.ResponsePackNew responsePackNew = null; - loading.Start(); - new System.Threading.Thread(() => - { - try - { - //鍙戦�佹寜閿垹闄わ紱 - responsePackNew = PirSend.GetDeviceList("ir.module"); - } - catch { } - finally - { - Application.RunOnMainThread(() => - { - loading.Hide(); - if (responsePackNew != null && responsePackNew.Code == "0" && responsePackNew.Data.ToString() != "") - { - - } - else - { - Method method = new Method(); - method.ErrorShow(responsePackNew); - } - - }); - } - - }) - { IsBackground = true }.Start(); - } - } - + } -- Gitblit v1.8.0