Flutter開發之Widget學習

来源:https://www.cnblogs.com/jyd0124/archive/2020/02/09/widget.html

一、Text 組件 屬性 textAlign: TextAlign.left, 文本對齊方式 maxLines: 1, 顯示最大行 overflow: TextOverflow.clip, 文本溢出的處理方式 clip:直接切斷溢出的文字。 ellipsis:在後邊顯示省略號(...) 常用 fad ...


一、Text 組件

屬性

 textAlign: TextAlign.left,                           -----文本對齊方式
 maxLines: 1,                                            -----顯示最大行
 overflow: TextOverflow.clip,                 -----文本溢出的處理方式
  • clip:直接切斷溢出的文字。
  • ellipsis:在後邊顯示省略號(...)  常用
  • fade: 漸變消失效果

style文字的樣式

 body: new Center(
          child: new Text('非淡泊無以明志,非寧靜無以致遠。(諸葛亮)',
              textAlign: TextAlign.left,
              maxLines: 1,
              overflow: TextOverflow.ellipsis,
              style: TextStyle(
                fontSize: 20,
                color: Color.fromARGB(255, 0, 0, 255),
                decoration: TextDecoration.underline,
                decorationStyle: TextDecorationStyle.solid,
                fontStyle: FontStyle.italic,
              )),
        ),

二、Container組件

 Alignment屬性,Container內child的對齊方式,也就是容器子內容的對齊方式,並不是容器本身的對齊方式。
padding         內邊距
margin           外邊距
decoration     裝飾器
使用:
body: new Center(
          child: new Container(
            child: new Text(
              '非淡泊無以明志,非寧靜無以致遠。(諸葛亮)',
              style: TextStyle(fontSize: 30.0),
            ),
            alignment: Alignment.topLeft,
            width: 500.0,
            height: 200.0,
            //color: Colors.lightBlue,
            //padding: const EdgeInsets.all(10),    //內邊距
            padding: const EdgeInsets.fromLTRB(10.0, 50.0, 0, 0),
            margin: const EdgeInsets.all(20.0),
            decoration: new BoxDecoration(
              gradient: const LinearGradient(
                  colors: [Colors.lightBlue, Colors.green, Colors.purple]
                  ),
                  border: Border.all(width: 5.0,color:Colors.red
                  ),
            ),
          ),
        ),

三、Image組件

加入圖片的方式:

  1. Image.asset                  項目資源圖片
  2. Image.file (絕對路徑)    系統資源圖片
  3. Image.network(url)   網路資源圖片

fit屬性

  • BoxFit.fill                             
  • BoxFit.contain                     
  • BoxFit.cover                        

repeat屬性

  • ImageRepeat.repeat      橫向和縱向都重覆,鋪滿整個容器
  • ImageRepeat.repeatX    橫向重覆
  • ImageRepeat.repeatY    縱向重覆
body: new Center(
            child: new Container(
          child: new Image.network(
            'https://profile.csdnimg.cn/0/5/2/1_jyd0124',
            fit: BoxFit.cover,
            //color: Colors.lightBlue,
            //colorBlendMode: BlendMode.darken, //圖片混合模式(colorBlendMode)和color屬性配合使用
          ),
          width: 300.0,
          height: 200.0,
          color: Colors.lightGreen,
        )
    ),

四、ListView組件

列表使用

body: new ListView(
          children: <Widget>[
            /*new Image.network(
                'https://cdn2.jianshu.io/assets/web/banner-s-club-aa8bdf19f8cf729a759da42e4a96f366.png'),
            new Image.network(
                'https://cdn2.jianshu.io/assets/web/banner-s-7-1a0222c91694a1f38e610be4bf9669be.png'),
             */ //圖片列表使用
            new ListTile(
              leading: new Icon(
                Icons.perm_camera_mic,
              ),
              title: new Text('perm_camera_mic'),
            ),
            new ListTile(
              leading: new Icon(
                Icons.perm_phone_msg,
              ),
              title: new Text('perm_phone_msg'),
            ),
          ],
        ),

橫向列表:ListView組件裡加一個scrollDirection屬性

body: new Center(
            child: new Container(
                height: 200.0,
                child: new ListView(
                  scrollDirection: Axis.horizontal, //Axis.vertical:縱向列表
                  children: <Widget>[
                    new Container(
                      width: 230.0,
                      color: Colors.lightBlue,
                    ),
                    new Container(
                      width: 230.0,
                      color: Colors.lightGreen,
                    ),
                  ],
                ))),

Dart語言List的聲明方式:

  • var myList = List(): 非固定長度的聲明。
  • var myList = List(2): 固定長度的聲明。
  • var myList= List<String>():固定類型的聲明方式。
  • var myList = [1,2,3]: 對List直接賦值
import 'package:flutter/material.dart';

void main() =>
    runApp(MyApp(items: List<String>.generate(1000, (i) => 'item $i')));

class MyApp extends StatelessWidget {
  final List<String> items;
  MyApp({Key key, @required this.items}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'ListView Dome',
      home: new Scaffold(
        appBar: new AppBar(title: new Text('ListView Widget')),
        body: new ListView.builder(
            itemCount: items.length,
            itemBuilder: (context, index) {
              return new ListTile(
                title: new Text('${items[index]}'),
              );
            }),
      ),
    );
  }
}

五、GridView組件

  常用屬性:

  • crossAxisSpacing:網格間的空當。
  • crossAxisCount:一行放置的網格數量
body: GridView.count(
            padding: EdgeInsets.all(20.0),
            crossAxisSpacing: 10.0,
            crossAxisCount: 3,
            children: <Widget>[
              const Text('I am j.y.d'),
              const Text('I love flutter'),
              const Text('jyd0124.com'),
              const Text('2020/02/06'),
              const Text('Come on,China!'),
              const Text('Come on,Wuhan!'),
            ],
          ),

官方已經不鼓勵使用這種方法,另一種寫法為

body: GridView(
           gridDelegate: SliverGridDelegateWithFixedCrossAxisCount(
             crossAxisCount: 3,
             mainAxisSpacing: 2.0,
             crossAxisSpacing: 2.0,
             childAspectRatio: 0.75,
             ),
            children: <Widget>[
              new Image.network('http://img5.mtime.cn/mg/2019/10/02/105324.67493314_170X256X4.jpg',fit:BoxFit.cover),
              new Image.network('http://img5.mtime.cn/mg/2019/09/26/092514.83698073_170X256X4.jpg',fit:BoxFit.cover),
              new Image.network('http://img5.mtime.cn/mg/2019/11/07/111316.10093613_170X256X4.jpg',fit:BoxFit.cover),
              new Image.network('http://img5.mtime.cn/mg/2019/12/13/094432.64997517_170X256X4.jpg',fit:BoxFit.cover),
              new Image.network('http://img31.mtime.cn/mt/2014/02/22/230757.74994253_220X124X4.jpg',fit:BoxFit.cover),
              new Image.network('http://img5.mtime.cn/mg/2019/07/10/164947.40820910_170X256X4.jpg',fit:BoxFit.cover),
            ],
        ),
  • childAspectRatio:寬高比
  • mainAxisSpacing:橫向網格空檔 
  • crossAxisSpacing: 向縱向網格空擋

至此,使用組件的學習就到這兒了,下篇我們將學習佈局的相關知識!


您的分享是我們最大的動力!

更多相關文章
  • 微信公眾號: "Dotnet9" ,網站: "Dotnet9" ,問題或建議: "請網站留言" , 如果對您有所幫助: "歡迎贊賞" 。 簡化MVVM屬性設置和修改 .NET CORE(C ) WPF開發 閱讀導航 1. 常用類屬性設置、獲取方式 2. 二次封裝 INotifyPropertyCha ...
  • 前段時間看.net core 更更更新了,大家反應都挺好,想有機會也學習一下,正好這兩天要寫一個簡單的服務在centos上面跑,於是決定放棄使用java,直接.net core走起來,事情進行的非常順利. 但是我們的vps都是合作伙伴提供,有時候是centos7,有時候是centos6,雖然cent ...
  • 這個是C#5中的新特性,當遇到await時,會從線程池中取出一個線程非同步執行await等待的操作,然後方法立即返回。等非同步操作結束後回到await所在的地方接著往後執行。await需要等待async Task ...
  • using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System. ...
  • 首先 經過我測試,php74模塊沒有支持apache的.所以升級到php74 之後,php無法使用. 最基本的函數phpinfo 調用不出來,沒有相關的模塊. 安裝mariadb 10.4 之後發現,mariadb 這個版本好像不支持密碼(反正我是沒搞定,一天) .改配置什麼的我都試了,仍然免密登陸 ...
  • 前言 我不是名校畢業,更沒有大廠的背景,我只是一個畢業不到 2 年的普普通通的程式員,在摸爬滾打的工作這段時間里,深知了有一個「完整的知識體系」是非常重要的。當事人非常後悔沒有在大學期間知道這個道理…… 眾多大廠招人的需求也是非常註重此方面,畢竟我們不能單單隻是一個只會寫代碼的程式員,更應該成為一個 ...
  • 為了在伺服器上跑爬蟲,以及學SegNet,研究了一圈看來linux是必學品了。在自己電腦上安裝了一個 1。官網下載iso,一個linux dvd是穩定版,選之,另一個stream版是更新更快的測試版,裡面軟體更新。 https://www.centos.org/download/ 2。刻u盤,用Wi ...
  • 問題說明(環境:windows7,MySql8.0) 今天安裝好MySql後啟動MySql服務 啟動服務都失敗的就不要往下看了,自行百度解決。 打開客戶端秒退,但在cmd中是可以使用資料庫的。 正常來說只要能用就好了,但客戶端方便,就不想敲那一行代碼。就在網上找,百度,google,各種方法都試了。 ...
一周排行
  • 枚舉是 C 中最有意思的一部分,大部分開發人員只瞭解其中的一小部分,甚至網上絕大多數的教程也只講解了枚舉的一部分。那麼,我將通過這篇文章向大傢具體講解一下枚舉的知識。我將從大家都瞭解的部分開始講解,然後再講解大家所不知道的或者瞭解很少的部分。 零、基礎知識 枚舉是由開發人員聲明的一種 值類型 ,它在 ...
  • 一. elasticsearch on windows 1.下載地址: https://www.elastic.co/cn/downloads/elasticsearch 如果瀏覽器下載文件慢,建議使用迅雷下載,速度很快。下載版本為7.5.2 2. 修改配置文件 下載後解壓,找到config\jvm ...
  • 最近因為” 新冠” 疫情在家辦公,學習了 ASP.NET Core MVC 網站的一些知識,記錄如下。 ...
  • Regex.Replace("<!--(.|[\r\n])*?-->",string.Empty) ...
  • 本筆記摘抄自:https://www.cnblogs.com/PatrickLiu/p/7743118.html,記錄一下學習過程以備後續查用。 一、引言 今天我們要講結構型設計模式的第四個模式--組合模式。當我們談到這個模式的時候,有一個物件和這個模式很像,那就是“俄羅斯套娃”。“俄羅斯套娃”是 ...
  • 一、前言 Entity Framework(後面簡稱EF)作為微軟家的ORM,自然而然從.NET Framework延續到了.NET Core。 二、程式包管理器控制台 為了能夠在控制臺中使用命令行來操作EF,需要先安裝Microsoft.EntityFrameworkCore.Tools。 安裝 ...
  • 項目gitHub地址 點我跳轉 今天給大家帶來一個C#裡面的時間工具類,具體的直接看下麵代碼 1 using System; 2 3 namespace ToolBox.DateTimeTool 4 { 5 public static class DateTimeExtend 6 { 7 /// < ...
  • 《C# 6.0 本質論》 [作者] (美) Mark Michaelis (美) Eric Lippert[譯者] (中) 周靖 龐燕[出版] 人民郵電出版社[版次] 2017年02月 第5版[印次] 2017年02月 第1次 印刷[定價] 108.00元 【前言】 成功學習 C# 的關鍵在於,要盡 ...
  • 本筆記摘抄自:https://www.cnblogs.com/PatrickLiu/p/7772184.html,記錄一下學習過程以備後續查用。 一、引言 今天我們要講結構型設計模式的第五個模式--外觀模式。先從名字上來理解一下外觀模式,當看到“外觀”這個詞時,很容易想到“外表”這個詞語,兩者有著 ...
  • 在 C 中存在一個名叫靜態類型檢查的機制,這個機制可以讓編譯器幫助我們把類型不服的用法找出來,從而使得應用程式在運行期間加少一些類型檢查的操作。但是有時候我們還是需要進行運行期類型檢查,比如我們在設計框架時將方法的參數類型定義為 object ,那麼這時我們就有很大的可能需要將 object 類型的 ...
x