flutter - 如何显示用户图像?
问题描述
我显示用户个人资料图片,我有 3 个可以显示的选项。第一个是当前拾取的图像,它是从相机或库中拾取的,如果有图像,它将被显示。然后用户可以保护它,以便在用户重新启动应用程序时也会显示它,在这种情况下我会显示保存的图像。然后是我的第三个选项,如果没有保存图片并且目前没有选择图片,那么我将显示默认图像,这在我的资产中。这是我的问题,我该怎么做,因为这个默认图片也会显示,如果用户删除当前保存的图片,所以如果他改回“没有拍照”,那么默认图片将再次显示。
Container(
child: Center(
child:
CircleAvatar(
radius: 70,
foregroundImage: _pickedImage!=null? FileImage(_pickedImage): NetworkImage ( userData.url),
),
),
decoration: new BoxDecoration(
shape: BoxShape.circle,
这是我的方法:
onPressed: () async {
if (_formKey.currentState.validate()) {
final ref= FirebaseStorage.instance.ref().child('user_profile_pictures').child(user.uid+'.jpg');
await ref.putFile(_pickedImage);
final url = await ref.getDownloadURL();
_curenturl= url;
String authError =
await DatbaseService(uid: user.uid).updateUserData(
_currentusername ?? userData.user,
_currentfullname ?? userData.fullname,
_currentemail ?? userData.email,
_currentpassword ?? userData.password,
_curenturl ??userData.url,
);
if (authError != null) {
这是我将当前 url 设置为 null 以及 userData.url 的按下方法
onTap: () {
DatbaseService(uid: user.uid).updateUserData(
_currentusername ?? userData.user,
_currentfullname ?? userData.fullname,
_currentemail ?? userData.email,
_currentpassword ?? userData.password,
_curenturl =null,
);
Navigator.pop(context);
},
因此,您可以看到我再次将 url 设置为 null。即时通讯这样做是为了不再有保存的图片。然后我想显示我的资产中的默认图像。我试图用那张图片更新我当前的 url,但 url 是一个字符串,我的图片是一个资产图像。
解决方案
你可以试试我的代码:
ClipRRect(
borderRadius: BorderRadius.circular(60),
child: Container(
height: 100,
width: 100,
decoration: BoxDecoration(
color: Colors.grey.shade300,
),
child: image != null
? Image.file(
image,
fit: BoxFit.cover,
)
: networkImg != null && networkImg != ''
? Image.network(
networkImg,
fit: BoxFit.cover,
)
: Image.asset(
// Your image path is here when image is no available.
),
),
),
请让我知道它是否有效。
推荐阅读
- angular - ngmodule 不是子类型 ngmoduletype
- linux - Git不使用user.name
- python - Gunicorn 工作人员在长时间 API 调用后自行重启
- asp.net-core - mvc和api授权中间件的区别
- python-3.x - 如何将 askdirectory 中的值插入条目?Python3
- laravel - 模型绑定不检索模型数据
- r - 在给定点之后将列的值设置为 NA
- gitlab-ci - 在合并到 master 时运行 Gitlab CI 作业,仅用于更改
- python - 矩阵数学 - 最大化
- typescript - TypeScript 静态成员返回相同的类实例?