我正在尝试以编程方式创建一些标签,代码没有返回任何错误,但我在窗口中看不到任何标签。
dim dr As DatabaseRecord
dim sql As String
sql = "SELECT * FROM pack WHERE applicabilita_modello LIKE '%" + versione + "%'"
dim rs As RecordSet = database.SQLSelect(sql)
dim i As Integer = 1
dim test(10) As Label
while not rs.EOF
test(i) = new Label
test(i).Text = rs.Field("descrizione").StringValue
test(i).Left = me.Left
test(i).Top = me.Top * i
test(i).Enabled = true
test(i).Visible = true
rs.MoveNext
i = i + 1
wend
rs.Close我已经验证了记录集包含一些数据,循环工作正常,但没有显示标签,并且无法理解原因。
谢谢你的帮助
发布于 2011-10-17 21:48:14
在Real Studio中,有两种方法可以在运行时创建控件。第一个是创建一个控件数组。您可以将控件命名为MyLabel,并将其索引设置为零。那么你的代码应该是:
test(i) = new MyLabel第二种方法是使用ContainerControl。这个容器将包含一个标签,因为您可以使用新命令和ContainerControl.EmbedWithin方法将它们添加到您的窗口(或其他容器)中。
出于许多原因,我通常更喜欢ContainerControl方法,但最主要的原因是控制数组使逻辑变得更加复杂。容器的唯一缺点是它需要Real Studio Professional或Real Studio Enterprise。
http://docs.realsoftware.com/index.php/UsersGuide:Chapter_5:Creating_New_Instances_of_Controls_On_The_Fly
http://docs.realsoftware.com/index.php/ContainerControl
https://stackoverflow.com/questions/7792795
复制相似问题