日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
淺析VB.NET實(shí)現(xiàn)下拉列表的折行顯示

VB.NET有很多值得學(xué)習(xí)的地方,這里我們主要介紹VB.NET實(shí)現(xiàn)下拉列表,包括介紹控件進(jìn)行改進(jìn)等方面。

.NET是Microsoft公司提供解決未來計(jì)算需要的工具。在.NET Framework中提供了許多控件,可以解決編程中用戶界面的設(shè)計(jì)和實(shí)現(xiàn),但在實(shí)際應(yīng)用中可能需要對系統(tǒng)提供的控件進(jìn)行改進(jìn),如下拉列表不能折行顯示。本文將介紹用VB.NET實(shí)現(xiàn)下拉列表折行顯示。

設(shè)計(jì)能自動折行的下拉列表

VB.NET實(shí)現(xiàn)下拉列表,在ComboBox控件中每項(xiàng)占用一行,如果有選擇項(xiàng)的內(nèi)容長度超過下拉列表的寬度,則超過部分不顯示,這樣就可能造成用戶所見的內(nèi)容不完全而無法選擇的情況。我們對該控件進(jìn)行改進(jìn),當(dāng)一行顯示不完全某項(xiàng)時(shí)進(jìn)行折行顯示,為了防止用戶將折行的項(xiàng)誤認(rèn)為是兩個(gè)選擇項(xiàng),我們將不同的選項(xiàng)用相互間隔的顏色區(qū)分。類代碼如下:

 
 
 
  1. Public Class myComboBox  
  2. Inherits System.Windows.Forms.ComboBox  
  3.  
  4. #Region " Windows 窗體設(shè)計(jì)器生成的代碼 "  
  5. …  
  6. #End Region  
  7. '下面代碼用不同的顏色顯示選項(xiàng)  
  8. Private Sub myComboBox_DrawItem(ByVal sender As Object, 
    ByVal e As _ System.Windows.Forms.DrawItemEventArgs) Handles MyBase.DrawItem  
  9. If e.Index < 0 Then Exit Sub  
  10. Dim txtColor As SolidBrush  
  11. Dim bgColor As SolidBrush  
  12. Dim txtfnt As Font  
  13. txtColor = New SolidBrush(Color.Black)  
  14. If e.Index / 2 = CInt(e.Index / 2) Then  
  15. bgColor = New SolidBrush(Color.White)  
  16. Else  
  17. bgColor = New SolidBrush(Color.LightYellow)  
  18. End If  
  19. If e.State And DrawItemState.Selected Then  
  20. txtColor = New SolidBrush(Color.Blue)  
  21. End If  
  22. e.Graphics.FillRectangle(bgColor, e.Bounds)  
  23. e.Graphics.DrawRectangle(Pens.Black, e.Bounds)  
  24. Dim r As New RectangleF(e.Bounds.X, e.Bounds.Y, e.Bounds.Width, e.Bounds.Height)  
  25. e.Graphics.DrawString(Items(e.Index).ToString, Me.Font, txtColor, r)  
  26. End Sub  
  27. '下面代碼計(jì)算每行選項(xiàng)需要的尺寸  
  28. Private Sub myComboBox_MeasureItem(ByVal sender As Object, 
    ByVal e As _ System.Windows.Forms.MeasureItemEventArgs) Handles MyBase.MeasureItem  
  29. Dim lsize As SizeF  
  30. lsize = e.Graphics.MeasureString(Items(e.Index).ToString, Me.Font, New SizeF(Me.Width, 200))  
  31. e.ItemHeight = lsize.Height  
  32. e.ItemWidth = lsize.Width  
  33. End Sub  
  34. End Class 

以上介紹VB.NET實(shí)現(xiàn)下拉列表折行顯示。

【編輯推薦】

  1. 講解VB.NET定制Windows控件
  2. 全面描述VB.NET字節(jié)數(shù)組
  3. 概括VB.NET窗體編程模式
  4. 淺談VB6.0實(shí)現(xiàn)多窗體交互
  5. 詳解VB6.0和VB.NET窗體的區(qū)別

網(wǎng)站題目:淺析VB.NET實(shí)現(xiàn)下拉列表的折行顯示
網(wǎng)頁鏈接:http://www.5511xx.com/article/dpsicog.html