Foxtable(狐表)用户栏目专家坐堂 → [下载][分享]Listbox间距调整函数


  共有5479人关注过本帖树形打印复制链接

主题:[下载][分享]Listbox间距调整函数

帅哥哟,离线,有人找我吗?
jnletao
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:941 积分:7786 威望:0 精华:0 注册:2013/7/7 13:37:00
[下载][分享]Listbox间距调整函数  发帖心情 Post By:2014/3/8 13:23:00 [显示全部帖子]

借花献佛,把有点甜老师 的“加大ListBox间隔的例子”  做成了 函数。有需要的朋友可以用下。

窗口与控件事件

 

窗口1_AfterLoad

 

Functions.Execute("ListBoxDraw","窗口1")

 

自定义函数

 

     ListBoxDraw

 

'Args(0) 窗体名

For Each c As WinForm.Control In Forms(Args(0)).Controls

    If Typeof c Is WinForm.ListBox Then '判断控件

        Dim cbx As System.Windows.Forms.ListBox = Forms(Args(0)).Controls(c.name).BaseControl

        cbx.DrawMode = System.Windows.Forms.DrawMode.OwnerDrawFixed

        cbx.ItemHeight = 20

        AddHandler cbx.DrawItem, AddressOf BoxList_DrawItem

    End If

Next

 

全局代码

 

Public Sub BoxList_DrawItem(sender As object, e As System.Windows.Forms.DrawItemEventArgs)  '重绘列表控件行间距

    If e.Index < 0 Then Return

    e.DrawBackground()

    e.DrawFocusRectangle()

    e.Graphics.DrawString(sender.Items(e.Index).ToString(), e.Font, new SolidBrush(e.ForeColor), e.Bounds.X, e.Bounds.Y + 3)

End Sub

 


 回到顶部
帅哥哟,离线,有人找我吗?
jnletao
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:941 积分:7786 威望:0 精华:0 注册:2013/7/7 13:37:00
  发帖心情 Post By:2014/3/8 15:34:00 [显示全部帖子]

combobox试了下,没成功,我只是把有点甜老师的成果总结了下,其它功能还需要有点甜老师给方法

除了combobox,我还想把listbox实现 背景行 交替变色,也没成功,不过文字变色成功了,没放上来。

 回到顶部
帅哥哟,离线,有人找我吗?
jnletao
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:941 积分:7786 威望:0 精华:0 注册:2013/7/7 13:37:00
  发帖心情 Post By:2014/3/8 16:07:00 [显示全部帖子]

以下是引用xiaoohoo在2014-3-8 15:55:00的发言:
‘交替行变色
e.Graphics.FillRectangle(IIf(e.Index Mod 2, Brushes.LightCyan, Brushes.LightBlue), e.Bounds)
[此贴子已经被作者于2014-3-8 15:58:26编辑过]

成功了,图片点击可在新窗口打开查看


 回到顶部
帅哥哟,离线,有人找我吗?
jnletao
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:四尾狐 帖子:941 积分:7786 威望:0 精华:0 注册:2013/7/7 13:37:00
  发帖心情 Post By:2014/3/8 16:08:00 [显示全部帖子]

全局代码

Public Sub BoxList_DrawItem(sender As object, e As System.Windows.Forms.DrawItemEventArgs)  '重绘列表控件行间距
If e.Index < 0 Then Return
e.DrawBackground()
Dim myBrush As Brush = Brushes.Black
If e.Index Mod 2 = 0 Then
    myBrush = Brushes.Red  ‘文字变色
Else
    myBrush = Brushes.Purple
End If
e.DrawFocusRectangle()
e.Graphics.FillRectangle(IIf(e.Index Mod 2, Brushes.LightCyan, Brushes.LightBlue), e.Bounds) ’交替行变色
'  e.Graphics.DrawString(sender.Items(e.Index).ToString(), e.Font, new SolidBrush(e.ForeColor), e.Bounds.X, e.Bounds.Y + 3)
e.Graphics.DrawString(sender.Items(e.Index).ToString(), e.Font,myBrush, e.Bounds.X, e.Bounds.Y + 3)
End Sub

 回到顶部