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: &lt;latest_version&gt;

基本用法

对于更多的用法,请查看 <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

1 回复

更多关于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,
);
回到顶部