ข้ามไปที่เนื้อหา

การทำงานกับสไตล์

ในบทความนี้และวิดีโอที่เกี่ยวข้อง เราจะอธิบายวิธีการใช้สไตล์เพื่อเปลี่ยนลักษณะของอิลิเมนต์ 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
};

เราจะเริ่มต้นแผงสแต็กด้วย

1
2
3
4
5
6
var panel = new StackPanel
{
    Orientation = Orientation.Vertical,
    HorizontalAlignment = HorizontalAlignment.Center,
    VerticalAlignment = VerticalAlignment.Center
};

จากนั้นเพิ่มกล่องข้อความเหล่านี้ลงในแผง

1
2
3
panel.AddChild(firstTextBox);
panel.AddChild(secondTextBox);
panel.AddChild(thirdTextBox);

สุดท้าย เพิ่มแผงลงในกราฟ

1
Chart.AddControl(panel);

หลังจากที่เราสร้าง cBot เราควรจะเห็นกล่องข้อความสามกล่องถูกวาดลงบนกราฟโดยตรง

ใช้คลาส Style

โค้ดของ cBot ของเรามีการทำซ้ำเนื่องจากเรากำหนดค่าแต่ละกล่องข้อความแยกกันและทำซ้ำการเริ่มต้นคุณสมบัติสำหรับทุกอิลิเมนต์ การทำซ้ำโค้ดสามารถทำให้โครงการขนาดใหญ่ยากต่อการบำรุงรักษาและปรับปรุงประสิทธิภาพ เราสามารถทำให้โค้ดของเรากระชับและบำรุงรักษาง่ายขึ้นโดยใช้สไตล์เพื่อกำหนดค่าลักษณะของการควบคุมของเรา

ก่อนอื่น เราจะเริ่มต้นออบเจ็กต์ใหม่ของคลาส Styles

1
var textBoxStyle = new Style();

จากนั้นเราจะกำหนดค่าลักษณะของการควบคุมที่เกี่ยวข้องกับสไตล์นี้

1
2
3
4
5
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 ของเรา ซึ่งในกรณีนี้กล่องข้อความทั้งหมดของเราจะถูกจัดสไตล์แตกต่างกัน

1
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();
        }

    }        
}

หลังจากสร้างปลั๊กอินของเรา เราควรจะเห็นกล่องข้อความของเราในหน้าต่างที่กำหนดเองและในแผงสัญลักษณ์ที่ใช้งานอยู่

สรุป

การจัดสไตล์การควบคุมมีความสำคัญหากคุณต้องการแสดงอิลิเมนต์ที่กำหนดเองให้กับผู้ใช้โดยไม่ต้องกังวลเกี่ยวกับความซ้ำซ้อนในโค้ดของคุณ