VB ListView 隔行背景

Private Sub SetListViewColor(Lv As ListView, pic As PictureBox, LvCount As Long)
   Dim i As Integer

   pic.BackColor = Lv.BackColor

   Lv.Parent.ScaleMode = vbTwips

    pic.ScaleMode = vbTwips

    pic.BorderStyle = vbBSNone

    pic.AutoRedraw = True

    pic.Visible = False

    pic.Width = Screen.Width   '因为我的LISTVIEW会自动调整大小的,所以直接用屏幕的宽度

    pic.Height = Lv.ListItems(1).Height * LvCount '取得要添充的高度

    pic.ScaleHeight = LvCount

    pic.ScaleWidth = 1

    pic.DrawWidth = 1
    '-----------------------------

    '画出每行LISTVIEW的颜色

    '------------------------------

    For i = 1 To LvCount
       
        If i / 2 = Int(i / 2) Then

                        
            pic.Line (0, i - 1)-(1, i), &HC0FFFF, BF


        Else
            pic.Line (0, i - 1)-(1, i), 16777152, BF

        End If

    Next

    Lv.Picture = pic.Image
    
End Sub


Private Sub SetListViewColor(Lv As ListView, pic As PictureBox)

    Dim h               As Single
    Dim sw              As Single
    Dim oAltBackColor   As OLE_COLOR
    
    oAltBackColor = pic.BackColor
    
    With Lv
        If .View = lvwReport Then
            If .ListItems.Count Then
                .PictureAlignment = lvwTile
                h = .ListItems(1).Height
                With pic
                    .Visible = False
                    .BackColor = Lv.BackColor
                    .BorderStyle = 0
                    .Height = h * 2
                    .Width = 10 * Screen.TwipsPerPixelX
                    sw = .ScaleWidth
                    .AutoRedraw = True
                    If StartAtOddRow Then
                        pic.Line (0, 0)-Step(sw, h - Screen.TwipsPerPixelY), oAltBackColor, BF
                    Else
                        pic.Line (0, h)-Step(sw, h), oAltBackColor, BF
                    End If
                    Set Lv.Picture = .Image
                    .AutoRedraw = False
                    .BackColor = oAltBackColor
                End With
                .Refresh
                Exit Sub
            End If
        End If
        Set .Picture = Nothing
    End With
    
End Sub

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值