【Flutter】圖片及ICON(二)

一艘绍、圖片

圖片類似UIImageView,在Flutter中兩種方式加載圖片诱鞠,本地與網(wǎng)絡(luò)。

1. 從asset即本地加載圖片

  • 在工程根目錄下創(chuàng)建一個(gè)images目錄蕉朵,并將所需要的圖片xxx.png拷貝到該目錄阳掐。

  • 在pubspec.yaml中的flutter部分添加如下內(nèi)容(默認(rèn)此文件下面會(huì)有注釋,只需要將圖片相關(guān)的注釋打開即可)如下:

  assets:
  - images/xxx.png
  - images/xxxx.png

注意這里有個(gè)坑: 由于 yaml 文件對(duì)縮進(jìn)嚴(yán)格觅闽,所以必須嚴(yán)格按照每一層兩個(gè)空格的方式進(jìn)行縮進(jìn)蛉拙,此處assets前面應(yīng)有兩個(gè)空格彻亲。否則圖片不能正常的顯示

2.從網(wǎng)絡(luò)加載圖片

  • 使用構(gòu)造函數(shù) Image.network 從網(wǎng)絡(luò)加載、顯示圖片
相關(guān)圖片的類官方簡(jiǎn)介
Image

Image widget有一個(gè)必選的image參數(shù)苞尝,它對(duì)應(yīng)一個(gè)ImageProvider宙址。

ImageProvider

ImageProvider 是一個(gè)抽象類,主要定義了圖片數(shù)據(jù)獲取的接口load()大咱,從不同>的數(shù)據(jù)源獲取圖片需要實(shí)現(xiàn)不同的ImageProvider 注益,如AssetImage是實(shí)現(xiàn)了從>Asset中加載圖片的ImageProvider,而NetworkImage實(shí)現(xiàn)了從網(wǎng)絡(luò)加載圖片的ImageProvider厦瓢。

            Image(
             image: AssetImage('images/1.jpeg'),
              width: 300.0,
              height: 200.0,
            ),

            Image(
              image: NetworkImage(
                 'https://ss0.bdstatic.com/70cFuHSh_Q1YnxGkpoWK1HF6hhy/it/u=2153937626,1074119156&fm=27&gp=0.jpg'),
              width: 200.0,
              height: 200.0,
            ),
運(yùn)行效果
參數(shù)

Image的主要常用參數(shù)如下煮仇,可自行嘗試:

const Image({
  ...
  this.width, //圖片的寬
  this.height, //圖片高度
  this.color, //圖片的混合色值
  this.colorBlendMode, //混合模式
  this.fit,//縮放模式
  this.alignment = Alignment.center, //對(duì)齊方式
  this.repeat = ImageRepeat.noRepeat, //重復(fù)方式
  ...
})

這里引用一張官方的關(guān)于fit的參數(shù)的圖顽冶,比較直觀


fit不同顯示樣式.png




二、ICON

Flutter中绞呈,icon是將圖標(biāo)做成字體文件间景,然后通過指定不同的字符而顯示不同的圖片。在字體文件中圾亏,每一個(gè)字符都對(duì)應(yīng)一個(gè)位碼,而每一個(gè)位碼對(duì)應(yīng)一個(gè)顯示字形夭问,不同的字體就是指字形不同曹铃,即字符對(duì)應(yīng)的字形是不同的。

簡(jiǎn)單的說陕见,將這些圖標(biāo)當(dāng)做文字一樣去使用评甜。

在Flutter開發(fā)中,iconfont和圖片相比有如下優(yōu)勢(shì):

  1. 體積腥炭馈:可以減小安裝包大小佩研。
  2. 矢量的:iconfont都是矢量圖標(biāo),放大不會(huì)影響其清晰度嘉抒。
  3. 可以應(yīng)用文本樣式:可以像文本一樣改變字體圖標(biāo)的顏色袍暴、大小對(duì)齊等。
  4. 可以通過TextSpan和文本混用政模。
使用Material Design字體圖標(biāo)

pubspec.yaml文件中,Flutter默認(rèn)包含了一套Material Design的字體圖標(biāo)淋样,配置如下,Material Design所有圖標(biāo)可以在其官網(wǎng)查看:https://material.io/tools/icons/

flutter:
  uses-material-design: true

我們看一個(gè)簡(jiǎn)單的例子:

String icons = "";
icons += "\uE914";
icons += " \uE000";
icons += " \uE90D";

Text(icons,
  style: TextStyle(
      fontFamily: "MaterialIcons",
      fontSize: 24.0,
      color: Colors.green
  ),
);

運(yùn)行效果,跟文字沒啥兩樣

上面的如\uE000一樣的不知符號(hào)并不友好刊咳,所以儡司,F(xiàn)lutter封裝了一個(gè)IconDataIcon來專門顯示字體圖標(biāo),(在開發(fā)的時(shí)候會(huì)有提示),更改代碼如下:

Row(
  mainAxisAlignment: MainAxisAlignment.center,
  children: <Widget>[
    Icon(Icons.accessible,color: Colors.green,),
    Icon(Icons.error,color: Colors.green,),
    Icon(Icons.fingerprint,color: Colors.green,),
  ],
)

使用自定義字體圖標(biāo)

如果默認(rèn)的不能滿足捕犬,我們也可以使用自定義字體圖標(biāo)酵镜。iconfont.cn上有很多字體圖標(biāo)素材柴钻,步驟也很簡(jiǎn)單贴届,這里不再重復(fù),可參考https://book.flutterchina.club/chapter3/img_and_icon.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市斩跌,隨后出現(xiàn)的幾起案子耀鸦,更是在濱河造成了極大的恐慌,老刑警劉巖袖订,帶你破解...
    沈念sama閱讀 216,651評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洛姑,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡参咙,警方通過查閱死者的電腦和手機(jī)硫眯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,468評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來净宵,“玉大人裹纳,你說我怎么就攤上這事〉蟀叮” “怎么了她我?”我有些...
    開封第一講書人閱讀 162,931評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)酝碳。 經(jīng)常有香客問我,道長(zhǎng)呛讲,這世上最難降的妖魔是什么返奉? 我笑而不...
    開封第一講書人閱讀 58,218評(píng)論 1 292
  • 正文 為了忘掉前任芽偏,我火速辦了婚禮,結(jié)果婚禮上污尉,老公的妹妹穿的比我還像新娘。我一直安慰自己某宪,他們只是感情好锐朴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,234評(píng)論 6 388
  • 文/花漫 我一把揭開白布焚志。 她就那樣靜靜地躺著,像睡著了一般娩嚼。 火紅的嫁衣襯著肌膚如雪岳悟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,198評(píng)論 1 299
  • 那天呵俏,我揣著相機(jī)與錄音滔灶,去河邊找鬼。 笑死录平,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的动猬。 我是一名探鬼主播,決...
    沈念sama閱讀 40,084評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼彼水!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起链瓦,我...
    開封第一講書人閱讀 38,926評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤叛赚,失蹤者是張志新(化名)和其女友劉穎稽揭,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體事镣,經(jīng)...
    沈念sama閱讀 45,341評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡璃哟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,563評(píng)論 2 333
  • 正文 我和宋清朗相戀三年喊递,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片铐伴。...
    茶點(diǎn)故事閱讀 39,731評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡当宴,死狀恐怖泽疆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情殉疼,我是刑警寧澤捌年,帶...
    沈念sama閱讀 35,430評(píng)論 5 343
  • 正文 年R本政府宣布延窜,位于F島的核電站抹锄,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏获高。R本人自食惡果不足惜吻育,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,036評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望摊趾。 院中可真熱鬧游两,春花似錦、人聲如沸肛炮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,676評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽秕重。三九已至厉膀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間站蝠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,829評(píng)論 1 269
  • 我被黑心中介騙來泰國打工留荔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留聚蝶,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,743評(píng)論 2 368
  • 正文 我出身青樓巷挥,卻偏偏與公主長(zhǎng)得像验靡,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子胜嗓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,629評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容