You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ansu_ui/lib/buttons/as_gradient_button.dart

141 lines
3.6 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

import 'package:flutter/material.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:ansu_ui/styles/as_colors.dart';
class ASGradientButton extends StatelessWidget {
///按钮文字
///动态类型可以是string或者widget
final dynamic title;
///按钮文字颜色
///若已定义文字风格则此属性不生效
final Color? textColor;
///圆角
final double? radius;
///按钮文字风格
final TextStyle? textStyle;
///内边距
final EdgeInsetsGeometry? padding;
///点击事件
final VoidCallback? onPressed;
///渐变颜色
final List<Color>? colors;
///开始位置
final AlignmentGeometry? begin;
///结束位置
final AlignmentGeometry? end;
///宽度
final double? width;
///不可点击颜色
final Color? disableColor;
///不可点击文字颜色
final Color? disableTextColor;
ASGradientButton(
{Key? key,
required this.title,
this.textColor,
this.radius,
this.textStyle,
this.padding,
this.onPressed,
this.colors,
this.width,
this.begin,
this.end,
this.disableColor,
this.disableTextColor})
: super(key: key);
ASGradientButton.pay({
Key? key,
required this.title,
this.textStyle,
this.onPressed,
this.disableColor,
this.disableTextColor,
}) : textColor = kLightTextColor,
radius = 19.w,
colors = [Color(0xFFF89B14), Color(0xFFF86B14)],
width = 100.w,
begin = Alignment.topCenter,
end = Alignment.bottomCenter,
padding = EdgeInsets.symmetric(vertical: 8.w),
super(key: key);
ASGradientButton.operation(
{Key? key,
required this.title,
this.textColor,
this.onPressed,
this.disableColor,
this.width,
this.radius,
this.begin,
this.end,
this.padding,
this.disableTextColor})
: textStyle = TextStyle(
color: Color(0xFFFFFFFF),
fontSize: 14.sp,
fontWeight: FontWeight.bold),
colors = [Color(0xFFFFA700), Color(0xFFFFBD00)],
super(key: key);
bool get isNullFunc => onPressed == null;
List<Color>? get _colors {
if (colors == null)
return null;
else {
return List.generate(
colors!.length,
(index) => colors![index].withOpacity(isNullFunc ? 0.5 : 1),
);
}
}
@override
Widget build(BuildContext context) {
return AnimatedContainer(
curve: Curves.easeInOutCirc,
duration: Duration(milliseconds: 300),
width: width ?? 110.w,
decoration: BoxDecoration(
gradient: LinearGradient(
begin: begin ?? Alignment.topCenter,
end: end ?? Alignment.bottomCenter,
colors: _colors ??
[
kDarkPrimaryColor.withOpacity(isNullFunc ? 0.5 : 1),
kLightPrimaryColor.withOpacity(isNullFunc ? 0.5 : 1),
],
),
borderRadius: BorderRadius.circular(radius ?? 20.w),
),
child: MaterialButton(
disabledColor: disableColor,
textColor: textColor ?? Color(0xD9FFFFFF),
disabledTextColor: disableTextColor,
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
onPressed: onPressed,
child: title is String
? Text(title,
style: textStyle ?? TextStyle(fontSize: 18.sp))
: title,
padding: padding ?? EdgeInsets.symmetric(vertical: 10.w),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(radius ?? 20.w)),
elevation: 0,
),
);
}
}