基本和AppBar一樣,只是他只能在CustomScrollView中使用,應(yīng)該很常見,滑動的時候固定appbar,就需要用到他.

創(chuàng)新互聯(lián)一直秉承“誠信做人,踏實做事”的原則,不欺瞞客戶,是我們最起碼的底線! 以服務(wù)為基礎(chǔ),以質(zhì)量求生存,以技術(shù)求發(fā)展,成交一個客戶多一個朋友!為您提供網(wǎng)站制作、成都網(wǎng)站設(shè)計、成都網(wǎng)頁設(shè)計、小程序設(shè)計、成都網(wǎng)站開發(fā)、成都網(wǎng)站制作、成都軟件開發(fā)、成都app軟件開發(fā)是成都本地專業(yè)的網(wǎng)站建設(shè)和網(wǎng)站設(shè)計公司,等你一起來見證!
大部分和appbar一樣,主要說下重要的幾個:
是否將導(dǎo)航欄部分固定在appbar的位置.這個需求在實際中很常用. 看看效果圖.
當(dāng) pinned = false:
可以看到appbar并沒有固定在最上面,而是根據(jù)內(nèi)容劃出了界面.
當(dāng) pinned = true :
這個應(yīng)該是需求中經(jīng)常用到的效果了.
當(dāng)floating = false :
當(dāng)floating = true:
仔細(xì)看 ,區(qū)別是在列表整體向下滑動時,appbar開始顯示的位置不同.
當(dāng)為false時 ,向下滑動時,會先降列表內(nèi)容滑動頂部,然后appbar會跟著列表滑動顯示出來.如上圖
當(dāng)為true時, 向下滑動時,appbar會先跟著列表滑動顯示出來. 然后繼續(xù)列表的滑動. 如上圖
不能單獨(dú)使用要配合 ****floating 和 ****pinned
具體效果看官網(wǎng)地址
是否展開,默認(rèn)false,直接看值為true的效果圖,就明白了.
可以再里面添加擴(kuò)展的內(nèi)容:
通過測試發(fā)現(xiàn) **后面不是 FlexibleSpaceBar 的話, stretch = true 無效. **
和Padding一樣.子控件是 sliver 類型...
上圖中在padding中添加了一個背景色為青色的容器widget
里面可以設(shè)置不是 sliver 類型的widget。如上圖中的 padding中添加的 container
就兩個協(xié)議,一個是布局協(xié)議一個展示協(xié)議.基本和GridView一樣.也有count和extext... 不設(shè)置個數(shù)默認(rèn)無數(shù)個
SliverChildListDelegate 這種方式前提是知道cell個數(shù),比較少,好搭建
SliverChildBuilderDelegate 這種方式,可以根據(jù)數(shù)組去創(chuàng)建,不知道cell個數(shù)
和listview差不多.也是協(xié)議 不設(shè)置個數(shù)默認(rèn)無數(shù)個
小菜在業(yè)務(wù)開發(fā)過程中會自定義 Slider 滑動條,而在自定義之前,小菜先簡單了解一下 Flutter 自帶的 Slider ;
簡單分析源碼可得, Slider 是一個有狀態(tài)的 StatefulWidget 組件,屬性也很清晰易懂,其中滑動過程中對應(yīng)的 value 值和 onChanged 回調(diào)是必須參數(shù);
value 未滑動過程中對應(yīng)的值,在 min 和 max 之間; onChanged 是在滑動過程中回調(diào),當(dāng) onChanged 為 null 或 value 所在的 min 和 max 集合范圍為空時, Slider 禁止滑動;
min 和 max 為滑動條范圍,而 value 的取值范圍是在 min 和 max 之間,無論 value 為正還是負(fù),均需要在 min 和 max 之間;
activeColor 為滑動條已滑動過的顏色; inactiveColor 為滑動條中未滑動的顏色;兩者均可以在 SliderTheme 中設(shè)置;
label 為滑動條滑動到某一節(jié)點(diǎn)的標(biāo)簽文案; divisions 是把 min 和 max 等分為 divisions 份數(shù);只有在 divisions 生效時, label 才會展示;
onChangeStart 和 onChangeEnd 分別對應(yīng)滑動過程中 value 值何時開始更改或何時完成更改時對應(yīng)的回調(diào);
Slider 的主題效果可以通過 SliderTheme 或 ThemeData.sliderTheme 中獲取更新,相較于 Slider 只提供已滑動和未滑動顏色效果,屬性粒度更細(xì);
activeTrackColor 和 inactiveTrackColor 分別對應(yīng) Slider 已滑動過和未滑動過的軌道顏色;
thumbColor 對應(yīng)滑動按鈕顏色,而 overlayColor 對應(yīng)滑動按鈕映射的疊層顏色,通常設(shè)置為半透明狀態(tài); overlayShape 對應(yīng)疊層樣式;
valueIndicatorColor 對應(yīng) label 氣泡顏色; valueIndicatorShape 對應(yīng)氣泡內(nèi)文字屬性; valueIndicatorShape 對應(yīng)氣泡樣式,可以再此進(jìn)行自定義氣泡;
activeTickMarkColor 對應(yīng)已選中刻度顏色; inactiveTickMarkColor 對應(yīng)未選中刻度顏色; tickMarkShape 對應(yīng)刻度樣式;
trackHeight 為 Slider 軌道高度; trackShape 對應(yīng)軌道樣式,主要再此處進(jìn)行自定義樣式;
對于不可滑動狀態(tài), SliderThemeData 提供了對應(yīng)屬性;
Slider 案例源碼
小菜本節(jié)暫未涉及自定義滑動條樣式,對于底層的 Slider 了解還不夠深入;如有錯誤,請多多指導(dǎo)!
1.webview_flutter
2.flutter_inappwebview
3.flutter_webview_plugin
筆者最近發(fā)現(xiàn)webview_flutter在Android端嵌套帶有較長的Webview頁面時偶?xì)W會存在卡頓問題表現(xiàn)為加速向下滑動到頁面底部,然后從底部慢慢像上滑就不起作用了,體驗很不好,經(jīng)過一天的排查和實驗發(fā)現(xiàn)是webview_flutter插件自己的問題,用原生嵌套WebView并沒有問題,后來改成flutter_webview_plugin問題可以解決,但是flutter_webview_plugin插件并不是基于flutter渲染的并不能在嵌套webview的頁面自定義flutter樣式層,后來發(fā)現(xiàn)使用flutter_inappwebview插件能夠完美解決問題。推薦你們用flutter_inappwebview。
空間超出提示
注釋 :Flutter Incorrect use of ParentDataWidget
問題原因:Expanded、Flexible等組件,在“Container、Padding、Stack”組件中導(dǎo)致的。
解決方案:保持: Expanded、Flexible 只在 Row、Column 等組件內(nèi),不在其他組件內(nèi)使用。
控件Row有一個水平的布局方向,但是內(nèi)容已經(jīng)超出了可顯示的范圍。
建議我們使用有彈性的控件比如Expanded代替,或者使用可裁剪的控件ClipRect代替,還可以使用具體滾動屬性的控件比如ListView代替
1、類似圖片加載失敗,然后溢出擠壓空間,可以用Container包裹一下
直接使用,如果圖片地址失效,就會溢出
直接使用,圖片鏈接失效引起
2、類似這種超出
A RenderFlex overflowed by 48 pixels on the right.
3、類似這種Column滾動超出!
實現(xiàn)頁面滑動需要用到SingleChildScrollView組件,SingleChildScrollView和Android中ScrollView類似
問題原因:Expanded、Flexible等組件,在“Container、Padding、Stack”組件中導(dǎo)致的。
解決方案:保持:Expanded、Flexible只在Row、Column等組件內(nèi),不在其他組件內(nèi)使用。
PageView 是一個滑動視圖列表,它也是繼承至 CustomScrollView 的。
在 PageView 里有三個構(gòu)造函數(shù):
PageView 有以下常用屬性:
文章標(biāo)題:flutter滑動頁面,flutter頭部導(dǎo)航向下滑動
網(wǎng)頁網(wǎng)址:http://chinadenli.net/article49/dsijseh.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站排名、網(wǎng)站制作、ChatGPT、Google
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)