From a023039e525469ef33bf0324d17d3e954e6b29d7 Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期二, 16 三月 2021 17:54:20 +0800
Subject: [PATCH] 兼容温总的添加红外宝
---
HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/DeviceSet.cs | 494 ++++++++++++++++--------------------------------------
1 files changed, 145 insertions(+), 349 deletions(-)
diff --git a/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/DeviceSet.cs b/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/DeviceSet.cs
index 7f35847..6af3af1 100644
--- a/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/DeviceSet.cs
+++ b/HDL_ON/UI/UI2/4-PersonalCenter/PirDevice/DeviceSet.cs
@@ -19,7 +19,8 @@
topView.topNameBtn.TextID = StringId.shebeigaunli;
topView.topIconBtn.Visible = true;
this.AddChidren(topView.FLayoutView());
- topView.clickBackBtn.MouseUpEventHandler += (sender, e) => {
+ topView.clickBackBtn.MouseUpEventHandler += (sender, e) =>
+ {
action();
this.RemoveFromParent();
};
@@ -32,14 +33,14 @@
//鍏抽棴鍒锋柊View锛�
vv.EndHeaderRefreshing();
//鑾峰彇鍒楄〃
- Method.GetPirDeviceList(this,() =>
- {
- Application.RunOnMainThread(() =>
- {
- //鍒锋柊鐣岄潰
- UIView(vv);
- });
- });
+ Method.GetPirDeviceList(this, () =>
+ {
+ Application.RunOnMainThread(() =>
+ {
+ //鍒锋柊鐣岄潰
+ UIView(vv);
+ });
+ });
};
#endregion
@@ -63,147 +64,32 @@
Height = Application.GetRealHeight(12 + 92 + (50 * pirDevice.FunctioList.Count)),
};
vv.AddChidren(fLayout);
-
- //绾㈠瀹濇樉绀虹埗鎺т欢
- FrameLayout devfLayout = new FrameLayout
- {
- Y = Application.GetRealHeight(12),
- X = Application.GetRealWidth(16),
- Width = Application.GetRealWidth(375 - 16 * 2),
- Height = Application.GetRealHeight(92 + (50 * pirDevice.FunctioList.Count)),
- BackgroundColor = CSS.CSS_Color.view,
- Radius = (uint)Application.GetRealHeight(12),
- };
- fLayout.AddChidren(devfLayout);
-
-
- //绾㈠瀹濆浘鏍�
- Button priequipmentBtn = new Button
- {
- Y = Application.GetRealHeight(16),
- X = Application.GetRealWidth(5),
- Width = Application.GetRealWidth(60),
- Height = Application.GetRealWidth(60),
- UnSelectedImagePath = "PirIcon/priequipment.png",
- TextAlignment = TextAlignment.Center,
- };
- devfLayout.AddChidren(priequipmentBtn);
+ View.PirView pirView = new View.PirView();
//绾㈠瀹濆悕绉�
- Button deviceNameBtn = new Button
+ pirView.deviceNameBtn.Text = pirDevice.name;
+ //绾㈠瀹濆綋鍓嶆湁澶氬皯涓仴鎺у櫒
+ pirView.geBtn.Text = pirDevice.FunctioList.Count.ToString();
+ //绾㈠瀹濇槸鍚﹀湪绾�-绂荤嚎
+ if (pirDevice.online)
{
- Y = Application.GetRealHeight(16),
- X = priequipmentBtn.Right + Application.GetRealWidth(7),
- Width = Application.GetRealWidth(120),
- Height = Application.GetRealHeight(20),
- Text = pirDevice.name,
- TextAlignment = TextAlignment.CenterLeft,
- TextSize = TextSize.text14,
- TextColor = CSS.CSS_Color.textColor,
- IsBold = true,
- };
- devfLayout.AddChidren(deviceNameBtn);
- //鐗堟湰鍙�
- Button versionBtn = new Button
- {
- Y = deviceNameBtn.Bottom + Application.GetRealHeight(4),
- X = priequipmentBtn.Right + Application.GetRealWidth(7),
- Width = Application.GetRealWidth(120),
- Height = Application.GetRealHeight(17),
- Text = "鐗堟湰鍙穠1.3.5",
- TextAlignment = TextAlignment.CenterLeft,
- TextSize = TextSize.text12,
- TextColor = CSS.CSS_Color.textCancelColor,
- };
- devfLayout.AddChidren(versionBtn);
- // 5/10
- Button geBtn = new Button
- {
- Y = versionBtn.Bottom + Application.GetRealHeight(2),
- X = priequipmentBtn.Right + Application.GetRealWidth(7),
- Width = Application.GetRealWidth(120),
- Height = Application.GetRealHeight(17),
- Text = pirDevice.FunctioList.Count.ToString(),
- TextAlignment = TextAlignment.CenterLeft,
- TextSize = TextSize.text12,
- TextColor = CSS.CSS_Color.textConfirmColor,
- };
- devfLayout.AddChidren(geBtn);
- geBtn.Width = geBtn.GetTextWidth();
- // 5/10
- Button sumBtn = new Button
- {
- Y = versionBtn.Bottom + Application.GetRealHeight(2),
- X = geBtn.Right,
- Width = Application.GetRealWidth(20),
- Height = Application.GetRealHeight(17),
- Text = "/10",
- TextAlignment = TextAlignment.CenterLeft,
- TextSize = TextSize.text12,
- TextColor = CSS.CSS_Color.textCancelColor,
- };
- devfLayout.AddChidren(sumBtn);
- //鐘舵�佸浘鏍�
- Button stateIconBtn = new Button
- {
- Y = Application.GetRealHeight(23),
- X = Application.GetRealWidth(291),
- Width = Application.GetRealWidth(8),
- Height = Application.GetRealWidth(8),
- UnSelectedImagePath = "PirIcon/online.png",
- SelectedImagePath = "PirIcon/offline.png",
- };
- devfLayout.AddChidren(stateIconBtn);
- //绾㈠瀹濈姸鎬侊紙鍦ㄧ嚎-绂荤嚎锛�
- Button stateTextBtn = new Button
- {
- Y = Application.GetRealHeight(18),
- X = Application.GetRealWidth(303),
- Width = Application.GetRealWidth(30),
- Height = Application.GetRealHeight(17),
- TextID = StringId.zaixianhwb,
- TextAlignment = TextAlignment.CenterLeft,
- TextSize = TextSize.text12,
- TextColor = 0xFF67D569,// CSS.CSS_Color.textColor,
- SelectedTextColor =CSS.CSS_Color.textRedColor,
- IsBold = true,
- };
- devfLayout.AddChidren(stateTextBtn);
- if (pirDevice.online) {
- stateIconBtn.IsSelected = true;
- stateTextBtn.IsSelected = true;
- } else {
- stateIconBtn.IsSelected = false;
- stateTextBtn.IsSelected = false;
+ pirView.stateIconBtn.IsSelected = true;
+ pirView.stateTextBtn.IsSelected = true;
}
- //绾�
- Button lineBtn = new Button
+ else
{
- Y = Application.GetRealHeight(92) - 1,
- X = Application.GetRealWidth(16),
- Width = Application.GetRealWidth(343 - 16 * 2),
- Height = 1,
- BackgroundColor = CSS.CSS_Color.viewLine,
- };
- devfLayout.AddChidren(lineBtn);
- //鐐瑰嚮浜嬩欢
- FrameLayout clickFram = new FrameLayout
+ pirView.stateIconBtn.IsSelected = false;
+ pirView.stateTextBtn.IsSelected = false;
+ }
+ //鏍囪绾㈠瀹�
+ pirView.clickBtn.Tag = pirDevice;
+ //绾㈠瀹濈偣鍑讳簨浠�
+ pirView.clickBtn.MouseUpEventHandler += (sender, e) =>
{
- Y = Application.GetRealHeight(12),
- X = Application.GetRealWidth(16),
- Width = Application.GetRealWidth(375 - 16 * 2),
- Height = Application.GetRealHeight(92),
- BackgroundColor = 0x00000000, //CSS.CSS_Color.view,
- Radius = (uint)Application.GetRealHeight(12),
- Tag = Pir.pirDeviceList[i],
- };
- fLayout.AddChidren(clickFram);
-
- clickFram.MouseUpEventHandler += (sender, e) =>
- {
- var pirclick = (clickFram.Tag as Pir);
+ var pirclick = (pirView.clickBtn.Tag as Pir);
NewSwitchView(pirclick, vv);
};
-
+ //鍔犺浇鐣岄潰
+ pirView.Show(pirDevice.FunctioList.Count, fLayout);
if (Pir.pirDeviceList.Count - 1 == i)
{
//鏈�鍚庝竴涓悗闈㈠鍔犻棿闅旇儗鏅�
@@ -214,152 +100,64 @@
for (int j = 0; j < pirDevice.FunctioList.Count; j++)
{
var control = pirDevice.FunctioList[j];
- RowLayout funControlRow = new RowLayout
- {
- Y = Application.GetRealHeight(92 + (50 * j)),
- Width = Application.GetRealWidth(375 - 16 * 2),
- Height = Application.GetRealHeight(50),
- LineColor = CSS.CSS_Color.textWhiteColor,
- SubViewWidth = Application.GetRealWidth(68),
- };
- devfLayout.AddChidren(funControlRow);
+
+ View.ControlView controlView = new View.ControlView();
+ controlView.Show(pirView.devfLayout, j);
//閬ユ帶鍣ㄥ悕绉�
- Button nameBtn = new Button
+ controlView.nameBtn.Text = control.name;
+ //閬ユ帶鍣ㄥ瓨鏀惧尯鍩�
+ controlView.areaBtn.Text = Intelligence.Automation.LogicMethod.GetGetRoomName(control);
+ //鏍囪閬ユ帶鍣�
+ controlView.delBtn.Tag = control;
+ //鍒犻櫎鐐瑰嚮浜嬩欢
+ controlView.delBtn.MouseUpEventHandler += (sender, e) =>
{
- X = Application.GetRealWidth(16),
- Width = Application.GetRealWidth(150),
- Height = Application.GetRealHeight(20),
- Text = control.name,
- TextAlignment = TextAlignment.CenterLeft,
- TextSize = TextSize.text14,
- TextColor = CSS.CSS_Color.textColor,
- Gravity = Gravity.CenterVertical,
+ var Function = controlView.delBtn.Tag as Entity.Function;
+ string text = Language.StringByID(StringId.shanchushebei) + Function.name + "?";
+ TipPopView tipPopView = new TipPopView();
+ tipPopView.TipBox(StringId.tip, text, (dialog) =>
+ {
+ Thread(dialog, (responsePackNew) =>
+ {
+ dialog.Close();
+ var function = pirDevice.FunctioList.Find((c) => c.sid == Function.sid);
+ if (function != null)
+ {
+ pirDevice.FunctioList.Remove(Function);
+ if (Pir.currPir != null && pirDevice.sid == Pir.currPir.sid)
+ {
+ Pir.currPir.FunctioList = pirDevice.FunctioList;
+ }
+ }
+ UIView(vv);
+
+ }, "鍒犻櫎", Function.deviceId, "");
+
+ }, () => { }, false);
};
- funControlRow.AddChidren(nameBtn);
- //閬ユ帶鍣ㄥ尯鍩�
- Button areaBtn = new Button
- {
- X = Application.GetRealWidth(311 + 16 - (40 + 100)),
- Width = Application.GetRealWidth(100),
- Height = Application.GetRealHeight(17),
- Text = Intelligence.Automation.LogicMethod.GetGetRoomName(control),
- TextAlignment = TextAlignment.CenterRight,
- TextSize = TextSize.text12,
- TextColor = CSS.CSS_Color.textCancelColor,
- Gravity = Gravity.CenterVertical,
- };
- funControlRow.AddChidren(areaBtn);
- //涓嬩竴绾у浘鏍�
- Button nextIconBtn = new Button
- {
- X = Application.GetRealWidth(295 + 16),
- Width = Application.GetRealWidth(16),
- Height = Application.GetRealWidth(16),
- UnSelectedImagePath = "PirIcon/next.png",
- Gravity = Gravity.CenterVertical,
- };
- funControlRow.AddChidren(nextIconBtn);
- //鍒犻櫎
- Button delBtn = new Button
- {
- Width = Application.GetRealWidth(50),
- Height = Application.GetRealHeight(22),
- TextID = StringId.Del,
- TextAlignment = TextAlignment.Center,
- TextSize = TextSize.text16,
- TextColor = CSS.CSS_Color.textWhiteColor,
- IsBold = true,
- BackgroundColor = CSS.CSS_Color.textRedColor,
- Tag = control,
- };
- funControlRow.AddRightView(delBtn);
- //绾�
- Button line1Btn = new Button
- {
- Y = Application.GetRealHeight(50 - 2),
- X = Application.GetRealWidth(16),
- Width = Application.GetRealWidth(311),
- Height = 1,
- BackgroundColor = CSS.CSS_Color.viewLine,
- };
- funControlRow.AddChidren(line1Btn);
+ //view鐐瑰嚮浜嬩欢
+ controlView.clickBtn.MouseUpEventHandler += (sender, e) =>
+ {
+ EditControl editControl = new EditControl();
+ MainPage.BasePageView.AddChidren(editControl);
+ editControl.Show(control, pirDevice, (device) =>
+ {
+ //鍥炶皟鏇存柊鍚嶅瓧/鍖哄煙
+ controlView.nameBtn.Text = device.name;
+ controlView.areaBtn.Text = Intelligence.Automation.LogicMethod.GetGetRoomName(device);
+
+ });
+ MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
+ };
if (j == pirDevice.FunctioList.Count - 1)
{
//鏈�鍚庢敼鍙樹竴涓嚎鐨勯鑹�
- line1Btn.BackgroundColor = CSS.CSS_Color.viewTranslucence;
- funControlRow.LineColor = CSS.CSS_Color.viewTranslucence;
+ controlView.line1Btn.BackgroundColor = CSS.CSS_Color.viewTranslucence;
+ controlView.funControlRow.LineColor = CSS.CSS_Color.viewTranslucence;
}
- delBtn.MouseUpEventHandler += (sender, e) =>
- {
- var Function = delBtn.Tag as Entity.Function;
- //鍔犺浇log
- Loading loading = new Loading();
- this.AddChidren(loading);
- HDL_ON.DAL.Server.ResponsePackNew responsePackNew = null;
- loading.Start();
- new System.Threading.Thread(() =>
- {
- try
- {
- responsePackNew = PirSend.DeleteDevice(Function.deviceId);
- }
- catch { }
- finally
- {
- Application.RunOnMainThread(() =>
- {
- loading.Hide();
- try
- {
- if (responsePackNew != null && responsePackNew.Code == "0" && responsePackNew.Data.ToString() != "")
- {
- var function = pirDevice.FunctioList.Find((c)=>c.sid== Function.sid);
- if (function != null)
- {
- pirDevice.FunctioList.Remove(Function);
- if (Pir.currPir != null && pirDevice.sid == Pir.currPir.sid)
- {
- Pir.currPir.FunctioList = pirDevice.FunctioList;
- }
- }
- UIView(vv);
- }
- else
- {
- Method method = new Method();
- method.ErrorShow(responsePackNew);
- }
- }
- catch { }
-
- });
- }
-
- })
- { IsBackground = true }.Start();
- };
- EventHandler<MouseEventArgs> editClick = (sender, e) =>
- {
- EditControl editControl = new EditControl();
- MainPage.BasePageView.AddChidren(editControl);
- editControl.Show(control, pirDevice, (device) =>
- {
- //鍥炶皟鏇存柊鍚嶅瓧/鍖哄煙
- nameBtn.Text = device.name;
- areaBtn.Text = Intelligence.Automation.LogicMethod.GetGetRoomName(device);
-
- });
- MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
- };
- funControlRow.MouseUpEventHandler += editClick;
- nameBtn.MouseUpEventHandler += editClick;
- areaBtn.MouseUpEventHandler += editClick;
- nextIconBtn.MouseUpEventHandler += editClick;
}
-
-
}
}
@@ -379,50 +177,23 @@
if (StringId.xiugaimingzi == intValue)
{
List<string> list = new List<string>();
- for (int b = 0; b < Pir.pirDeviceList.Count; b++)
+ for (int b = 0; b < PirDevice.Pir.pirDeviceList.Count; b++)
{
- list.Add(Pir.pirDeviceList[b].name);
+ list.Add(PirDevice.Pir.pirDeviceList[b].name);
}
- Method methodView = new Method();
+ Method methodView = new Method();
methodView.EditControlName(StringId.xiugaimingzi, list, pirclick.name, (name, view) =>
{
- pirclick.name = name;
- //鍔犺浇log
- Loading loading = new Loading();
- view.AddChidren(loading);
- HDL_ON.DAL.Server.ResponsePackNew responsePackNew = null;
- loading.Start();
- new System.Threading.Thread(() =>
+ Thread(view, (responsePackNew) =>
{
- try
- {
- responsePackNew = PirSend.DeviceRename(pirclick.deviceId, pirclick.name);
- }
- catch { }
- finally
- {
- Application.RunOnMainThread(() =>
- {
- loading.Hide();
- if (responsePackNew != null && responsePackNew.Code == "0" && responsePackNew.Data.ToString() != "")
- {
- view.Close();
- UIView(vv);
- }
- else
- {
- Method method = new Method();
- method.ErrorShow(responsePackNew);
- }
-
- });
- }
-
- })
- { IsBackground = true }.Start();
- },()=> {
+ pirclick.name = name;
+ view.Close();
+ UIView(vv);
+ }, "淇敼鍚嶇О", pirclick.deviceId, pirclick.name);
+ }, () =>
+ {
NewSwitchView(pirclick, vv);
- },false);
+ }, false);
}
else
@@ -431,40 +202,16 @@
TipPopView tipPopView = new TipPopView();
tipPopView.TipBox(StringId.tip, text, (dialog) =>
{
- //鍔犺浇log
- Loading loading = new Loading();
- dialog.AddChidren(loading);
- HDL_ON.DAL.Server.ResponsePackNew responsePackNew = null;
- loading.Start();
- new System.Threading.Thread(() =>
- {
- try
- {
- responsePackNew = PirSend.DeleteDevice(pirclick.deviceId);
- }
- catch { }
- finally
- {
- Application.RunOnMainThread(() =>
+ Thread(dialog, (responsePackNew) =>
{
- loading.Hide();
- if (responsePackNew != null && responsePackNew.Code == "0" && responsePackNew.Data.ToString() != "")
+ var pir = Pir.pirDeviceList.Find((c) => c.deviceId == pirclick.deviceId);
+ if (pir != null)
{
- dialog.Close();
- UIView(vv);
+ Pir.pirDeviceList.Remove(pirclick);
}
- else
- {
-
- Method method = new Method();
- method.ErrorShow(responsePackNew);
- }
-
- });
- }
-
- })
- { IsBackground = true }.Start();
+ dialog.Close();
+ UIView(vv);
+ }, "鍒犻櫎", pirclick.deviceId, "");
}, () =>
{
NewSwitchView(pirclick, vv);
@@ -473,7 +220,56 @@
}
});
}
+ /// <summary>
+ /// 鍙戦�佺嚎绋�
+ /// </summary>
+ /// <param name="dialog"></param>
+ /// <param name="action"></param>
+ /// <param name="str"></param>
+ /// <param name="deviceId"></param>
+ /// <param name="obj"></param>
+ void Thread(Dialog dialog, Action<HDL_ON.DAL.Server.ResponsePackNew> action, string str, string deviceId, string obj)
+ {
+ //鍔犺浇log
+ Loading loading = new Loading();
+ dialog.AddChidren(loading);
+ HDL_ON.DAL.Server.ResponsePackNew responsePackNew = null;
+ loading.Start();
+ new System.Threading.Thread(() =>
+ {
+ try
+ {
+ if (str == "鍒犻櫎")
+ {
+ responsePackNew = PirSend.DeleteDevice(deviceId);
+ }
+ else if (str == "淇敼鍚嶇О")
+ {
-
+ responsePackNew = PirSend.DeviceRename(deviceId, obj);
+ }
+ }
+ catch { }
+ finally
+ {
+ Application.RunOnMainThread(() =>
+ {
+ loading.Hide();
+ if (responsePackNew != null && responsePackNew.Code == "0" && responsePackNew.Data.ToString() != "")
+ {
+ action(responsePackNew);
+ }
+ else
+ {
+ Method method = new Method();
+ method.ErrorShow(responsePackNew,"");
+ }
+
+ });
+ }
+
+ })
+ { IsBackground = true }.Start();
+ }
}
}
--
Gitblit v1.8.0