分割(Division)
2024-05-23 02:08:57作者:卓艾滢Kingsley
探索Division,一个灵感源于CSS的简单易用且功能强大的Flutter样式组件库。这个库的目标是将样式和结构组件解耦,以提高代码可读性,并简化动画操作。
如果你遇到问题或有任何改进意见,欢迎在GitHub Issues上向我们反馈!
请注意:本文档中提到的Division已被styled_widget替代,但以下信息仍可供参考。
开始使用
Division的核心在于其结合了两种主要组件:
Parent(
child: Widget,
style: ParentStyle,
gesture: Gestures,
);
Txt(
String,
style: TxtStyle,
gesture: Gestures,
);
这些组件使你可以轻松地为你的Flutter应用添加样式并处理交互。
基本示例
要开始使用Division,首先导入库:
import 'package:division/division.dart';
然后尝试下面的基本按钮样例:
bool pressed = false;
final buttonStyle = (pressed) => TxtStyle()
..alignment.center()
..background.color(pressed ? Colors.orange : Colors.white)
..textColor(pressed ? Colors.white : Colors.orange)
..borderRadius(all: 5)
..border(all: 3, color: Colors.orange)
..padding(vertical: 10, horizontal: 15)
..ripple(true)
..animate(150, Curves.easeOut);
Gestures buttonGestures() =>
Gestures()..isTap((isPressed) => setState(() => pressed = isPressed));
@override
Widget build(BuildContext context) {
return Txt(
'风格化的按钮!',
style: buttonStyle(pressed),
gesture: buttonGestures(),
);
}
该示例的结果是一个带有平滑动画效果的响应式按钮,点击时颜色会变化。
应用场景与特性
- 结构与样式的分离:Division允许你在不混杂布局逻辑的情况下定义样式,使得代码更清晰。
- 易于创建动画:只需通过简单的属性设置,即可实现各种复杂的动画效果。
- 丰富的样式选项:包括但不限于对齐方式、背景色、边框、内阴影、过渡动画等,基本涵盖所有常见的CSS属性。
- 手势支持:轻轻松松地添加触摸事件,如点击、滑动等。
示例和最佳实践
查看Division的GitHub仓库,了解更复杂的应用示例,包括表格布局、表单设计以及更多。这些例子展示了如何利用Division来构建既美观又实用的界面。
文档简介
所有的Division组件都共享一套基础样式接口。以下是其中一部分关键样式方法:
- 动画(Animate):用于在样式改变时进行平滑过渡。
- 对齐(Alignment):用于设置组件及其内容的对齐方式。
- 填充(Padding):提供灵活的内外边距设置。
- 背景颜色(Background color):包括颜色选择器和渐变背景。
- 边界(Border):允许自定义边框宽度、颜色和样式。
了解更多详细信息和示例,请参阅完整的官方文档。
现在就加入Division的世界,让你的Flutter应用焕然一新,享受优雅编码的乐趣吧!
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
yuanrongopenYuanrong runtime:openYuanrong 多语言运行时提供函数分布式编程,支持 Python、Java、C++ 语言,实现类单机编程高性能分布式运行。Go051
MiniCPM-SALAMiniCPM-SALA 正式发布!这是首个有效融合稀疏注意力与线性注意力的大规模混合模型,专为百万级token上下文建模设计。00
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX01
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
541
3.77 K
Ascend Extension for PyTorch
Python
353
420
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
889
616
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
339
186
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
988
253
openGauss kernel ~ openGauss is an open source relational database management system
C++
169
233
暂无简介
Dart
778
194
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
115
142
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.35 K
759