图片

从项目中加载图片

如果图片是存放于项目之中, 需要先在 pubspec.yaml 中的flutter部分添加如下内容:

flutter:
  assets:
    - assets/imgs/avatar.png

其中 assets 是位于项目根目录而不是 lib 文件夹

使用的时候:

Image(
  image: AssetImage("assets/imgs/avatar.png"),
  width: 60,
  height: 60,
);
// 或:
Image.asset("assets/imgs/avatar.png", width: 60, height: 60,)

加载网络图片

Image(
  image: NetworkImage(
      "https://avatars1.githubusercontent.com/u/13745132?s=460&v=4"),
  width: 100.0,
)
// 或:
Image.network(
  "https://avatars1.githubusercontent.com/u/13745132?s=460&v=4",
  width: 100.0,
)

如果只设置width、height的其中一个,那么另一个属性默认会按比例缩放

Image

Image的定义:

const Image({
  ...
  this.width, //图片的宽
  this.height, //图片高度
  this.color, //图片的混合色值
  this.colorBlendMode, //混合模式
  this.fit,//缩放模式
  this.alignment = Alignment.center, //对齐方式
  this.repeat = ImageRepeat.noRepeat, //重复方式
  ...
})

fit

该属性用于在图片的显示空间和图片本身大小不同时指定图片的适应模式。适应模式是在BoxFit中定义,它是一个枚举类型,有如下值可选:

  • fill:会拉伸填充满显示空间,图片本身长宽比会发生变化,图片会变形。
  • cover:会按图片的长宽比放大后居中填满显示空间,图片不会变形,超出显示空间部分会被剪裁。
  • contain:这是图片的默认适应规则,图片会在保证图片本身长宽比不变的情况下缩放以适应当前显示空间,图片不会变形。
  • fitWidth:图片的宽度会缩放到显示空间的宽度,高度会按比例缩放,然后居中显示,图片不会变形,超出显示空间部分会被剪裁。
  • fitHeight:图片的高度会缩放到显示空间的高度,宽度会按比例缩放,然后居中显示,图片不会变形,超出显示空间部分会被剪裁。
  • none:图片没有适应策略,会在显示空间内显示图片,如果图片比显示空间大,则显示空间只会显示图片中间部分。

color 和 colorBlendMode

在图片绘制时可以对每一个像素进行颜色混合处理,color指定混合色,而colorBlendMode指定混合模式, 示例:

Image(
  image: AssetImage("images/avatar.png"),
  width: 100.0,
  color: Colors.blue,
  colorBlendMode: BlendMode.difference,
);

repeat

当图片本身大小小于显示空间时,指定图片的重复规则。

  • ImageRepeat.noRepeat 默认
  • ImageRepeat.repeat
  • ImageRepeat.repeatX
  • ImageRepeat.repeatY

MIT Licensed | Copyright © 2018-present 滇ICP备16006294号

Design by Quanzaiyu | Power by VuePress