FlexGrid中添加Windows控件

 FlexGrid中添加Windows控件  


在FlexGrid的使用过程中,遇到在列中显示按钮的要求,利用 HostedControl 实现。
本例添加一列按钮,其他控件同理。

1. 新规作成一Form,加入FlexGrid控件,将Dock属性设置为 Fill。

2. 追加HostedControl类。

3. 在Form的Load事件中,添加所需要控件。

完整代码如下

Imports  C1.Win.C1FlexGrid
Public   Class FlexGrid
    
Private _al As ArrayList = New ArrayList()


    
Private Sub FlexGrid_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

        
For i As Integer = 1 To 10
            
' ボタンを定義する
            Dim btn1 As Button = New Button()
            btn1.BackColor 
= SystemColors.Control
            
'ボタン名を設定する(行番号)
            btn1.Name = i.ToString

            btn1.Text 
= "BTN " + i.ToString

            
'HostedControlを追加する
            _al.Add(New HostedControl(C1FlexGrid1, btn1, i, 1))

            
' 行高さを設定する
            C1FlexGrid1.Rows(i).Height = 20

            
'事件を追加する 
            AddHandler btn1.Click, AddressOf FlexGridButton_Click
        
Next
        
    
End Sub


    
Private Sub C1FlexGrid1_Paint(ByVal sender As ObjectByVal e As System.Windows.Forms.PaintEventArgs) Handles C1FlexGrid1.Paint
        
For Each hosted As HostedControl In _al
            hosted.UpdatePosition()
        
Next hosted
    
End Sub


    
Private Sub FlexGridButton_Click(ByVal sender As ObjectByVal e As System.EventArgs)
        MessageBox.Show(
"行番号は【" & CType(sender, Button).Name & "】です!")
    
End Sub


End Class


Friend   Class HostedControl
    
Friend _flex As C1FlexGrid
    
Friend _ctl As Control
    
Friend _row As Row
    
Friend _col As Column

    
Friend Sub New(ByVal flex As C1FlexGrid, ByVal hosted As Control, ByVal row As IntegerByVal col As Integer)
        _flex 
= flex
        _ctl 
= hosted
        _row 
= flex.Rows(row)
        _col 
= flex.Cols(col)

        
' ホストされたコントロールをグリッドに追加します。
        _flex.Controls.Add(_ctl)
    
End Sub

    
Friend Function UpdatePosition() As Boolean
        
' 行および列のインデックスを取得します。
        Dim r As Integer = _row.Index
        
Dim c As Integer = _col.Index
        
If r < 0 OrElse c < 0 Then
            
Return False
        
End If

        
' セルの位置を取得します
        Dim rc As Rectangle = _flex.GetCellRect(r, c, False)

        
'  セルに収まらない場合コントロールを非表示します。
        If rc.Width <= 0 OrElse rc.Height <= 0 OrElse (Not rc.IntersectsWith(_flex.ClientRectangle)) Then
            _ctl.Visible 
= False
            
Return True
        
End If

        
' コントロールを表示します。
        _ctl.Bounds = rc
        _ctl.Visible 
= True

        
Return True
    
End Function

End Class

执行结果如下

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值