Flutter Image图片组件讲解
	
	Flutter中,我们可以通过 Image 组件来加载并显示图片 Image 的数据源可以是asset、文件、内存以及网络。
	
      构造方法
Image: 从ImageProvider获取数据
Image.network: 加载网络图片。
Image.asset: 加载本地图片文件。
new Image.file: 加载本地图片文件(File文件)图片。
new Image.memory: 加载Uint8List资源图片(byte数组)图片。
Image 组件的常用属性:
| 名称 | 类型 | 说明 | 
|---|
| alignment | Alignment | 图片的对齐方式 | 
| color 和 colorBlendMode |  | 设置图片的背景颜色,通常和 colorBlendMode 配合一起使用,这样可以是图片颜色和背景色混合 | 
| fit | BoxFit | 用来控制图片的拉伸和挤压,这都是根据父容器来的。BoxFit.fill:全图显示,图片会被拉伸并充满父容器;BoxFit.contain:全图显示,显示原比例,可能会有空隙;BoxFit.cover(最常用):显示可能拉伸或裁切,图片会充满整个容器,但不变形;BoxFit.fitWidth:横向充满,显示可能拉伸或裁切;BoxFit.fitHeight:纵向充满,显示可能拉伸或裁切;BoxFit.saleDown:效果和 contain 差不多,但是此属性不允许显示超过原图片大小 | 
| repeat | 平铺 | ImageRepeat.repeat:横向和纵向都进行重复,直到铺满整个画布;ImageRepeat.repeatX:横向重复;ImageRepeat.repeatY:纵向重复 | 
| width |  | 宽度,一般结合 ClipOval 才能看到效果 | 
| height |  | 高度,一般结合 ClipOval 才能看到效果 | 
加载远程图片
		
			
				
import 'package:flutter/material.dart';
void main() {
  runApp(MaterialApp(
    home: Scaffold(
        appBar: AppBar(title: const Text("加载远程图片")), body: const MyApp()),
  ));
}
class MyApp extends StatelessWidget {
  const MyApp({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Container(
        width: 300,
        height: 160,
        decoration: const BoxDecoration(color: Colors.lightBlue),
        child: Image.network(
          "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/a721aa24-c1f8-4988-b6f8-73f8edaef42b.png",
          fit: BoxFit.cover,
        ),
      ),
    );
  }
}
				 
			 
		 
	 
 
Container实现圆形图片
圆形图片在实际中很常用,比如我们的头像
		
			
				
import 'package:flutter/material.dart';
void main() {
  runApp(MaterialApp(
    home: Scaffold(
        appBar: AppBar(title: const Text("Container实现圆形图片")),
        body: const MyApp()),
  ));
}
class MyApp extends StatelessWidget {
  const MyApp({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Container(
        width: 200,
        height: 200,
        decoration: BoxDecoration(
            color: Colors.lightBlue,
            borderRadius: BorderRadius.circular(100),
            image: const DecorationImage(
                //使用远程图片
                image: NetworkImage(
                  "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/a721aa24-c1f8-4988-b6f8-73f8edaef42b.png",
                ),
                fit: BoxFit.cover)),
      ),
    );
  }
}
				 
			 
		 
	 
 
ClipOval实现圆形图片
在 Flutter 中,ClipOval 是一个用于将子组件剪裁为椭圆形的组件。通过 ClipOval,你可以将任意形状的子组件剪裁为椭圆形,从而创建椭圆形的视觉效果。
ClipOval 组件非常适合用于展示圆形或椭圆形的内容,比如头像、图标等。它可以让你在布局中轻松地实现各种椭圆形的视图。
		
			
				
import 'package:flutter/material.dart';
void main() {
  runApp(MaterialApp(
      home: Scaffold(
          appBar: AppBar(title: const Text("圆形图片")),
          //Column: 垂直排列子组件的布局组件
          body: const Column(children: [
            MyApp(),
            //用一个盒子来隔开两张图片
            SizedBox(
              height: 20,
            ),
            ClipOvalImage()
          ]))));
}
//Container实现圆形图片
class MyApp extends StatelessWidget {
  const MyApp({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Container(
        width: 200,
        height: 200,
        decoration: BoxDecoration(
            color: Colors.lightBlue,
            borderRadius: BorderRadius.circular(100),
            image: const DecorationImage(
                //使用远程图片
                image: NetworkImage(
                  "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/a721aa24-c1f8-4988-b6f8-73f8edaef42b.png",
                ),
                fit: BoxFit.cover)),
      ),
    );
  }
}
//ClipOval实现圆形图片
class ClipOvalImage extends StatelessWidget {
  const ClipOvalImage({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
        child: ClipOval(
      child: Image.network(
        "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/512aff8e-8374-4740-879a-74b617f2cb6c.jpg",
        width: 200,
        height: 200,
        fit: BoxFit.cover,
      ),
    ));
  }
}
				 
			 
		 
	 
 
CircleAvatar实现圆形图片
在 Flutter 中,CircleAvatar 是一个用于显示圆形头像的组件。它提供了一个简单而方便的方式来展示用户头像或者其他圆形图片。
CircleAvatar 组件自带了一些常见的样式设置,例如背景颜色、边框宽度和颜色等,同时也可以很容易地指定头像的来源,比如网络图片、本地图片或者图标。
基本上,CircleAvatar 不提供设置边框的属性。但是,可以将其包裹在具有更大半径和不同背景颜色的不同 CircleAvatar 中,以创建类似于边框的内容。
		
			
				
import 'package:flutter/material.dart';
void main() {
  runApp(MaterialApp(
      home: Scaffold(
          appBar: AppBar(title: const Text("圆形图片")),
          //Column: 垂直排列子组件的布局组件
          body: const Column(children: [
            MyApp(),
            //用一个盒子来隔开两张图片
            SizedBox(height: 20),
            ClipOvalImage(),
            SizedBox(height: 20),
            CircleAvatarImage()
          ]))));
}
//Container实现圆形图片
class MyApp extends StatelessWidget {
  const MyApp({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Container(
        width: 200,
        height: 200,
        decoration: BoxDecoration(
            color: Colors.lightBlue,
            borderRadius: BorderRadius.circular(100),
            image: const DecorationImage(
                //使用远程图片
                image: NetworkImage(
                  "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/a721aa24-c1f8-4988-b6f8-73f8edaef42b.png",
                ),
                fit: BoxFit.cover)),
      ),
    );
  }
}
//ClipOval实现圆形图片
class ClipOvalImage extends StatelessWidget {
  const ClipOvalImage({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
        child: ClipOval(
      child: Image.network(
        "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/512aff8e-8374-4740-879a-74b617f2cb6c.jpg",
        width: 200,
        height: 200,
        fit: BoxFit.cover,
      ),
    ));
  }
}
//CircleAvatar实现圆形图片
class CircleAvatarImage extends StatelessWidget {
  const CircleAvatarImage({super.key});
  @override
  Widget build(BuildContext context) {
    return const CircleAvatar(
        radius: 105,
        backgroundColor: Colors.lightBlue,
        child: CircleAvatar(
          radius: 100,
          backgroundImage: NetworkImage(
              "https://xixi-web-tlias.oss-cn-guangzhou.aliyuncs.com/20240326135455.jpg"),
        ));
  }
}
				 
			 
		 
	 
 
加载本地图片
1、项目根目录新建 images 文件夹,在 images 中新建 2.0x、3.0x 对应的文件夹,然后将一张图片分别放进这三个文件夹中:

2、打开 pubspec.yaml,找到声明本地图片的地方,声明一下添加的图片文件, 注意格式

3、使用本地图片
		
			
				
import 'package:flutter/material.dart';
void main() {
  runApp(MaterialApp(
      home: Scaffold(
    appBar: AppBar(title: const Text("加载本地图片")),
    body: const MyApp(),
  )));
}
class MyApp extends StatelessWidget {
  const MyApp({super.key});
  @override
  Widget build(BuildContext context) {
    return Center(
      child: CircleAvatar(
        radius: 150,
        backgroundColor: Colors.white,
        backgroundImage: const AssetImage('images/1.jpeg'),
        foregroundColor: Colors.blue,
        child: Container(
          decoration: BoxDecoration(
            shape: BoxShape.circle,
            border: Border.all(color: Colors.blue, width: 3),
            boxShadow: [
              BoxShadow(
                color: Colors.blue.withOpacity(0.3),
                spreadRadius: 5,
                blurRadius: 7,
                offset: const Offset(0, 3),
              ),
            ],
          ),
        ),
      ),
    );
  }
}