真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

VB.NET中怎么實(shí)現(xiàn)下拉列表折行顯示

VB.NET中怎么實(shí)現(xiàn)下拉列表折行顯示,針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

創(chuàng)新互聯(lián)是一家專業(yè)的成都網(wǎng)站建設(shè)公司,我們專注成都網(wǎng)站制作、網(wǎng)站設(shè)計(jì)、網(wǎng)絡(luò)營(yíng)銷、企業(yè)網(wǎng)站建設(shè),外鏈,廣告投放平臺(tái)為企業(yè)客戶提供一站式建站解決方案,能帶給客戶新的互聯(lián)網(wǎng)理念。從網(wǎng)站結(jié)構(gòu)的規(guī)劃UI設(shè)計(jì)到用戶體驗(yàn)提高,創(chuàng)新互聯(lián)力求做到盡善盡美。

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

VB.NET實(shí)現(xiàn)下拉列表,在ComboBox控件中每項(xiàng)占用一行,如果有選擇項(xiàng)的內(nèi)容長(zhǎng)度超過(guò)下拉列表的寬度,則超過(guò)部分不顯示,這樣就可能造成用戶所見(jiàn)的內(nèi)容不完全而無(wú)法選擇的情況。我們對(duì)該控件進(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 

關(guān)于VB.NET中怎么實(shí)現(xiàn)下拉列表折行顯示問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


分享標(biāo)題:VB.NET中怎么實(shí)現(xiàn)下拉列表折行顯示
標(biāo)題路徑:http://weahome.cn/article/gihgei.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部