Сначала измените class
на StatefulWidget
:
import 'package:flutter/material.dart';
class ButtonCalculate extends StatefulWidget {
ButtonCalculate({Key key,}): super(key: key);
@override
_ButtonCalculateState createState() => new _ButtonCalculateState();
}
Затем в классе State
добавьте переменную для определения состояния кнопки:
class _ButtonCalculateState extends State<ButtonCalculate> {
var pressed = false ; // This is the press variable
@override
Widget build(BuildContext context) {
var container = Container(
decoration: BoxDecoration(gradient: null,
borderRadius: BorderRadius.circular(20.0),
color: pressed ? Colors.amber : Colors.blue , // if the button is pressed color will be amber if pressed again it'll go back to blue
boxShadow: [
BoxShadow(
color: Colors.black12,
offset: Offset(0.0, 0.5),
blurRadius: 40.5,
),
]),
child: new FlatButton(
child: Image(
image:AssetImage('assets/2.0x/Button_Calculate.png')),
onPressed: () {
setState((){
pressed = !pressed ; // update the state of the class to show color change
});
},
),
width: 290.0,
);
// Add the reminder of your code and remember to close the class parenthesis