Solucionado (ver solução)
Solucionado
(ver solução)
1
resposta

[Dúvida] Alguém poderia me dizer qual seria a melhor forma de implementar a decoração nesse código?

import 'package:flutter/material.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.blue),
        useMaterial3: true,
      ),
      home: MyAppBar(),
    );
  }
}

class MyAppBar extends StatelessWidget {
  const MyAppBar({super.key});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Colors.redAccent,
        foregroundColor: Colors.white,
        title: const Text(
          'Flutter: Exercício',
          style: TextStyle(fontSize: 24),
        ),
        actions: <Widget>[
          IconButton(
            icon: const Icon(
              Icons.add,
              size: 30,
            ),
            onPressed: () {
              ScaffoldMessenger.of(context).showSnackBar(const SnackBar(
                  backgroundColor: Colors.red,
                  content: Text('Essa função ainda não está dísponivel :)',
                      style: TextStyle(fontSize: 18, color: Colors.white))));
            },
          ),
        ],
      ),
      body: Container(
        color: Color.fromARGB(255, 210, 220, 236),
        child: ListView(
          children: [
            Blocks(
                cor1: Colors.white,
                cor2: Colors.pinkAccent,
                cor3: Colors.lightBlueAccent),
            Blocks(
                cor1: Colors.pink,
                cor2: Colors.purple,
                cor3: Colors.purpleAccent),
            Blocks(
                cor1: Colors.pinkAccent,
                cor2: Colors.amber,
                cor3: Colors.lightBlue),
            Blocks(
                cor1: Colors.purpleAccent,
                cor2: Colors.white,
                cor3: Colors.green),
            Blocks(
                cor1: Colors.amberAccent,
                cor2: Colors.deepPurple,
                cor3: Colors.orangeAccent),
            Blocks(cor1: Colors.green, cor2: Colors.white, cor3: Colors.red),
          ],
        ),
      ),
    );
  }
}

class Blocks extends StatelessWidget {
  final Color cor1;
  final Color cor2;
  final Color cor3;

  const Blocks(
      {required this.cor1, required this.cor2, required this.cor3, super.key});

  @override
  Widget build(BuildContext context) {
    return Padding(
      padding: const EdgeInsets.all(8.0),
      child: Row(
        children: [
          Blocks2(cor1),
          Blocks2(cor2),
          Blocks2(cor3),
        ],
      ),
    );
  }
}

class Blocks2 extends StatelessWidget {
  final Color cor;

  const Blocks2(this.cor, {super.key});

  @override
  Widget build(BuildContext context) {
    return Container(
      width: 80,
      height: 120,
      color: cor,
    );
  }
}
1 resposta
solução!

Olá, Micael!

Para implementar a decoração no código que você compartilhou, você pode utilizar o widget Container e definir as propriedades desejadas, como bordas e cores. Por exemplo, você pode adicionar uma borda preta e arredondada ao redor dos blocos de cores no widget Blocks2. Veja como ficaria:

class Blocks2 extends StatelessWidget {
  final Color cor;

  const Blocks2(this.cor, {Key? key});

  @override
  Widget build(BuildContext context) {
    return Container(
      width: 80,
      height: 120,
      decoration: BoxDecoration(
        color: cor,
        border: Border.all(
          color: Colors.black,
          width: 2,
        ),
        borderRadius: BorderRadius.circular(10),
      ),
    );
  }
}

Dessa forma, cada bloco de cor terá uma borda preta e arredondada ao redor. Você pode ajustar as propriedades de acordo com suas preferências.

Espero ter ajudado e bons estudos!