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