xly 0.4.0 xly: ^0.4.0 copied to clipboard
A Test Flutter Package, DO NOT USE IT at present
XLY包 #
XLY 是一个Flutter懒人工具包,提供了一些常用的功能和组件。虽然目前仍在开发中,但已经可以在项目中使用许多实用功能。
功能 #
当前,这个包提供了以下功能:
- 基于GetX的状态管理
- 基于ScreenUtil的屏幕适配
- 基于window_manager的窗口管理
- Toast消息显示(基于oktoast)
- 导航辅助函数
- 自定义按钮组件
- 自定义菜单组件
- 焦点管理
使用示例 #
初始化应用 #
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:xly/xly.dart';
import 'pages/page1.dart';
import 'pages/page2.dart';
import 'pages/page3.dart';
void main() async {
await MyApp.initialize(
designSize: const Size(800, 600),
splash: const MySplash(
nextRoute: Routes.page1,
lottieAssetPath: 'assets/animation/splash_loading.json',
appTitle: 'My Awesome App',
backgroundColor: Colors.blueGrey,
splashDuration: Duration(seconds: 3),
textColor: Colors.white,
fontSize: 60,
fontWeight: FontWeight.bold,
lottieWidth: 250,
spaceBetween: 30,
),
routes: [
MyRoute<Page1Controller>(
path: Routes.page1,
page: const Page1View(),
controller: () => Page1Controller(),
),
MyRoute<Page2Controller>(
path: Routes.page2,
page: const Page2View(),
controller: () => Page2Controller(),
),
MyRoute<Page3Controller>(
path: Routes.page3,
page: const Page3View(),
controller: () => Page3Controller(),
),
],
keyToRollBack: LogicalKeyboardKey.backspace,
exitInfoText: '自定义: 再按一次退出App',
backInfoText: '自定义: 再按一次返回上一页',
pageTransitionStyle: Transition.fade,
);
}
class Routes {
static const String page1 = '/page1';
static const String page2 = '/page2';
static const String page3 = '/page3';
}
显示 Toast 消息 #
toast('这是一条测试Toast消息');
使用自定义按钮 #
Widget buildCustomButton() {
return MyButton(
text: '点击我',
onPressed: () => print('按钮被点击'),
icon: Icons.star,
shape: MyButtonShape.normal,
backgroundColor: Colors.blue,
foregroundColor: Colors.white,
);
}
使用菜单按钮 #
Widget buildMenuButton() {
return MyMenuButton(
icon: Icons.more_vert,
iconSize: 30.0,
iconColor: Colors.green,
menuItems: [
MyMenuItem(
text: '选项A',
icon: Icons.star,
onTap: () => toast('选择了选项A'),
),
MyMenuItem(
text: '选项B',
icon: Icons.favorite,
onTap: () => toast('选择了选项B'),
),
],
);
}
使用焦点管理 #
class MyWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Text('可聚焦的文本').setFocus(
focusKey: 'focusable_text',
onPressed: () => toast('文本被聚焦并点击'),
opacity: true,
focusedBorderColor: Colors.green,
borderWidth: 2,
);
}
}
导航到新页面 #
goToPage(context, Routes.page2);
显示对话框 #
MyDialog.show(
content: '这是一个测试对话框',
onLeftButtonPressed: () => toast('选择了左按钮'),
onRightButtonPressed: () => toast('选择了右按钮'),
);
MyDialog.showIos(
content: '这是一个测试对话框',
onLeftButtonPressed: () => toast('选择了左按钮'),
onRightButtonPressed: () => toast('选择了右按钮'),
);
使用底部菜单 #
MyBottomMenu.show(
child: Text('这是一个测试底部菜单'),
style: MyMenuStyle(shadowRatio: 0.2),
);
右键菜单 #
Widget buildRightMenu() {
return Text('这是一个测试右键菜单').showRightMenu(
context: context,
menuElements: [
MyMenuItem(text: '选项A', onTap: () => toast('选择了选项A')),
MyMenuItem(text: '选项B', onTap: () => toast('选择了选项B')),
],
);
}
## 完整示例
对于一个完整的示例,请参考Example页面。该示例展示了如何综合使用 xly 包中的各种功能,包括按钮、菜单、焦点管理和导航等。Example 页面提供了更详细的代码实现和实际运行效果,可以帮助您更好地理解和使用 xly 包的各项功能。
您可以在项目的 `example` 目录下找到完整的示例代码。通过运行示例项目,您可以直观地体验 xly 包提供的各种组件和功能,并了解它们在实际应用中的使用方法。
## splash Json动画资源
- [lottie 动画参考1](https://lottiefiles.com/featured)
- [lottie 动画参考2](https://iconscout.com/lottie-animations/)
## 注意事项
- 确保在使用 XLY 包的功能之前已经正确初始化了应用。
- 某些功能可能需要额外的设置或权限,请参考具体组件的文档。
## 贡献
欢迎提交问题和拉取请求。对于重大更改,请先开启一个问题讨论您想要更改的内容。
## 许可证
[MIT](https://choosealicense.com/licenses/mit/)