flutter - How to make a raised button that has a gradient background?

后端 未结 10 1690
野性不改
野性不改 2021-01-31 14:52

Is there a way to change the raised button background color to a gradient? if not, how can I achieve something like this?

相关标签:
10条回答
  • 2021-01-31 15:33

    I know this question is a bit old.. But I've found myself with this requirement and I wanted to share my solution. It uses a Card and animates the elevation when the button is pressed.

    import 'package:flutter/material.dart';
    
    class GradientButton extends StatefulWidget {
      final String label;
      final VoidCallback onPressed;
      final Gradient gradient;
      final double elevation;
      final double height;
      final TextStyle labelStyle;
    
      GradientButton({
        @required this.label,
        @required this.onPressed,
        @required this.gradient,
        this.elevation,
        this.height,
        this.labelStyle,
      })  : assert(label != null && onPressed != null),
            assert(gradient != null);
    
      @override
      _GradientButtonState createState() => _GradientButtonState();
    }
    
    class _GradientButtonState extends State<GradientButton> with TickerProviderStateMixin {
      AnimationController _animationController;
      Animation _animation;
    
      elevateUp(TapDownDetails details) {
        _animationController.forward();
      }
    
      elevateDown() {
        _animationController.reverse();
      }
    
      @override
      void initState() {
        super.initState();
        _animationController = AnimationController(duration: Duration(milliseconds: 50), vsync: this);
        _animation = Tween(begin: widget.elevation ?? 2.0, end: 12.0).animate(_animationController);
      }
    
      @override
      Widget build(BuildContext context) {
        return AnimatedBuilder(
          animation: _animation,
          builder: (c, w) {
            return GestureDetector(
              onTapDown: elevateUp,
              onTapCancel: elevateDown,
              onTapUp: (value) {
                elevateDown();
                widget.onPressed();
              },
              child: Card(
                elevation: _animation.value,
                shape: RoundedRectangleBorder(
                  borderRadius: BorderRadius.circular(25.0),
                ),
                child: Container(
                  width: double.infinity,
                  height: widget.height ?? 50.0,
                  decoration: BoxDecoration(
                    gradient: widget.gradient,
                    borderRadius: BorderRadius.circular(25.0),
                  ),
                  child: Center(
                    child: Text(
                      widget.label,
                      style: widget.labelStyle ?? Theme.of(context).textTheme.button,
                    ),
                  ),
                ),
              ),
            );
          },
        );
      }
    }
    

    There's room for improving it (maybe you don't want those rounded borders by default), but hope can be useful for some of you :D

    0 讨论(0)
  • 2021-01-31 15:38

    Gradient package is available at pub store which supports few predefined gradients

    You can create the gradient button as

    GradientButton(
                     child: Text('Gradient'),
                     callback: () {},
                     gradient: Gradients.backToFuture,
               ),
    

    The package have GradientCard, GradientProgressIndicator, GradientButton, CircularGradientButton and the GradientText

    Gradient Widgets

    0 讨论(0)
  • 2021-01-31 15:38

    You can use a more easier way by using RawMaterialButton from material.dart , you can make it's shape as rounded or circle too . here is a simple example of this .

      Card(
        elevation: 7,
        child: Container(
          width: 120.0,
          height: 75.0,
          decoration: BoxDecoration(
            gradient: LinearGradient(
              begin: Alignment.bottomLeft,
              end: Alignment.topRight,
              colors: <Color>[
                Colors.blue,
                Colors.red,
              ],
            ),
          ),
          child: RawMaterialButton(
            onPressed: () {},
            splashColor: Colors.grey,
            child: Text(
              "Button",
              style: TextStyle(color: Colors.white, fontSize: 20.0),
            ),
          ),
        ),
      ),
    
    0 讨论(0)
  • 2021-01-31 15:41

    Simply make one more container as a child set the decoration of that container and make gradient color as you want

    Then after this use RaisedButton as the child of the above container same as with MaterialButton also

       child: Container(
          decoration: BoxDecoration(
            gradient: LinearGradient(
                colors: [Colors.red, Colors.blue],
                begin: FractionalOffset(0.0, 0.0),
                end: FractionalOffset(0.5, 0.0),
                stops: [0.0, 1.0],
                tileMode: TileMode.clamp),
          ),
          child: RaisedButton(
            color: Colors.transparent,
            child: Text("Ask Permssion"),
            onPressed: () {
              askPermission();
            },
          )),
    

    Output:

    0 讨论(0)
  • 2021-01-31 15:42

    Docs last example https://api.flutter.dev/flutter/material/RaisedButton-class.html

    RaisedButton(
      onPressed: () {},
      textColor: Colors.white,
      padding: const EdgeInsets.all(0.0),
      child: Container(
        decoration: const BoxDecoration(
          gradient: LinearGradient(
            colors: <Color>[
              Color(0xFF0D47A1),
              Color(0xFF1976D2),
              Color(0xFF42A5F5),
            ],
          ),
        ),
        padding: const EdgeInsets.all(10.0),
        child: const Text(
          'Gradient Button',
          style: TextStyle(fontSize: 20)
        ),
      ),
    );
    
    0 讨论(0)
  • 2021-01-31 15:43

    The Flutter API doc has an example of how to render a RaisedButton with gradient background - see here https://api.flutter.dev/flutter/material/RaisedButton-class.html

    Widget gradientButton = Container(
      child: RaisedButton(
        onPressed: () { },
        textColor: Colors.white,
        padding: const EdgeInsets.all(0.0),
        child: Container(
          width: 300,
          decoration: new BoxDecoration(
            gradient: new LinearGradient(
              colors: [
                Color.fromARGB(255, 148, 231, 225),
                Color.fromARGB(255, 62, 182, 226)
              ],
            )
          ),
          padding: const EdgeInsets.all(10.0),
          child: Text(
            "Gradient Button",
            textAlign: TextAlign.center,
          ),
        ),
      ),
    );
    

    0 讨论(0)
提交回复
热议问题