การทำงานกับสไตล์
ในบทความนี้และวิดีโอที่เกี่ยวข้อง เราจะอธิบายวิธีการใช้สไตล์เพื่อเปลี่ยนลักษณะของอิลิเมนต์ UI ที่กำหนดเองที่สร้างขึ้นผ่าน cBots อินดิเคเตอร์ และปลั๊กอิน
สร้าง cBot ตัวอย่าง
นำทางไปที่ cTader Algo และสร้าง cBot ใหม่ เราจะตั้งชื่อว่า "Styles Example" ในตัวอย่างนี้ เราจะสร้างกล่องข้อความสามกล่องและแสดงบนกราฟโดยใช้แผงสแต็ก
ก่อนอื่น เราจะเริ่มต้นกล่องข้อความสามกล่อง เราจะกำหนดค่าลักษณะของกล่องข้อความแต่ละกล่องโดยการตั้งค่าคุณสมบัติทีละรายการ
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29 | var firstTextBox = new TextBox
{
ForegroundColor = Color.Red,
Margin = 5,
FontFamily = "Cambria",
FontSize = 12,
Text = "Type...",
Width = 150
};
var secondTextBox = new TextBox
{
ForegroundColor = Color.Red,
Margin = 5,
FontFamily = "Cambria",
FontSize = 12,
Text = "Type...",
Width = 150
};
var thirdTextBox = new TextBox
{
ForegroundColor = Color.Red,
Margin = 5,
FontFamily = "Cambria",
FontSize = 12,
Text = "Type...",
Width = 150
};
|
เราจะเริ่มต้นแผงสแต็กด้วย
| var panel = new StackPanel
{
Orientation = Orientation.Vertical,
HorizontalAlignment = HorizontalAlignment.Center,
VerticalAlignment = VerticalAlignment.Center
};
|
จากนั้นเพิ่มกล่องข้อความเหล่านี้ลงในแผง
| panel.AddChild(firstTextBox);
panel.AddChild(secondTextBox);
panel.AddChild(thirdTextBox);
|
สุดท้าย เพิ่มแผงลงในกราฟ
หลังจากที่เราสร้าง cBot เราควรจะเห็นกล่องข้อความสามกล่องถูกวาดลงบนกราฟโดยตรง
ใช้คลาส Style
โค้ดของ cBot ของเรามีการทำซ้ำเนื่องจากเรากำหนดค่าแต่ละกล่องข้อความแยกกันและทำซ้ำการเริ่มต้นคุณสมบัติสำหรับทุกอิลิเมนต์ การทำซ้ำโค้ดสามารถทำให้โครงการขนาดใหญ่ยากต่อการบำรุงรักษาและปรับปรุงประสิทธิภาพ เราสามารถทำให้โค้ดของเรากระชับและบำรุงรักษาง่ายขึ้นโดยใช้สไตล์เพื่อกำหนดค่าลักษณะของการควบคุมของเรา
ก่อนอื่น เราจะเริ่มต้นออบเจ็กต์ใหม่ของคลาส Styles
| var textBoxStyle = new Style();
|
จากนั้นเราจะกำหนดค่าลักษณะของการควบคุมที่เกี่ยวข้องกับสไตล์นี้
| textBoxStyle.Set(ControlProperty.ForegroundColor, Color.Red);
textBoxStyle.Set(ControlProperty.Margin, 5);
textBoxStyle.Set(ControlProperty.FontFamily, "Cambria");
textBoxStyle.Set(ControlProperty.FontSize, 12);
textBoxStyle.Set(ControlProperty.Width, 150);
|
เราจะกำหนดสไตล์นี้ให้กับกล่องข้อความแต่ละกล่องของเราและลบการเริ่มต้นพารามิเตอร์ออก
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 | var firstTextBox = new TextBox
{
Text = "Type...",
Style = textBoxStyle
};
var secondTextBox = new TextBox
{
Text = "Type...",
Style = textBoxStyle
};
var thirdTextBox = new TextBox
{
Text = "Type...",
Style = textBoxStyle
};
|
หากเราสร้าง cBot และเพิ่มลงในกราฟ เราจะเห็นว่ากล่องข้อความทั้งหมดของเราแสดงผลตามปกติ เราสามารถกลับไปที่โค้ดและเปลี่ยนคุณสมบัติหนึ่งของออบเจ็กต์ textBoxStyle ของเรา ซึ่งในกรณีนี้กล่องข้อความทั้งหมดของเราจะถูกจัดสไตล์แตกต่างกัน
| textBoxStyle.Set(ControlProperty.ForegroundColor, Color.Yellow, ControlState.Hover);
|
ใช้สไตล์ในหน้าต่างที่กำหนดเองและปลั๊กอิน
สไตล์การควบคุมยังทำงานเมื่อการควบคุมถูกแสดงในที่อื่นนอกเหนือจากกราฟ เช่น หน้าต่างที่กำหนดเอง เราจะสร้างปลั๊กอินตัวอย่างที่จะแสดงกล่องข้อความในหน้าต่างที่กำหนดเองและจัดสไตล์ตามนั้น
เราจะเริ่มต้นด้วยการแสดงการควบคุมของเราในหน้าต่างที่กำหนดเอง
ต่อไปนี้คือโค้ดสำหรับปลั๊กอินของเรา:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69 | using cAlgo.API;
namespace cAlgo.Plugins
{
[Plugin(AccessRights = AccessRights.None)]
public class StylesExample : Plugin
{
protected override void OnStart()
{
var block = Asp.SymbolTab.AddBlock("Styles Example");
block.Index = 2;
block.Height = 500;
var textBoxStyle = new Style();
textBoxStyle.Set(ControlProperty.ForegroundColor, Color.Red);
textBoxStyle.Set(ControlProperty.Margin, 5);
textBoxStyle.Set(ControlProperty.FontFamily, "Cambria");
textBoxStyle.Set(ControlProperty.FontSize, 12);
textBoxStyle.Set(ControlProperty.Width, 150);
textBoxStyle.Set(ControlProperty.ForegroundColor, Color.Yellow, ControlState.Hover);
var firstTextBox = new TextBox
{
Text = "Type...",
Style = textBoxStyle
};
var secondTextBox = new TextBox
{
Text = "Type...",
Style = textBoxStyle
};
var thirdTextBox = new TextBox
{
Text = "Type...",
Style = textBoxStyle
};
var panel = new StackPanel
{
Orientation = Orientation.Vertical,
HorizontalAlignment = HorizontalAlignment.Center,
VerticalAlignment = VerticalAlignment.Center
};
panel.AddChild(firstTextBox);
panel.AddChild(secondTextBox);
panel.AddChild(thirdTextBox);
block.Child = panel;
var window = new Window
{
Child = panel,
Title = "My Window",
WindowStartupLocation = WindowStartupLocation.CenterScreen,
Topmost = true
};
window.Show();
}
}
}
|
หลังจากสร้างปลั๊กอินของเรา เราควรจะเห็นกล่องข้อความของเราในหน้าต่างที่กำหนดเองและในแผงสัญลักษณ์ที่ใช้งานอยู่
สรุป
การจัดสไตล์การควบคุมมีความสำคัญหากคุณต้องการแสดงอิลิเมนต์ที่กำหนดเองให้กับผู้ใช้โดยไม่ต้องกังวลเกี่ยวกับความซ้ำซ้อนในโค้ดของคุณ