自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

深入討論VB.NET設(shè)置控件

開(kāi)發(fā) 后端
這里介紹VB.NET設(shè)置控件,用戶可以根據(jù)自己的喜好來(lái)選擇不同的界面,從而實(shí)現(xiàn)了個(gè)性化的設(shè)置。但是換膚技術(shù)有一個(gè)不足之處,那就是所有的皮膚都是由開(kāi)發(fā)者預(yù)先提供的,而且數(shù)量有限。

VB.NET經(jīng)過(guò)長(zhǎng)時(shí)間的發(fā)展,很多用戶都很了解VB.NET設(shè)置控件了,這里我發(fā)表一下個(gè)人理解,和大家討論討論。個(gè)人都不希望在別人的身上發(fā)現(xiàn)有與自己的相同之處。作為計(jì)算機(jī)軟件來(lái)說(shuō)也是一樣,每一個(gè)用戶都希望自己使用的軟件與別人不一樣,于是誕生了換膚技術(shù)。用戶可以根據(jù)自己的喜好來(lái)選擇不同的界面,從而實(shí)現(xiàn)了個(gè)性化的設(shè)置。但是換膚技術(shù)有一個(gè)不足之處,那就是所有的皮膚都是由開(kāi)發(fā)者預(yù)先提供的,而且數(shù)量有限。這就導(dǎo)致了有些用戶使用的皮膚會(huì)和另一些用戶使用的皮膚相同,從而違背了設(shè)計(jì)者的初衷。雖然有些讀者會(huì)說(shuō),開(kāi)發(fā)商現(xiàn)在提供了下載服務(wù),可以從它們的網(wǎng)站下載更多的皮膚供用戶選擇,可是從我的使用中發(fā)現(xiàn)這些皮膚依然是有限的,而且對(duì)于沒(méi)有條件上網(wǎng)的用戶來(lái)說(shuō)這種服務(wù)是毫無(wú)價(jià)值。

作為一個(gè)軟件開(kāi)發(fā)人員,當(dāng)一種技術(shù)已經(jīng)無(wú)法滿足用戶的需要的時(shí)候就該開(kāi)動(dòng)腦筋,想想是否可以從另一種角度來(lái)思考問(wèn)題的答案。在這個(gè)前提下,通過(guò)本人的思考終于想出了一個(gè)新的方法,我將它稱為--交互界面。使用這種技術(shù)可以保證在全球范圍內(nèi)不會(huì)出現(xiàn)相同的界面結(jié)構(gòu),從而完全實(shí)現(xiàn)個(gè)性化。

其實(shí)要實(shí)現(xiàn)這種界面在技術(shù)方式上并沒(méi)有太高的要求。實(shí)現(xiàn)原理就是:讓用戶自己調(diào)整每一個(gè)控件的位置然后保存這些控件在界面上的坐標(biāo)位置。在以后啟動(dòng)這個(gè)程序的界面時(shí)讀取這些值,用這些值來(lái)VB.NET設(shè)置控件在界面中的位置。下面的代碼就是為實(shí)現(xiàn)這個(gè)功能而設(shè)計(jì)的(用VB.NET編寫)

  1. Private Sub Form1_MouseUp(ByVal sender As Object,  
  2. ByVal e As System.Windows.Forms.MouseEventArgs) Handles MyBase.MouseUp  
  3. Dim x, y  
  4. x = e.X  
  5. y = e.Y'獲得新的x,y的坐標(biāo)  
  6. If Button1.Enabled = False Then  
  7. Button1.Top = y 
  8. Button1.Left = x'坐標(biāo)替換  
  9. End If  
  10. If TextBox1.Enabled = False Then  
  11. TextBox1.Top = y 
  12. TextBox1.Left = x  
  13. End If  
  14. End Sub  
  15. Private Sub MenuItem2_Click(ByVal sender As System.Object,
    ByVal e As System.EventArgs) Handles MenuItem2.Click  
  16. Button1.Enabled = False'禁止控件響應(yīng)事件  
  17. If TextBox1.Enabled = False Then  
  18. TextBox1.Enabled = True 
  19. End If  
  20. End Sub  
  21. Private Sub MenuItem3_Click(ByVal sender As System.Object,  
  22. ByVal e As System.EventArgs) Handles MenuItem3.Click  
  23. TextBox1.Enabled = False 
  24. If Button1.Enabled = False Then  
  25. Button1.Enabled = True 
  26. End If  
  27. End Sub  
  28. Private Sub MenuItem4_Click(ByVal sender As System.Object,
    ByVal e As System.EventArgs) Handles MenuItem4.Click  
  29. TextBox1.Enabled = True 
  30. Button1.Enabled = True 
  31. '將新的坐標(biāo)保存到文本文件中  
  32. If IO.File.Exists("c:\k.txt") = True Then  
  33. IO.File.Delete("c:\txt")  
  34. Dim sw As IOIO.StreamWriter = IO.File.CreateText("c:\k.txt")  
  35. Dim cstringt, cstringl As String  
  36. Dim tstringt, tstringl As String  
  37. cstringt = Button1.Top  
  38. cstringl = Button1.Left  
  39. tstringt = TextBox1.Top  
  40. tstringl = TextBox1.Left  
  41. sw.WriteLine(cstringt)'寫入新坐標(biāo)到文本文件中  
  42. sw.WriteLine(cstringl)  
  43. sw.WriteLine(tstringt)  
  44. sw.WriteLine(tstringl)  
  45. sw.Close()  
  46. Else  
  47. Dim sw As IOIO.StreamWriter = IO.File.CreateText("c:\k.txt")  
  48. Dim cstringt, cstringl As String  
  49. Dim tstringt, tstringl As String  
  50. cstringt = Button1.Top  
  51. cstringl = Button1.Left  
  52. tstringt = TextBox1.Top  
  53. tstringl = TextBox1.Left  
  54. sw.WriteLine(cstringt)  
  55. sw.WriteLine(cstringl)  
  56. sw.WriteLine(tstringt)  
  57. sw.WriteLine(tstringl)  
  58. sw.Close()  
  59. End If  
  60. MsgBox("當(dāng)前界面已經(jīng)保存")  
  61. End Sub  
  62. Private Sub Form1_Load(ByVal sender As Object,  
  63. ByVal e As System.EventArgs) Handles MyBase.Load  
  64.  
  65. If IO.File.Exists("c:\k.txt") = True Then  
  66. Dim sr As IOIO.StreamReader = IO.File.OpenText("c:\k.txt")  
  67. Dim input1, input2, input3, input4 As String  
  68. input1 = sr.ReadLine  
  69. input2 = sr.ReadLine  
  70. input3 = sr.ReadLine  
  71. input4 = sr.ReadLine'讀取文件中的坐標(biāo)  
  72. Button1.Top = input1 
  73. Button1.Left = input2 
  74. TextBox1.Top = input3 
  75. TextBox1.Left = input4'用文件中的值來(lái)初始化控件在界面中的位置  
  76. sr.Close()  
  77. End If  
  78. End Sub 

程序說(shuō)明:在MenuItem4_Click 是在調(diào)整控件之后將控件的新位置保存到c;\k.txt文件中。form_load中的if作用是,如果是沒(méi)有VB.NET設(shè)置控件的新位置在初始化是將不會(huì)發(fā)現(xiàn)c;\k.txt文件,從而使用默認(rèn)的參數(shù)來(lái)指定控件的位置。如果是有c;\k.txt文件存在就讀取其中的參數(shù)來(lái)初始化控件的位置。在Form1_MouseUp中通過(guò)點(diǎn)擊窗口中的位置來(lái)獲得新的坐標(biāo),使控件移動(dòng)到此坐標(biāo)處。對(duì)于Enabled屬性的使用是為了使控件在移動(dòng)時(shí)不響應(yīng)如click等的事件。

本文移動(dòng)的控件是textbox和button兩個(gè)控件,你可以按照本文提出的方法加入更多的控件,從而實(shí)現(xiàn)千人千面。

其實(shí)本人寫這篇文章的一個(gè)主要目的是為了說(shuō)明一個(gè)程序員不但要掌握牢固的技術(shù),同時(shí)還要有創(chuàng)新的思想。正如國(guó)外的分析家指出"微軟的成功在很大的程度上是依靠它的創(chuàng)新思維",所以希望讀了此文的讀者在以后的開(kāi)發(fā)過(guò)程中不要墨守成規(guī)!

【編輯推薦】

  1. 代碼講述VB.NET實(shí)現(xiàn)數(shù)據(jù)綁定
  2. VB.NET TextBox組件高手經(jīng)驗(yàn)談
  3. 瞬間掌握VB.NET Web Service
  4. 實(shí)例分析VB.NET Treeview結(jié)構(gòu)
  5. 百寶箱之VB.NET設(shè)計(jì)制作窗體
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2010-01-12 15:21:48

VB.NET權(quán)限控制

2009-10-26 15:26:37

VB.NET屬性

2009-10-20 10:29:30

VB.NET使用Sor

2010-01-13 10:53:24

VB.NET控件

2009-10-14 10:19:57

VB.NET Doma

2009-10-14 16:04:43

VB.NET Noti

2009-10-20 10:16:24

VB.NET COMB

2009-10-23 13:14:38

2010-01-19 10:12:39

VB.NET Butt

2009-10-14 11:27:20

VB.NET Grou

2009-10-23 13:10:14

VB.NET List

2009-10-12 15:02:51

VB.NET動(dòng)態(tài)控件

2009-10-16 14:31:48

VB.NET Noti

2009-10-14 17:21:47

VB.NET定制Win

2009-10-27 18:06:41

VB.NET開(kāi)發(fā)控件

2009-10-16 13:19:04

VB.NET Data

2009-10-13 15:09:19

VB.NET使用Tre

2009-10-16 14:07:18

VB.NET使用Mon

2009-10-10 16:44:52

VB.NET開(kāi)發(fā)控件

2009-10-14 11:15:06

VB.NET Grou
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)