溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

VB.NET中如何使用COMBOBOX控件

發(fā)布時(shí)間:2021-12-02 09:49:56 來源:億速云 閱讀:448 作者:小新 欄目:編程語言

小編給大家分享一下VB.NET中如何使用COMBOBOX控件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Visual Basic.NET是基于微軟.NET Framework之上的面向?qū)ο蟮闹虚g解釋性語言,可以看作是Visual Basic在.Net Framework平臺(tái)上的升級(jí)版本,增強(qiáng)了對(duì)面向?qū)ο蟮闹С?。但由于改?dòng)太大,導(dǎo)致VB.net對(duì)VB的向后兼容性不好,在業(yè)界引起不小的爭議。

大多的VB.NET程序員使用Visual Studio .Net作為IDE(integrated development environment). SharpDevelop是另一種可用的開源的IDE。VB.NET需要在.Net Framework平臺(tái)上才能執(zhí)行。

前不久,有位朋友發(fā)帖,尋求顏色選擇的VB.NET COMBOBOX控件的制作方法,經(jīng)過試驗(yàn),整理了出來,僅供參考。

  1. Private Sub filllistboxwithcolors()  

  2. Me.ComboBox1.DrawMode = DrawMode.OwnerDrawFixed  

  3. Me.ComboBox1.DropDownStyle = ComboBoxStyle.DropDownList  

  4. Me.ComboBox1.ItemHeight = 15 

  5. '避免閃爍beginupdate  

  6. Me.ComboBox1.BeginUpdate()  

  7. ComboBox1.Items.Clear()  

  8. Dim pi As Reflection.PropertyInfo  

  9. For Each pi In GetType(Color).GetProperties(Reflection.BindingFlags.
    Public Or Reflection.BindingFlags.Static)  

  10. Me.ComboBox1.Items.Add(pi.Name)  

  11. Next  

  12. ComboBox1.EndUpdate()  

  13. End Sub  

  14.  

  15. Private Sub ComboBox1_DrawItem(ByVal sender As Object, 
    ByVal e As System.Windows.Forms.DrawItemEventArgs) Handles ComboBox1.DrawItem  

  16. If e.Index < 0 Then Exit Sub  

  17.  

  18. Dim rect As Rectangle = e.Bounds '每一項(xiàng)的邊框  

  19.  

  20. '繪制項(xiàng)如果被選中則顯示高亮顯示背景,否則用白色  

  21. If e.State And DrawItemState.Selected Then  

  22. e.Graphics.FillRectangle(SystemBrushes.Highlight, rect)  

  23. Else  

  24. e.Graphics.FillRectangle(SystemBrushes.Window, rect)  

  25. End If  

  26.  

  27. Dim colorname As String = ComboBox1.Items(e.Index)  

  28. Dim b As New SolidBrush(Color.FromName(colorname))  

  29.  

  30. '縮小選定項(xiàng)區(qū)域()  

  31. rect.Inflate(-16, -2)  

  32. '填充顏色(文字對(duì)應(yīng)的顏色)  

  33. e.Graphics.FillRectangle(b, rect)  

  34. '繪制邊框()  

  35. e.Graphics.DrawRectangle(Pens.Black, rect)  

  36. Dim b2 As Brush  

  37. '確定顯示的文字的顏色()  

  38. If CInt(b.Color.R) + CInt(b.Color.G) + CInt(b.Color.B) > 128 * 3 Then  

  39. b2 = Brushes.Black  

  40. Else  

  41. b2 = Brushes.White  

  42.  

  43. End If  

  44. e.Graphics.DrawString(colorname, Me.ComboBox1.Font, b2, rect.X, rect.Y)  

  45.  

  46. End Sub  

  47.  

  48. Private Sub Form1_Load
    (ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load  

  49. filllistboxwithcolors()  

  50. End Sub 

以上是“VB.NET中如何使用COMBOBOX控件”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI