點燈坊

戦わなければ、勝てない

ElavatedButton 設定背景漸層色

Sam Xiao's Avatar 2024-10-22

ElavatedButton 亦可設定成背景為 漸層色,但必須搭配 ContainerBoxDecoration 才能實現。

Version

Flutter 3.24

Flutter

gradient01

  • Android 與 iOS 都成功使用 ElavatedButton 搭背背景竟層色

ElavatedButton

import 'package:flutter/material.dart';

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

  
  Widget build(BuildContext context) {
    var appBar = AppBar(
      title: const Text('ElevatedButton'),
    );

    var elevatedButton = Container(
      decoration: BoxDecoration(
        gradient: const LinearGradient(
          begin: Alignment(1, 0),
          end: Alignment(-1.00, 0.00),
          colors: [Color(0xFF359AD2), Color(0xFF7FB6DE)],
        ),
        borderRadius: BorderRadius.circular(8),
      ),
      child: ElevatedButton(
        onPressed: () {
          ScaffoldMessenger.of(context).showSnackBar(
            const SnackBar(
              content: Text('ElevatedButton Pressed!'),
            ),
          );
        },
        style: ElevatedButton.styleFrom(
          backgroundColor: Colors.transparent,
          shadowColor: Colors.transparent,
          padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 12),
        ),
        child: const Text(
          'Press Me',
          style: TextStyle(fontSize: 18, color: Colors.white),
        ),
      ),
    );

    var body = Center(
      child: elevatedButton,
    );

    return Scaffold(
      appBar: appBar,
      body: body,
    );
  }
}

Line 12

var elevatedButton = Container(
  decoration: BoxDecoration(
    gradient: const LinearGradient(
      begin: Alignment(1, 0),
      end: Alignment(-1.00, 0.00),
      colors: [Color(0xFF359AD2), Color(0xFF7FB6DE)],
    ),
    borderRadius: BorderRadius.circular(8),
  ),
  child: ElevatedButton(
  )
);  
  • Container:無法由 style 直接將 ElavatedButton 的背景設定為漸層色,必須在外層包一層 Container,並由 decoration 設定漸層色
    • decoration:由 BoxDecoration 內的 gradient 設定漸層色
    • borderRadius:亦可在 BoxDecoration 內設定圓角

Line 29

style: ElevatedButton.styleFrom(
  backgroundColor: Colors.transparent,
  shadowColor: Colors.transparent,
  padding: const EdgeInsets.symmetric(horizontal: 24, vertical: 12),
),
  • style:由 ElevatedButton.styleFrom() 設定 ElavatedButton 的 style
    • backgroundColor:由於背景顏色已經被 Container 接管,因此必須將 ElavatedButton 自己的 background 設定為 transparent ,否則會影響到 Container 所設定的漸層
    • shadowColor:也要設定成 transparent,否則會影響到 Container 所設定的漸層
    • padding:設定內部 padding

Conclusion

  • 無法直接在 ElavatedButton 設定背景漸層色,必須在外層搭配 Container ,在 BoxDecoration 設定 LinearGradient
  • 由於 背景顏色 已經被外層的 Container 接管,必須將原本 ElavatedButton 自己 style 的 backgroundColorshadowColor 都設定成 transparent,否則會影響 BoxDecoration 的漸層色