parent
7dac10c093
commit
4cc429d0f8
@ -0,0 +1,63 @@
|
|||||||
|
import 'package:ansu_ui/styles/as_colors.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:flutter_screenutil/flutter_screenutil.dart';
|
||||||
|
import 'package:ansu_ui/extension/num_extension.dart';
|
||||||
|
|
||||||
|
class ASRadioButton<T> extends StatefulWidget {
|
||||||
|
/// 选中的值
|
||||||
|
final T groupValue;
|
||||||
|
|
||||||
|
///按钮标题
|
||||||
|
final String title;
|
||||||
|
|
||||||
|
/// 该按钮的值
|
||||||
|
final T value;
|
||||||
|
|
||||||
|
///按钮回调
|
||||||
|
final Function(T value) onTap;
|
||||||
|
ASRadioButton({
|
||||||
|
Key key,
|
||||||
|
this.groupValue,
|
||||||
|
this.title,
|
||||||
|
this.value,
|
||||||
|
this.onTap,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
_ASRadioButtonState createState() => _ASRadioButtonState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _ASRadioButtonState extends State<ASRadioButton> {
|
||||||
|
bool get _selected => widget.value == widget.groupValue;
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return InkWell(
|
||||||
|
onTap: () => widget.onTap(widget.value),
|
||||||
|
borderRadius: 13.radius,
|
||||||
|
child: AnimatedContainer(
|
||||||
|
padding: EdgeInsets.symmetric(
|
||||||
|
horizontal: _selected ? 17.w : 16.w,
|
||||||
|
vertical: _selected ? 5.w : 4.w,
|
||||||
|
),
|
||||||
|
child: AnimatedDefaultTextStyle(
|
||||||
|
child: Text(widget.title),
|
||||||
|
style: TextStyle(
|
||||||
|
color: _selected ? kLightTextColor : kTextSubColor,
|
||||||
|
),
|
||||||
|
duration: Duration(milliseconds: 300),
|
||||||
|
),
|
||||||
|
duration: Duration(milliseconds: 300),
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color: _selected ? kPrimaryColor : Colors.transparent,
|
||||||
|
borderRadius: 13.radius,
|
||||||
|
border: _selected
|
||||||
|
? null
|
||||||
|
: Border.all(
|
||||||
|
width: 1.w,
|
||||||
|
color: Color(0xFF979797),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue