弱电论坛

标题: 【Access小品】列表框宽度自适应 [打印本页]

作者: 卡西达    时间: 2012-3-26 17:27
标题: 【Access小品】列表框宽度自适应
  昨天根据版友石三少同志的问题编写了一个导入导出的实例,在这个实例中用到了列表框来显示不同表的数据,这样的处理有个好处可以不必考虑子窗体增减控件的问题。但是昨天的实例留下来一个小问题,就是不同的数据表列宽都是一致的,数据要么显示不全,要么留白太多,实在不美观。根据这样一个遗留问题,今日写就本实例,解决列表框列宽自适应记录宽度问题。


  1. Function GetcomWidths(ctl As Control, ftSize As Long)
  2. '功能:列表框字段框度自适应
  3. '参数:ctl--列表框控件,ftSize--字号
  4. '示例:GetcomWidths me.记录,10
  5. Dim rs As New ADODB.Recordset
  6. Dim i As Long, j As Long
  7. Dim comWidths As String
  8. Dim w As Single
  9. rs.Open ctl.RowSource, CurrentProject.Connection, adOpenKeyset, adLockOptimistic
  10. ctl.FontSize = ftSize
  11. For i = 0 To rs.Fields.Count - 1
  12.         rs.MoveFirst
  13.         w = 0
  14.         For j = 1 To rs.RecordCount
  15.               If Len(Nz(rs(i).Value, "")) > w Then w = Len(Nz(rs(i).Value, ""))
  16.               rs.MoveNext
  17.         Next
  18.         If w > 20 Then w = 20
  19.         w = 0.0353 * (w + 1) * ctl.FontSize
  20.         comWidths = comWidths & w & " cm;"
  21. Next
  22. ctl.ColumnWidths = comWidths
  23. rs.Close
  24. End Function
复制代码



附件下载:列表框宽度自适应.rar





欢迎光临 弱电论坛 (http://bbs.rdzjw.com/) Powered by Discuz! X3.2