欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter實現(xiàn)滾動選擇數(shù)字

 更新時間:2022年03月22日 16:43:13   作者:Bob康康  
這篇文章主要為大家詳細(xì)介紹了Flutter實現(xiàn)滾動選擇數(shù)字,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了Flutter實現(xiàn)滾動選擇數(shù)字的具體代碼,供大家參考,具體內(nèi)容如下

前言

本來想百度查的,結(jié)果沒查到,只有自己寫,順便記錄一下,加深印象

頁面需求要用戶輸入頁碼,之前選擇的是使用TextField。后來覺得用showDialog彈出選項,讓用戶自己選擇。類似這樣的:

確定了樣式就開始寫吧。關(guān)于Dialog的選擇,我用的是SimpleDialog,有對細(xì)節(jié)上有要求的可以自己自定義一個。

showDialog(
? ? ? ? ? ? ? ? context: context,
? ? ? ? ? ? ? ? barrierDismissible: true,
? ? ? ? ? ? ? ? builder: (ctx){
? ? ? ? ? ? ? ? ? return SimpleDialog(
? ? ? ? ? ? ? ? ? ? title: Text('頁碼選擇'),
? ? ? ? ? ? ? ? ? ? contentPadding: EdgeInsets.zero,
? ? ? ? ? ? ? ? ? ? children: [
? ? ? ? ? ? ? ? ? ? ? PageChoose(changeBookIdCallBack: (pageNum2){
? ? ? ? ? ? ? ? ? ? ? ? setState(() {
? ? ? ? ? ? ? ? ? ? ? ? ? pageNum = pageNum2;
? ? ? ? ? ? ? ? ? ? ? ? });
? ? ? ? ? ? ? ? ? ? ? }),
? ? ? ? ? ? ? ? ? ? ? Divider(height: 1,),
? ? ? ? ? ? ? ? ? ? ? FlatButton(
? ? ? ? ? ? ? ? ? ? ? ? child: Text('取消'),
? ? ? ? ? ? ? ? ? ? ? ? onPressed: () {
? ? ? ? ? ? ? ? ? ? ? ? ? Navigator.of(context).pop();
? ? ? ? ? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? ? ? ? ),
? ? ? ? ? ? ? ? ? ? ? Divider(height: 1,),
? ? ? ? ? ? ? ? ? ? ? FlatButton(
? ? ? ? ? ? ? ? ? ? ? ? child: Text('確認(rèn)'),
? ? ? ? ? ? ? ? ? ? ? ? onPressed: () {
? ? ? ? ? ? ? ? ? ? ? ? ? }));
? ? ? ? ? ? ? ? ? ? ? ? },
? ? ? ? ? ? ? ? ? ? ? ),
? ? ? ? ? ? ? ? ? ? ],
? ? ? ? ? ? ? ? ? );
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? );

我將contentPadding設(shè)置為零,看著舒服點。目前已經(jīng)完成一部分了,還差中間的滾動選擇數(shù)字。

新建文件,創(chuàng)建一個StatelessWidget組件,這里不需要用到StatefulWidget,用不到setState。滾動數(shù)字我首先想到的是PageView組件,將它的scrollDirection變?yōu)锳xis.vertical,就可以實現(xiàn)上下的滑動,這里我需要預(yù)覽當(dāng)前前后兩個數(shù)字,在設(shè)置PageController的時候就需要給viewportFraction值,這里我給了0.3,具體看你給組件的寬高。

class PageChoose extends StatelessWidget {
? PageChoose({this.changeBookIdCallBack});
? final ValueChanged<int> changeBookIdCallBack;
? final PageController pagecontroller = new PageController(viewportFraction: 0.3,initialPage: 1);
? @override
? Widget build(BuildContext context) {
? ? return Center(
? ? ? child: Container(
? ? ? ? alignment: Alignment.center,
? ? ? ? height: 150,
? ? ? ? width: 60,
? ? ? ? child: Stack(
? ? ? ? ? children: [
? ? ? ? ? ? Center(
? ? ? ? ? ? ? child: Container(
? ? ? ? ? ? ? ? height: 50,
? ? ? ? ? ? ? ? decoration: BoxDecoration(
? ? ? ? ? ? ? ? ? border: Border(top: BorderSide(width: 0.5),bottom: BorderSide(width: 0.5))
? ? ? ? ? ? ? ? ),
? ? ? ? ? ? ? ),
? ? ? ? ? ? ),
? ? ? ? ? ? PageView.builder(
? ? ? ? ? ? ? itemCount: 50,
? ? ? ? ? ? ? controller: pagecontroller,
? ? ? ? ? ? ? scrollDirection: Axis.vertical,
? ? ? ? ? ? ? pageSnapping: true,
? ? ? ? ? ? ? physics: AlwaysScrollableScrollPhysics(),
? ? ? ? ? ? ? itemBuilder: (ctx ,index ){
? ? ? ? ? ? ? ? return Center(child: Text('$index',style: TextStyle(fontSize: 20),));
? ? ? ? ? ? ? },
? ? ? ? ? ? ? onPageChanged: (int index) {
? ? ? ? ? ? ? ? changeBookIdCallBack(index);
? ? ? ? ? ? ? },
? ? ? ? ? ? ),
? ? ? ? ? ],
? ? ? ? ),
? ? ? ),
? ? );
? }
}

我還給組件加了子傳父的方法,這樣在選完后直接傳值給父頁面。這樣就完成了。

總結(jié)

希望可以幫到初學(xué)Flutter的同學(xué)。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android視頻懸浮窗口實現(xiàn)的示例代碼

    Android視頻懸浮窗口實現(xiàn)的示例代碼

    這篇文章主要介紹了Android視頻懸浮窗口實現(xiàn)的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Android中3種全屏方法及3種去掉標(biāo)題欄的方法

    Android中3種全屏方法及3種去掉標(biāo)題欄的方法

    這篇文章主要介紹了Android中3種全屏方法及3種去掉標(biāo)題欄的方法,二個問題各給出了3種解決方法,并給出實例代碼,需要的朋友可以參考下
    2015-06-06
  • Flutter?Widget?之StatefulBuilder構(gòu)建方法詳解

    Flutter?Widget?之StatefulBuilder構(gòu)建方法詳解

    這篇文章主要為大家介紹了Flutter?Widget?之StatefulBuilder構(gòu)建方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • Android的文本和輸入之創(chuàng)建輸入法教程

    Android的文本和輸入之創(chuàng)建輸入法教程

    輸入法編輯器(IME)是讓用戶輸入文本的控件,Android提供了一個可擴展的的輸入法的框架,它允許應(yīng)用程序給用戶提供另外的輸入法,如軟鍵盤或語音輸入,需要的朋友可以了解下
    2012-12-12
  • Android編程四大組件之Activity用法實例分析

    Android編程四大組件之Activity用法實例分析

    這篇文章主要介紹了Android編程四大組件之Activity用法,實例分析了Activity的創(chuàng)建,生命周期,內(nèi)存管理及啟動模式等,具有一定參考借鑒價值,需要的朋友可以參考下
    2016-01-01
  • Android?Jetpack組件中LifeCycle作用詳細(xì)介紹

    Android?Jetpack組件中LifeCycle作用詳細(xì)介紹

    Jetpack是谷歌在Google?I/O?2017大會上發(fā)布一套幫助開發(fā)者解決Android架構(gòu)設(shè)計的方案,而Lifecycle是Jetpack?architecture下的一部分,一起來看一下Lifecycle的使用及原理分析
    2022-09-09
  • android使用ViewPager實現(xiàn)圖片自動切換

    android使用ViewPager實現(xiàn)圖片自動切換

    這篇文章主要為大家詳細(xì)介紹了android使用ViewPager實現(xiàn)圖片自動切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • android實現(xiàn)菜單三級樹效果

    android實現(xiàn)菜單三級樹效果

    這篇文章主要為大家詳細(xì)介紹了android實現(xiàn)菜單三級樹效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • android配合viewpager實現(xiàn)可滑動的標(biāo)簽欄示例分享

    android配合viewpager實現(xiàn)可滑動的標(biāo)簽欄示例分享

    本文主要介紹了android實現(xiàn)可滑動的標(biāo)簽欄示例,配合viewpager作為標(biāo)簽欄,且可以設(shè)置每頁顯示的標(biāo)簽個數(shù),超出可滑動顯示,需要的朋友可以參考下
    2014-02-02
  • Android帶刷新時間顯示的PullToRefresh上下拉刷新

    Android帶刷新時間顯示的PullToRefresh上下拉刷新

    這篇文章主要為大家詳細(xì)介紹了Android帶刷新時間顯示的PullToRefresh上下拉刷新,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12

最新評論