Windows Phone自定義控件
為了實現(xiàn)公司需求,不得不自己寫自定義控件。首先第一個需求是密碼掩碼和明碼顯示的切 換。做的時候發(fā)現(xiàn)PasswordBox沒有切換掩碼和明碼的屬性或方法。那好咱只好自己動手實現(xiàn),用一個TextBox和passwordBox來分別 實現(xiàn)掩碼和明碼的顯示。直接上效果圖吧。
明碼顯示
掩碼顯示
舊密碼仍舊掩碼顯示,而新編輯的密碼是明碼顯示
第二個控件是下拉刷新控件。下拉提示下拉可以刷新,下拉到一定程度提示松開可以刷新,松開手后顯示正在刷新。
這樣的控件網(wǎng)上還是有例子的,繼承ListBox,使用自己的控件模版來實現(xiàn)一個下拉刷新列表框。然而做好后發(fā)現(xiàn),公司需求是要可以容納大批量數(shù)據(jù)的列表,而且還要提供復(fù)選框。
這沒關(guān)系,有Toolkit控件嘛,LongListSelector有虛擬化功能,可以加載大約8000條數(shù)據(jù)而不占用大量內(nèi)存開銷,而且還有選擇狀態(tài),列表項前面有復(fù)選框。好吧,咱就繼承LongListSelector 控件實現(xiàn)一個下拉刷新控件。
照同樣的方法寫好了,然而發(fā)現(xiàn)數(shù)據(jù)綁定上去后,竟然顯示不出任何數(shù)據(jù)。這是為毛啊,為毛啊!斷點調(diào)試ItemsSource數(shù)據(jù)有綁定上去啊!瞬間淚奔啊!
后來從Toolkit的源碼里面找到LongListSelector 的控件模版,發(fā)現(xiàn)承載內(nèi)容的模版是好像是叫ViewPorts的控件。好把咱把控件的模版里面內(nèi)容承載的模版換成Viewport。再次運行,OK!顯示成功,瞬間內(nèi)流滿面!上圖
效果出來了,咱試試大批量數(shù)據(jù)加載,先加個800條看看,有些卡,不過還算正常。
再試試加載1000條數(shù)據(jù),瞬間崩潰了,為啥呀,為啥呀!后來發(fā)現(xiàn)繼承LongListSelector 寫的控件的模版有ScrollViewer,這個東西破壞了虛擬化。從LongListSelector 的可視化樹中取ScrollViewer,壓根沒這東西,只能取到ScrollBar。好吧!這樣寫是不行的,再次淚奔了。
最后絞盡腦筋只能用控件的MouseEnter、MouseMove和MouseLeave三個事件,加上控件ScrollBar的Value值來 模擬這樣的效果。總算是能實現(xiàn)同樣的效果,不過效果比繼承的方法略差。好處是,完全不會破壞LongListSelector 的虛擬化,一次加載個1000條數(shù)據(jù)完全顯示正常,不會崩潰。總算能交差了!