我会尝试尽可能地简化情况。
我有一个ActiveReports子报表,它有一个控件,我使用FetchData事件填充。有时我需要隐藏控件,如果它的空白或在这个场合,值是棉花,但聚酯应该出现。问题是,当我隐藏控件时,它会在报表中的每个事件中隐藏控件,而不仅仅是一个需要的实例。我有什么不对的。
我在InitializeReport中定义控件
Material1 = DirectCast(Detail.Controls("Material1"), Label)
Material2 = DirectCast(Detail.Controls("Material2"), Label)
我在DataInitialize事件中为控件设置了数据字段
Fields.Add("Material1")
Fields.Add("Material2")
在FetchData事件中,我填充控件,因此三个记录,控件被适当填充。没有错。如果第二个记录有一个值那么那很好。 e.g。
第一个记录,第一次调用FetchData事件。
Fields("Material1").Value = "Polyester"
Material1.Value = "Polyester"
Fields("Material2").value = "Wool"
Material2.Value = "Wool"
第二次记录,第二次调用FetchData事件。
Fields("Material1").Value = "Cotton"
Material1.Value = "Cotton"
Fields("Material2").Value = "Wool"
Material2.Value = "Wool"
如果我想隐藏第二个记录/控件,在控件填满后,我将控件隐藏在Details_Format事件中,但是,它隐藏了所有三个Material控件而不是一个单独的实例。我能做错什么?
If Fields("Material1").value = "Cotton" then
Material1.Visible = false
End if
我希望羊毛在两个记录中出现两次,但棉花出现在第二组中。我无法隐藏Cotton控件。我不想简单地删除Material1,因为我需要隐藏控件,以便我可以移动控件并重新组织报表。我隐藏了Material1旁边的标签以及Material1。
请使用VB或C#解决方案。
答案 0 :(得分:0)
您需要为您添加Else如果或替换为
Material1.Visible = Not (Fields("Material1").Value = "Cotton")
这样根据值打开或关闭。当您在整个控件的实例上设置属性时,子报表只有一个实例,而不是每个细节都有一个实例。
希望这会有所帮助。