From 44d6b49d86f8c531cbed718a8c109f3bc2db2177 Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期三, 09 八月 2023 16:27:23 +0800 Subject: [PATCH] 2023年08月09日16:27:16 --- HDL_ON/UI/UI2/FuntionControlView/Aks/CommonView/CornerFramLayout.cs | 213 +++++++++++++++++++++++++++++++++++++++-------------- 1 files changed, 156 insertions(+), 57 deletions(-) diff --git a/HDL_ON/UI/UI2/FuntionControlView/Aks/CommonView/CornerFramLayout.cs b/HDL_ON/UI/UI2/FuntionControlView/Aks/CommonView/CornerFramLayout.cs index be71892..63c868a 100644 --- a/HDL_ON/UI/UI2/FuntionControlView/Aks/CommonView/CornerFramLayout.cs +++ b/HDL_ON/UI/UI2/FuntionControlView/Aks/CommonView/CornerFramLayout.cs @@ -2,6 +2,7 @@ using HDL_ON.UI.Music; using Shared; using System.Collections.Generic; +using HDL_ON.UI.UI2.FuntionControlView.Aks.Entity; namespace HDL_ON.UI.UI2.FuntionControlView.Aks.CommonView { @@ -18,10 +19,12 @@ /// 涓�琛屽嚑涓厓绱� /// </summary> private int mRowNumber; + /// <summary> + /// 鍒楄〃鏈�澶у�� + /// </summary> + private int mListCount; - private List<string> mList; - - public Action<string> selectAction = null; + public Action<KeypadEntity> selectAction = null; /// <summary> /// 褰撳墠閫夋嫨鐨勭储寮�(鍐呴儴浣跨敤) /// </summary> @@ -33,15 +36,13 @@ /// </summary> /// <param name="width">瀹瑰櫒瀹藉害</param> /// <param name="height">瀹瑰櫒楂樺害</param> - ///<param name="rowNumber">涓�琛屽嚑涓厓绱�</param> ///<param name="rowNumber">鍦嗚鍊�</param> - public CornerFramLayout(int width, int height, int rowNumber = 0, int radius = 0) + public CornerFramLayout(int width, int height, int radius = 0) { this.BackgroundColor = MusicColor.WhiteColor; this.Width = Application.GetRealWidth(width); this.Height = Application.GetRealHeight(height); this.Radius = (uint)Application.GetRealHeight(radius); - this.mRowNumber = rowNumber; } @@ -60,57 +61,37 @@ this.rightMargin = right; } - /// <summary> - /// 璁剧疆鍒楄〃鏁版嵁(璇峰湪鍒濆鍖栧畬鎴愪箣鍓嶈皟鐢�) - /// </summary> - /// <param name="list"></param> - public void SetList(List<string> list) - { - if (list == null) - { - list = new List<string>(); - } - this.mList = list; - } + /// <summary> /// 鑾峰彇娴嬭瘯鍒楄〃鏁版嵁 /// </summary> - public List<string> GetTestList(int count) + public List<KeypadEntity> GetTestList() { - var list = new List<string>(); - for (int i = 1; i <= count; i++) - { - if (i % 2 == 0) - { - list.Add("浣犲ソ鍌诲摝!"); - } - else - { - list.Add("鐪熺殑鏄繖鏍风殑鍚�?"); - } - } - return list; + return AksCommonMethod.Current.GetTYYKeypadList(); } /// <summary> /// 鍔ㄦ�佸姞杞芥寜閿晫闈� - /// (娉ㄦ剰:mRowNumber!=0) /// </summary> - public void LoadButtonPage() + /// <param name="mList">鍒楄〃</param> + /// <param name="mRowNumber">涓�琛屽灏戜釜鍏冪礌</param> + public void LoadButtonPage(List<KeypadEntity> mList, int mRowNumber) { - if (this.mRowNumber == 0) + if (mRowNumber == 0) { return; } + this.mRowNumber = mRowNumber; + this.mListCount = mList.Count; int line = 0; int xCount = 0; - for (int i = 1; i <= this.mList.Count; i++) + for (int i = 1; i <= mList.Count; i++) { - var d = this.mList[i - 1]; + var keypad = mList[i - 1]; ButtonFramLayout buttonFram = new ButtonFramLayout(); this.AddChidren(buttonFram); - buttonFram.Tag = d; + buttonFram.Tag = keypad; buttonFram.Y = Application.GetRealHeight(this.topMargin) + Application.GetRealHeight(ButtonFramLayout.heightFrameLayout * line); buttonFram.X = Application.GetRealWidth(this.leftMargin) + Application.GetRealWidth(ButtonFramLayout.widthFrameLayout * xCount); buttonFram.AddImageView(); @@ -123,7 +104,8 @@ { buttonFram.AddBottomLine(); } - buttonFram.GetNameButton().Text = d; + buttonFram.GetImageButton().UnSelectedImagePath = keypad.localIconAddress; + buttonFram.GetNameButton().Text = keypad.name; xCount++; if (i % this.mRowNumber == 0) @@ -136,7 +118,7 @@ { if (buttonFram.Tag != null) { - selectAction?.Invoke(buttonFram.Tag.ToString()); + selectAction?.Invoke((KeypadEntity)buttonFram.Tag); } }); @@ -152,8 +134,9 @@ /// <summary> /// 鍔ㄦ�佸姞杞芥寜閿晫闈� /// </summary> - /// <param name="list">绱㈠紩鍒楄〃,琛ㄧず鏌愪竴鏉″搴﹀姞瀹�</param> - public void LoadButtonPage(List<int> list) + /// <param name="mList">鍒楄〃</param> + /// <param name="list">鍒楄〃涓储寮�,琛ㄧず鏌愪竴鏉″搴﹀姞瀹�</param> + public void LoadButtonPage(List<KeypadEntity> mList, List<int> list) { int currnetheightValue = 0; @@ -161,9 +144,9 @@ //鑾峰彇鐩稿涓�涓含搴﹀�� int heightDimensionValue = this.Height - Application.GetRealHeight(this.topMargin) - Application.GetRealHeight(this.bottomMargin) - Application.GetRealHeight(ButtonFramLayout.heightFrameLayout / 2); int widthDimensionValue = this.Width - Application.GetRealWidth(this.leftMargin) - Application.GetRealWidth(this.rightMargin) - Application.GetRealHeight(ButtonFramLayout.widthFrameLayout / 2); - for (int i = 1; i <= this.mList.Count; i++) + for (int i = 1; i <= mList.Count; i++) { - var d = this.mList[i - 1]; + var keypad = mList[i - 1]; ButtonFramLayout buttonFram = null; if (list.Contains(i)) { @@ -184,8 +167,9 @@ this.AddChidren(buttonFram); buttonFram.AddImageView(); buttonFram.AddNameView(); - buttonFram.Tag = d;//鏍囪鏁版嵁 - buttonFram.GetNameButton().Text = d.ToString(); + buttonFram.Tag = keypad;//鏍囪鏁版嵁 + buttonFram.GetImageButton().UnSelectedImagePath = keypad.localIconAddress; + buttonFram.GetNameButton().Text = keypad.name; if (widthDimensionValue > Application.GetRealWidth(currnetWidthValue)) { //鍔犲彸绾� @@ -208,7 +192,7 @@ { if (buttonFram.Tag != null) { - selectAction?.Invoke(buttonFram.Tag.ToString()); + selectAction?.Invoke((KeypadEntity)buttonFram.Tag); } }); @@ -219,27 +203,131 @@ } } + /// <summary> + ///鍔ㄦ�佸姞杞芥暟瀛楁寜閿晫闈� + /// </summary> + public void LoadNumberButtonPage(List<KeypadEntity> mList) + { + + int currnetheightValue = 0; + int currnetWidthValue = 0; + int heightMaxValue = 84; + int widthMaxValue = 78; + //鑾峰彇鐩稿涓�涓含搴﹀�� + int heightDimensionValue = this.Height - Application.GetRealHeight(this.topMargin) - Application.GetRealHeight(this.bottomMargin) - Application.GetRealHeight(heightMaxValue / 2); + int widthDimensionValue = this.Width - Application.GetRealWidth(this.leftMargin) - Application.GetRealWidth(this.rightMargin) - Application.GetRealHeight(widthMaxValue / 2); + for (int i = 1; i <= mList.Count; i++) + { + var keypad = mList[i - 1]; + Button button = new Button + { + Y = Application.GetRealHeight(this.topMargin) + Application.GetRealHeight(currnetheightValue), + X = Application.GetRealWidth(this.leftMargin) + Application.GetRealWidth(currnetWidthValue), + Width = Application.GetRealWidth(widthMaxValue), + Height = Application.GetRealHeight(heightMaxValue), + Text = keypad.name, + TextSize = TextSize.Text20, + TextColor = MusicColor.TextColor, + TextAlignment = TextAlignment.Center, + IsBold = true, + Tag = keypad, + BackgroundColor = MusicColor.WhiteColor, + SelectedBackgroundColor = 0xff454635, + }; + this.AddChidren(button); + + currnetWidthValue += widthMaxValue; + if (widthDimensionValue < Application.GetRealWidth(currnetWidthValue)) + { + currnetheightValue += heightMaxValue; + currnetWidthValue = 0; + } + button.MouseDownEventHandler += (sen, e) => + { + if (button.Tag == null || ((KeypadEntity)button.Tag).keypad == "none") + { + return; + } + button.IsSelected = true; + selectAction?.Invoke((KeypadEntity)button.Tag); + }; + button.MouseUpEventHandler += (sen, e) => + { + button.IsSelected = false; + }; + + //if (CurrnetSelectIndex != -1 && CurrnetSelectIndex == i) + //{ + // selectAction?.Invoke((int)buttonFram.Tag); + //} + } + } /// <summary> /// 鍔ㄦ�佸姞杞藉浘鐗囩晫闈� /// </summary> - public void LoadImagePage() + public void LoadImagePage(List<KeypadEntity> mList) { - if (this.mRowNumber == 0) + int currnetheightValue = 0; + int currnetWidthValue = 0; + int heightMaxValue = ImageFramlayout.heightFrameLayout; + int widthMaxValue = ImageFramlayout.widthFrameLayout; + //鑾峰彇鐩稿涓�涓含搴﹀�� + int heightDimensionValue = this.Height - Application.GetRealHeight(this.topMargin) - Application.GetRealHeight(this.bottomMargin) - Application.GetRealHeight(heightMaxValue / 2); + int widthDimensionValue = this.Width - Application.GetRealWidth(this.leftMargin) - Application.GetRealWidth(this.rightMargin) - Application.GetRealHeight(widthMaxValue / 2); + for (int i = 1; i <= mList.Count; i++) + { + var keypad = mList[i - 1]; + ImageFramlayout imageFram = new ImageFramlayout(); + imageFram.AddView(this); + imageFram.Tag = keypad; + imageFram.Y = Application.GetRealHeight(this.topMargin) + Application.GetRealHeight(currnetheightValue); + imageFram.X = Application.GetRealWidth(currnetWidthValue); + imageFram.btnName.Text = keypad.name; + currnetWidthValue += (widthMaxValue + 8);//8鏄殧闂村�� + if (widthDimensionValue < Application.GetRealWidth(currnetWidthValue)) + { + currnetheightValue += (heightMaxValue + 20);//20鏄殧闂村�� + currnetWidthValue = 0; + } + + imageFram.SetClickListener((fl) => + { + if (imageFram.Tag != null) + { + selectAction?.Invoke((KeypadEntity)imageFram.Tag); + } + }); + //if (CurrnetSelectIndex != -1 && CurrnetSelectIndex == i) + //{ + // selectAction?.Invoke((int)imageFram.Tag); + //} + } + } + /// <summary> + /// 鍔ㄦ�佸姞杞藉浘鐗囩晫闈� + /// </summary> + /// <param name="mRowNumber">涓�琛屽灏戜釜鍏冪礌</param> + public void LoadImagePage(List<KeypadEntity> mList, int mRowNumber) + { + + if (mRowNumber == 0) { return; } + this.mListCount = mList.Count; + this.mRowNumber = mRowNumber; int line = 0; int xCount = 0; - for (int i = 1; i <= this.mList.Count; i++) + for (int i = 1; i <= mList.Count; i++) { - var d = this.mList[i - 1]; + var keypad = mList[i - 1]; ImageFramlayout imageFram = new ImageFramlayout(); imageFram.AddView(this); - imageFram.Tag = d; + imageFram.Tag = keypad; imageFram.Y = Application.GetRealHeight(this.topMargin) + Application.GetRealHeight((ImageFramlayout.heightFrameLayout + 20) * line); imageFram.X = Application.GetRealWidth((ImageFramlayout.widthFrameLayout + 8) * xCount); - imageFram.btnName.Text = d; + imageFram.btnName.Text = keypad.name; xCount++; if (i % this.mRowNumber == 0) @@ -252,7 +340,7 @@ { if (imageFram.Tag != null) { - selectAction?.Invoke(imageFram.Tag.ToString()); + selectAction?.Invoke((KeypadEntity)imageFram.Tag); } }); @@ -281,8 +369,12 @@ /// <returns></returns> private bool IsLastColumn(int index) { - int lineCount = this.mList.Count / this.mRowNumber;//寰楀嚭琛屾暟 - int number = this.mList.Count % this.mRowNumber; + if (this.mRowNumber == 0 || mListCount == 0) + { + return false; + } + int lineCount = mListCount / this.mRowNumber;//寰楀嚭琛屾暟 + int number = mListCount % this.mRowNumber; if (number != 0) { if (index > lineCount * this.mRowNumber) @@ -300,7 +392,6 @@ } return false; - } /// <summary> /// 鏈�鍚庡彸杈归偅涓�涓� @@ -309,6 +400,10 @@ /// <returns></returns> private bool IsLastRight(int value) { + if (this.mRowNumber == 0) + { + return false; + } if (value % this.mRowNumber == 0) { return true; @@ -352,5 +447,9 @@ button.Width = width; } + + + + } } -- Gitblit v1.8.0