[英]How to create MaterialSingleLineTextField Controls dynamically
我想将MaterialSingleLineTextField
动态添加到表单中。
我使用了MaterialSkin NuGet package:
我正在尝试在 Form.Load 上动态创建多个 MaterialSkin 文本框。 但是软管面板中没有显示任何控件。
private void Form1_Load(object sender, EventArgs e)
{
int n = 5;
int pointX = 30;
int pointY = 40;
//panel1.Controls.Clear();
for (int i = 0; i < n - 1; i++)
{
MaterialSingleLineTextField a = new MaterialSingleLineTextField();
a.Text = (i + 1).ToString();
a.Visible = true;
a.Location = new Point(pointX, pointY);
panel1.Controls.Add(a);
panel1.Show();
pointY += 20;
}
}
这个代码块对于普通的 TextBox 来说工作得很好。
有没有办法动态添加MaterialSingleLineTextField
?
具有默认主题值的示例表单初始化。
MaterialSkinManager
在 Form Constructor 中初始化,将 Theme 设置为MaterialSkinManager.Themes.LIGHT
和默认配色方案。 表单基本类型设置为MaterialForm
。MaterialSingleLineTextField
控件被添加到父容器(面板)中,从定义的位置开始向下。 这些控件锚定到父控件,并且高度设置为Parent.Font.Height + 4
。
AddTextFields()
方法中看到的那样,如果您想用新的控件替换现有控件,则处理之前添加到父容器的控件非常重要。 使用这个库更重要。Control.Controls
集合的Clear()
方法(如您已注释掉的行中)不会处理任何内容,这些控件仍然活着。public partial class Form1 : MaterialForm
{
private readonly MaterialSkinManager msManager = null;
public Form1()
{
InitializeComponent();
msManager = MaterialSkinManager.Instance;
msManager.AddFormToManage(this);
msManager.Theme = MaterialSkinManager.Themes.LIGHT;
}
private void Form1_Load(object sender, EventArgs e)
{
AddTextFields(panel1, 5, new Point(30, 10), false);
}
private void AddTextFields(Control parent, int controlsCount, Point startPosition, bool ClearExisting)
{
if (clearExisting && parent.Controls.Count > 0) {
for (int i = parent.Controls.Count - 1; i >= 0; i--) {
parent.Controls[i].Dispose();
}
}
int controlHeight = parent.Font.Height + 4;
int yIncrement = 0;
for (int i = 0; i < controlsCount; i++) {
var textField = new MaterialSingleLineTextField() {
Text = (i + 1).ToString(),
Size = new Size(parent.ClientSize.Width - startPosition.X - 4, controlHeight),
Location = new Point(startPosition.X, startPosition.Y + yIncrement),
Anchor = AnchorStyles.Left | AnchorStyles.Top | AnchorStyles.Right
};
parent.Controls.Add(textField);
yIncrement += (controlHeight + 10);
}
}
private void matBtnChangeTheme_Click(object sender, EventArgs e)
{
msManager.Theme = MaterialSkinManager.Themes.DARK;
msManager.ColorScheme = new ColorScheme(Primary.Blue600, Primary.Blue900, Primary.Blue500, Accent.LightBlue200, TextShade.WHITE);
}
private void matBtnAddControls_Click(object sender, EventArgs e)
{
AddTextFields(panel1, 7, new Point(30, 10), true);
}
}
示例功能:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.