update checkbox

null_safety
张萌 4 years ago
parent c98577607d
commit 65c534e363

@ -3,12 +3,15 @@ import 'package:flutter_screenutil/flutter_screenutil.dart';
class ASCheckBox extends StatefulWidget { class ASCheckBox extends StatefulWidget {
final bool value; final bool value;
///
final bool checkStyle; final bool checkStyle;
ASCheckBox({Key key, this.value = false}) ///
final Color color;
ASCheckBox({Key key, this.value = false, this.color})
: checkStyle = false, : checkStyle = false,
super(key: key); super(key: key);
ASCheckBox.checkStyle({Key key, this.value = false}) ASCheckBox.checkStyle({Key key, this.value = false, this.color})
: checkStyle = true, : checkStyle = true,
super(key: key); super(key: key);
@ -35,7 +38,7 @@ class _ASCheckBoxState extends State<ASCheckBox> {
height: widget.value ? 13.w : 5.w, height: widget.value ? 13.w : 5.w,
width: widget.value ? 13.w : 5.w, width: widget.value ? 13.w : 5.w,
decoration: BoxDecoration( decoration: BoxDecoration(
color: Color(0xFFF69A2D).withOpacity(widget.value ? 1 : 0), color:widget.color?? Color(0xFFF69A2D).withOpacity(widget.value ? 1 : 0),
borderRadius: BorderRadius.circular(13.w), borderRadius: BorderRadius.circular(13.w),
), ),
), ),
@ -55,17 +58,19 @@ class _ASCheckBoxState extends State<ASCheckBox> {
width: widget.value ? 0 : 1.w, width: widget.value ? 0 : 1.w,
), ),
borderRadius: BorderRadius.circular(27.w), borderRadius: BorderRadius.circular(27.w),
color: Color(0xFFFFBD32).withOpacity(widget.value ? 1 : 0), color:widget.color?? Color(0xFFFFBD32).withOpacity(widget.value ? 1 : 0),
), ),
child: AnimatedOpacity( child: AnimatedOpacity(
duration: Duration(milliseconds: 300), duration: Duration(milliseconds: 300),
curve: Curves.fastOutSlowIn, curve: Curves.fastOutSlowIn,
opacity: widget.value ? 1 : 0, opacity: widget.value ? 1 : 0,
child: FittedBox(
child: Icon( child: Icon(
Icons.check, Icons.check,
size: 18.w, size: 18.w,
), ),
), ),
),
); );
} }

Loading…
Cancel
Save