Flutter 一行代碼實現(xiàn)9宮格圖片選擇器

dd_js_util

Flutter 常用組件

封裝了一些APP制作中常見的一些小組件,這篇博客介紹一下一行代碼實現(xiàn)9宮格圖片選擇器

安裝

dd_js_util: ^0.1.0

如何使用?

1.聲明組件
PictureSelection(multipleChoice: true,controller: _pictureSelectionController),
預(yù)覽
2. 可選配置 (一般用默認(rèn)的就可以了)
 /// 一行展示多少張圖片
  ///
  /// 默認(rèn): 3
  final int columnCount;

  ///最多可以選擇幾張圖片
  ///
  /// 默認(rèn): 9
  final int maxCount;

  /// 每張圖片之間的間距 (橫向)
  ///
  /// 默認(rèn):12
  final double? mainAxisSpacing;

  /// 每張圖片之間的間距 (豎向)
  ///
  /// 默認(rèn): 12
  final double? crossAxisSpacing;

  /// 組件的邊距
  ///
  /// 默認(rèn): 12
  final EdgeInsets? padding;

  /// 是否允許多選
  ///
  /// 默認(rèn)false
  final bool multipleChoice;

  /// 刪除某個圖片回調(diào)
  /// 如果添加了這個參數(shù),組件將不會執(zhí)行默認(rèn)的刪除函數(shù)
  final ValueChanged<File>? removed;

  /// 自定義圖片布局
  ///
  ///
  ///
  /// 例子
  ///                 itemBuilder: ( context, file, size, onRemove){
  ///                   return SizedBox(
  ///                     width: size.width,
  ///                     height: size.height,
  ///                     child: GestureDetector(child: Image.file(file),onTap:(){
  ///                       //點擊圖片刪除
  ///                       onRemove(file);
  ///                     }),
  ///                   );
  ///                 },
  ///
  ///
  final ImageItemRender? itemBuilder;

  /// 自定義占位小部件
  ///
  ///
  /// 例子
  ///                 placeholderBuilder: (size) {
  ///                   return SizedBox(
  ///                       width: size.width,
  ///                       height: size.height,
  ///                       child: Center(
  ///                         child: Column(
  ///                           mainAxisAlignment: MainAxisAlignment.center,
  ///                           children: [
  ///                             Icon(Icons.add),
  ///                             SizedBox(height: 2),
  ///                             Text('添加圖片'),
  ///                           ],
  ///                         ),
  ///                       ));
  ///                 },
  ///
  ///
  final PlaceholderBuilder? placeholderBuilder;

  /// 自定義彈出菜單布局
  ///
  /// [Function] - 參數(shù)1 - 相冊選擇方式回調(diào)函數(shù)
  /// [Function] - 參數(shù)2 - 相機拍攝選擇模式
  ///
  ///
  /// 例子:
  ///                 menusBuilder: (a,b){
  ///                   return Container(
  ///                     color: Colors.pink,
  ///                     child: SingleChildScrollView(
  ///                       child: Column(children: [
  ///                         TextButton(child: Text('圖庫選擇'),onPressed: () async {
  ///                           await a();
  ///                         },),
  ///                         TextButton(child: Text('相機選擇'),onPressed: () async {
  ///                           await b();
  ///                         },)
  ///                       ],)
  ///                     ),
  ///                   );
  ///                 },
  ///
  ///
  final MenusBuilder? menusBuilder;

  /// 組件的控制器
  final PictureSelectionController? controller;


3. 控制器API
//1). 獲取用戶選擇或者拍攝的圖片
List<File> files = _pictureSelectionController.getFiles;

//2). 清空全部圖片
_pictureSelectionController.clean();

//3). 獲取圖片數(shù)量
_pictureSelectionController.length;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末畦浓,一起剝皮案震驚了整個濱河市项阴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌坯门,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件晨横,死亡現(xiàn)場離奇詭異谴分,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門苍碟,熙熙樓的掌柜王于貴愁眉苦臉地迎上來酒觅,“玉大人,你說我怎么就攤上這事微峰∠系ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵蜓肆,是天一觀的道長颜凯。 經(jīng)常有香客問我,道長仗扬,這世上最難降的妖魔是什么症概? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮早芭,結(jié)果婚禮上彼城,老公的妹妹穿的比我還像新娘。我一直安慰自己退个,他們只是感情好募壕,可當(dāng)我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著语盈,像睡著了一般司抱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上黎烈,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天习柠,我揣著相機與錄音,去河邊找鬼照棋。 笑死资溃,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的烈炭。 我是一名探鬼主播溶锭,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼符隙!你這毒婦竟也來了趴捅?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤霹疫,失蹤者是張志新(化名)和其女友劉穎拱绑,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體丽蝎,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡猎拨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片红省。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡额各,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出吧恃,到底是詐尸還是另有隱情虾啦,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布痕寓,位于F島的核電站傲醉,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏厂抽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一丁眼、第九天 我趴在偏房一處隱蔽的房頂上張望筷凤。 院中可真熱鬧,春花似錦苞七、人聲如沸藐守。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽卢厂。三九已至,卻和暖如春惠啄,著一層夾襖步出監(jiān)牢的瞬間慎恒,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工撵渡, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留融柬,地道東北人。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓趋距,卻偏偏與公主長得像粒氧,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子节腐,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,901評論 2 345