Flutter自定义UI组件插件wired_elements的使用
Flutter自定义UI组件插件wired_elements的使用
wired_elements
Wired Elements
是一系列具有手绘风格的基本UI元素。这些元素可以用于线框图、原型设计或仅仅是有趣的手绘风格。它是 <a href="https://github.com/rough-stuff/wired-elements" rel="ugc">wired-elements</a>
的 Flutter 实现版本,基于 <a href="https://github.com/sergiandreplace/flutter_rough" rel="ugc">flutter_rough</a>
库。
安装
在你的 pubspec.yaml
文件的 dependencies:
部分添加以下行:
dependencies:
wired_elements: <latest_version>
基本用法
对于更多的用法,请查看 <a href="https://github.com/KevinZhang19870314/wired_elements/blob/main/example/lib/demos.dart" rel="ugc">例子</a>
。
示例
以下是 wired_elements
插件的一些截图:











其他信息
<a href="https://github.com/sergiandreplace/flutter_rough" rel="ugc">flutter_rough</a>
是一个很棒的库,但它还不支持空安全(null safety)。有一个 <a href="https://github.com/sergiandreplace/flutter_rough/issues/5" rel="ugc">问题</a>
相关于此,但至今未得到回应。因此,我不得不将所有代码复制到项目中并自行实现空安全。只要 <a href="https://github.com/sergiandreplace/flutter_rough" rel="ugc">flutter_rough</a>
的作者完成了空安全工作,我就会使用该库作为依赖项,而不是复制所有源代码。
欢迎提交 PR!
完整示例代码
下面是一个完整的示例代码,展示了如何使用 wired_elements
插件来创建一个简单的应用。
import 'package:flutter/material.dart';
import 'package:wired_elements/wired_elements.dart'; // 导入 wired_elements 包
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: HomePage(),
);
}
}
class HomePage extends StatefulWidget {
[@override](/user/override)
_HomePageState createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> {
bool isChecked = false;
[@override](/user/override)
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Wired Elements Example'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
WiredButton(
text: '点击我',
onPressed: () {
print('按钮被点击了');
},
),
SizedBox(height: 20),
WiredCard(
child: Padding(
padding: const EdgeInsets.all(16.0),
child: Text('这是一个手绘风格的卡片'),
),
),
SizedBox(height: 20),
WiredCheckbox(
value: isChecked,
onChanged: (bool? newValue) {
setState(() {
isChecked = newValue!;
});
},
),
SizedBox(height: 20),
WiredInput(
placeholder: '输入文字',
onChanged: (String value) {
print('输入的文字: $value');
},
),
SizedBox(height: 20),
WiredSlider(
value: 0.5,
onChanged: (double newValue) {
print('滑块值: $newValue');
},
),
],
),
),
);
}
}
更多关于Flutter自定义UI组件插件wired_elements的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html
更多关于Flutter自定义UI组件插件wired_elements的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
wired_elements
是一个基于 Flutter 的自定义 UI 组件库,提供了一系列手绘风格的 UI 组件。这些组件具有独特的手绘外观,非常适合用于需要个性化设计的应用程序。以下是如何在 Flutter 项目中使用 wired_elements
插件的步骤。
1. 添加依赖
首先,在 pubspec.yaml
文件中添加 wired_elements
依赖:
dependencies:
flutter:
sdk: flutter
wired_elements: ^1.0.0 # 检查最新版本
然后运行 flutter pub get
以安装依赖。
2. 使用 Wired Elements 组件
wired_elements
提供了多种手绘风格的组件,例如按钮、复选框、滑块等。以下是一些常用组件的示例用法。
2.1 WiredButton
import 'package:flutter/material.dart';
import 'package:wired_elements/wired_elements.dart';
class MyHomePage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Wired Elements Example'),
),
body: Center(
child: WiredButton(
child: Text('Click Me'),
onPressed: () {
print('Button Pressed');
},
),
),
);
}
}
2.2 WiredCheckbox
import 'package:flutter/material.dart';
import 'package:wired_elements/wired_elements.dart';
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
bool _isChecked = false;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Wired Elements Example'),
),
body: Center(
child: WiredCheckbox(
value: _isChecked,
onChanged: (bool value) {
setState(() {
_isChecked = value;
});
},
),
),
);
}
}
2.3 WiredSlider
import 'package:flutter/material.dart';
import 'package:wired_elements/wired_elements.dart';
class MyHomePage extends StatefulWidget {
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
double _sliderValue = 50.0;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Wired Elements Example'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
WiredSlider(
value: _sliderValue,
min: 0,
max: 100,
onChanged: (double value) {
setState(() {
_sliderValue = value;
});
},
),
Text('Value: $_sliderValue'),
],
),
),
);
}
}
3. 自定义样式
wired_elements
组件通常支持一些自定义属性,例如颜色、大小等。你可以根据需要使用这些属性来调整组件的外观。
例如,自定义 WiredButton
的颜色和大小:
WiredButton(
child: Text('Custom Button'),
onPressed: () {
print('Custom Button Pressed');
},
color: Colors.blue,
height: 50,
width: 150,
);