寫一個倒計時定時器聽起來真的好簡單,然而在Flutter里面寫這個東西還是挺坑的。
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供平和網(wǎng)站建設(shè)、平和做網(wǎng)站、平和網(wǎng)站設(shè)計、平和網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、平和企業(yè)網(wǎng)站模板建站服務(wù),10多年平和做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
原本以為創(chuàng)建一個Timer就一切都搞定了,但并沒辦法實時獲取倒計時的進度。
看了一下源碼,我們還可以創(chuàng)建一個周期性的Timer,從打印結(jié)果可以看到Timer的tick是從1開始的。
我們修改一下做一個倒計時獲取重新獲取驗證碼的功能。
1. div和table
這個是最簡單的,也是最基礎(chǔ)的。要熟練掌握div、form table、ul li 、p、span、font這些標簽,這些都是最常用的,特別是div和table,div用于布局、table也可以用于布局,但是不靈活,基本 table是用來和數(shù)據(jù)打交道。
2.html
HTML是指超文本標簽語言,是目前web領(lǐng)域應(yīng)用廣泛的語言,我們只需要在html文檔中插入對應(yīng)的標簽,即可實現(xiàn)web頁面的編寫與排列,所以要熟練掌握HTML基本知識,包括每個標簽的用法等。
3. CSS
CSS指層疊樣式表,可以為HTML標簽自定義樣式,通過設(shè)置HTML標簽的樣式,來改變其外形,達到美化與排版web頁面的目的。
4.Javascript
Javascript是網(wǎng)頁腳本語言,它可以在html中運行,設(shè)置并修改瀏覽器中的各種對象與變量。例如用來改進設(shè)計、驗證表單、檢測瀏覽器、創(chuàng)建 cookies等等,現(xiàn)在各大網(wǎng)站都可以看見 Javascript的蹤影,常見的網(wǎng)站首頁大眼晴、警告提示框、頁面動畫效果等等。Javascript更是一種在客戶端廣泛使用的腳步語言,在 Javascript當中提供了一些內(nèi)置函數(shù)、對象和DOM操作,借助這些內(nèi)容我們可以來實現(xiàn)一些客戶端的特效、驗證、交互等!
5.Jquery
Jquery是相當于把js封裝了一套的一個js插件,目的就是操作起來更方便,代碼寫的更少。 Jquery是一個免費、開源的輕量級的Javascript庫,并且兼容各種瀏覽器,同時現(xiàn)在有很多基于 Jquery的插件可供選擇,這樣在我們實現(xiàn)一些豐富的動態(tài)效果時更方便快捷,大大節(jié)省了我們開發(fā)的時間,提高了開發(fā)速度。
6.框架
從 bootstrap開始,響應(yīng)式的珊格系統(tǒng)被后來框架一直沿用,建議學(xué)一套主流mvc框架,vue,react, angular兩選一種。
7.會點后臺語言
對于前端工程師來說,并不需要像網(wǎng)站程序員樣,編寫對象、開發(fā)特殊功能、搭建數(shù)據(jù)庫。但是前端工程師要掌握基本的頁面GET&POST傳參、程序判斷語法、程序輸出語法、頁面提交、數(shù)據(jù)庫查詢與記錄插入,以及掌握HTTP與WEB工作原理、掌握Socket長連接實時網(wǎng)絡(luò)通信技術(shù)、掌握 NOSQL中的 MONGODB的應(yīng)用、了解PHP語法、了解 MYSQL數(shù)據(jù)庫的基本操作。
當然,以上技能能夠幫助你成為一個合格的前端工程師,但要成為一個優(yōu)秀的前端,必須掌握除技術(shù)以外的東西,例如設(shè)計,用戶等等,因此還需不斷的堅持學(xué)習(xí)。
對于一些復(fù)雜或不規(guī)則的UI,我們可能無法使用現(xiàn)有的 Widget 組合去實現(xiàn),比如需要一個帶動畫的進度條,
又或者是一個特殊形狀的多邊形等等,當然有時候我們可以直接用圖片去實現(xiàn),但是并沒有達到我們想要
的效果,反而會讓我們產(chǎn)生不良的體驗。
幾乎所有的UI系統(tǒng)都會提供一個自繪UI的接口,這個接口通常會提供一塊2D畫布Canvas,Canvas內(nèi)部封裝了
一些基本繪制的API,開發(fā)者可以通過Canvas繪制各種自定義圖形。在Flutter中,提供了一個CustomPaint Widget,
它可以結(jié)合一個畫筆CustomPainter來實現(xiàn)繪制自定義圖形。
我們看看 CustomPaint 構(gòu)造函數(shù):
1.painter: 背景畫筆,會顯示在子節(jié)點后面;
2.foregroundPainter: 前景畫筆,會顯示在子節(jié)點前面
3.size:當child為null時,代表默認繪制區(qū)域大小,如果有child則忽略此參數(shù),畫布尺寸則為child尺寸。如果有child但是想指定畫布為特定大小,可以使用SizeBox包裹CustomPaint實現(xiàn)。
4.isComplex:是否復(fù)雜的繪制,如果是,F(xiàn)lutter會應(yīng)用一些緩存策略來減少重復(fù)渲染的開銷。
5.willChange:和isComplex配合使用,當啟用緩存時,該屬性代表在下一幀中繪制是否會改變。
可以看到,繪制時我們需要提供前景或者背景畫筆,兩者也可以同時提供,
我們的畫筆需要繼承 CustomPainter 類,我們在畫筆類中實現(xiàn)真正的繪制邏輯。
顧名思義畫布的意思,我們繪制布局當然是在一張畫布上進行繪制,畫布為我們繪制圖形提供了很多方法。(熟悉畫布的就無需再看了)
在繪制之前我們需要準備畫筆 Paint,就如畫畫一樣,你用什么筆就能畫什么樣的畫,在Paint中,
我們可以配置畫筆的各種屬性如粗細、顏色、樣式等。如:
好了,繼承CustomPainter類,然后準備好畫筆,就可以在畫布上盡情的揮灑了!
寫的挺簡單的,就是介紹了一下自定義view的準備工作以及畫布畫筆的功能,具體實戰(zhàn)請看下一篇博客。
表格布局和線性布局比較相似,只是使用起來更簡潔一些。
本地Flutter 2.10.1,Mac版Android Studio Bumblebee | 2021.1.1 Patch 2
我是小栗子,初學(xué)Flutter ,文章會根據(jù)學(xué)習(xí)進度不定時更新,請多多指教~~