Argon Flutter Buttons 项目教程
1. 项目的目录结构及介绍
Argon-Flutter-Buttons/
├── lib/
│ ├── argon_button.dart
│ ├── argon_timer_button.dart
│ └── main.dart
├── pubspec.yaml
└── README.md
- lib/: 包含项目的主要代码文件。
- argon_button.dart: 定义了 ArgonButton 组件。
- argon_timer_button.dart: 定义了 ArgonTimerButton 组件。
- main.dart: 项目的入口文件。
- pubspec.yaml: 项目的配置文件,包含依赖管理和其他配置。
- README.md: 项目的说明文档。
2. 项目的启动文件介绍
main.dart 是项目的启动文件,负责初始化应用并运行。以下是 main.dart
的基本结构:
import 'package:flutter/material.dart';
import 'argon_button.dart';
import 'argon_timer_button.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Argon Buttons Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(),
);
}
}
class MyHomePage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Argon Buttons Demo'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
ArgonButton(
height: 50,
width: 350,
borderRadius: 5.0,
color: Color(0xFF7866FE),
child: Text(
"Continue",
style: TextStyle(
color: Colors.white,
),
),
onTap: (startLoading, stopLoading, btnState) {
// 按钮点击逻辑
},
),
SizedBox(height: 20),
ArgonTimerButton(
initialTimer: 10,
height: 50,
width: MediaQuery.of(context).size.width * 0.45,
minWidth: MediaQuery.of(context).size.width * 0.30,
color: Color(0xFF7866FE),
borderRadius: 5.0,
child: Text(
"Resend OTP",
style: TextStyle(
color: Colors.black,
fontSize: 18,
fontWeight: FontWeight.w700,
),
),
loader: (timeLeft) {
return Text(
"Wait | $timeLeft",
style: TextStyle(
color: Colors.black,
),
);
},
onTap: (startTimer, stopTimer, btnState) {
// 按钮点击逻辑
},
),
],
),
),
);
}
}
3. 项目的配置文件介绍
pubspec.yaml 是 Flutter 项目的配置文件,包含项目的基本信息、依赖管理和其他配置。以下是 pubspec.yaml
的基本结构:
name: argon_buttons_flutter
description: A new Flutter package project.
version: 1.0.0+1
environment:
sdk: ">=2.12.0 <3.0.0"
dependencies:
flutter:
sdk: flutter
cupertino_icons: ^1.0.2
dev_dependencies:
flutter_test:
sdk: flutter
flutter_lints: ^1.0.0
flutter:
uses-material-design: true
- name: 项目的名称。
- description: 项目的描述。
- version: 项目的版本号。
- environment: 指定 Dart SDK 的版本范围。
- dependencies: 项目的依赖