Voy a mostrar un ejemplo de cómo personalizar un loader para que aparezca en el momento que necesitemos cargar datos en nuestra aplicación.
data:image/s3,"s3://crabby-images/36859/36859cc5eabde3034a73cd8413761cef7a371b4f" alt=""
El elemento loader es el siguiente.
class Loader extends StatelessWidget { @override Widget build(BuildContext context) { return Center( child: Container( padding: EdgeInsets.all(16.0), decoration: BoxDecoration( color: Colors.white, borderRadius: BorderRadius.circular(10.0), boxShadow: [ BoxShadow( color: Colors.black.withOpacity(0.1), blurRadius: 10.0, offset: Offset(0, 5), ), ], ), child: Column( mainAxisSize: MainAxisSize.min, children: [ CircularProgressIndicator( valueColor: AlwaysStoppedAnimation<Color>(Colors.purple), backgroundColor: Colors.teal, strokeWidth: 4, ), SizedBox(height: 16.0), Text( 'Cargando...', style: TextStyle( fontSize: 16.0, fontWeight: FontWeight.bold, ), ), ], ), ), ); } }
Para customizar los colores y la anchura del elemento loader, debemos centrarnos en la siguiente parte del código.
CircularProgressIndicator( valueColor: AlwaysStoppedAnimation<Color>(Colors.purple), backgroundColor: Colors.teal, strokeWidth: 4, ),
A continuación muestro el código completo.
import 'package:flutter/material.dart'; void main() { runApp(MyApp()); } class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( title: 'Demo para DevCodeLight', theme: ThemeData( primarySwatch: Colors.blue, ), home: HomePage(), ); } } class HomePage extends StatelessWidget { void fetchData() async { await Future.delayed(Duration(seconds: 2)); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('Demo para DevCodeLight'), ), body: Center( child: ElevatedButton( onPressed: () { showDialog( context: context, barrierDismissible: false, builder: (BuildContext context) { return Dialog( backgroundColor: Colors.transparent, elevation: 0, child: Loader(), ); }, ); Future.delayed(Duration(seconds: 2), () { Navigator.pop( context); // Cerrar el diálogo del loader después de 2 segundos (simulación) }); }, child: Text('Cargar Datos'), ), ), ); } } class Loader extends StatelessWidget { @override Widget build(BuildContext context) { return Center( child: Container( padding: EdgeInsets.all(16.0), decoration: BoxDecoration( color: Colors.white, borderRadius: BorderRadius.circular(10.0), boxShadow: [ BoxShadow( color: Colors.black.withOpacity(0.1), blurRadius: 10.0, offset: Offset(0, 5), ), ], ), child: Column( mainAxisSize: MainAxisSize.min, children: [ CircularProgressIndicator( valueColor: AlwaysStoppedAnimation<Color>(Colors.purple), backgroundColor: Colors.teal, strokeWidth: 4, ), SizedBox(height: 16.0), Text( 'Cargando...', style: TextStyle( fontSize: 16.0, fontWeight: FontWeight.bold, ), ), ], ), ), ); } }
Espero que les sirva de ayuda, feliz día!
data:image/s3,"s3://crabby-images/6e5a1/6e5a14886c47c56837da7e72e9c853e772efe4be" alt=""