Flutter优雅单选按钮组插件elegant_radio_button_group的使用

Flutter优雅单选按钮组插件elegant_radio_button_group的使用

elegant_radio_button_group 是一个用于 Flutter 的优雅单选按钮组插件。它提供了流畅的动画效果,使您的应用界面更加美观。

特性

以下是一些该插件的特性展示:

截图

截图

截图

使用方法

以下是如何在 Flutter 应用中使用 elegant_radio_button_group 插件的示例代码:

import 'package:flutter/material.dart';
import 'package:elegant_radio_button_group/elegant_radio_button_group.dart';

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  [@override](/user/override)
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Elegant Radio button group pacakge expample',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const MyHomePage(),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({Key? key}) : super(key: key);

  [@override](/user/override)
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  late int? selectedValue;

  [@override](/user/override)
  void initState() {
    super.initState();
    selectedValue = 1;
  }

  [@override](/user/override)
  Widget build(BuildContext context) {
    return Scaffold(
      body: SafeArea(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.start,
          crossAxisAlignment: CrossAxisAlignment.center,
          children: [
            ListTile(
              leading: ElegantRadioButton<int>(
                groupValue: selectedValue,
                value: 1,
                onChanged: (value) {
                  setState(() {
                    selectedValue = value;
                  });
                },
                fillColor: MaterialStateProperty.all(Colors.red),
              ),
              title: const Text('单选按钮 1'),
            ),
            ListTile(
              leading: ElegantRadioButton<int>(
                groupValue: selectedValue,
                value: 2,
                onChanged: (value) {
                  setState(() {
                    selectedValue = value;
                  });
                },
                fillColor: MaterialStateProperty.all(const Color(0xFFFF9494)),
              ),
              title: const Text('单选按钮 2'),
            ),
            ListTile(
              leading: ElegantRadioButton<int>(
                groupValue: selectedValue,
                value: 3,
                onChanged: (value) {
                  setState(() {
                    selectedValue = value;
                  });
                },
                fillColor: MaterialStateProperty.all(const Color(0xFFFFDCDC)),
              ),
              title: const Text('单选按钮 3'),
            ),
          ],
        ),
      ),
    );
  }
}

说明

  1. 导入库

    import 'package:flutter/material.dart';
    import 'package:elegant_radio_button_group/elegant_radio_button_group.dart';
    
  2. 定义主应用

    void main() {
      runApp(const MyApp());
    }
    
  3. 创建MaterialApp

    class MyApp extends StatelessWidget {
      const MyApp({Key? key}) : super(key: key);
    
      [@override](/user/override)
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Elegant Radio button group pacakge expample',
          theme: ThemeData(
            primarySwatch: Colors.blue,
          ),
          home: const MyHomePage(),
        );
      }
    }
    
  4. 创建主页状态

    class MyHomePage extends StatefulWidget {
      const MyHomePage({Key? key}) : super(key: key);
    
      [@override](/user/override)
      State<MyHomePage> createState() => _MyHomePageState();
    }
    
  5. 初始化状态并设置初始值

    class _MyHomePageState extends State<MyHomePage> {
      late int? selectedValue;
    
      [@override](/user/override)
      void initState() {
        super.initState();
        selectedValue = 1;
      }
    
  6. 构建UI

    [@override](/user/override)
    Widget build(BuildContext context) {
      return Scaffold(
        body: SafeArea(
          child: Column(
            mainAxisAlignment: MainAxisAlignment.start,
            crossAxisAlignment: CrossAxisAlignment.center,
            children: [
              ListTile(
                leading: ElegantRadioButton<int>(
                  groupValue: selectedValue,
                  value: 1,
                  onChanged: (value) {
                    setState(() {
                      selectedValue = value;
                    });
                  },
                  fillColor: MaterialStateProperty.all(Colors.red),
                ),
                title: const Text('单选按钮 1'),
              ),
              // 其他单选按钮...
            ],
          ),
        ),
      );
    }
    

更多关于Flutter优雅单选按钮组插件elegant_radio_button_group的使用的实战教程也可以访问 https://www.itying.com/category-92-b0.html

1 回复

更多关于Flutter优雅单选按钮组插件elegant_radio_button_group的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html


elegant_radio_button_group 是一个用于 Flutter 的优雅单选按钮组插件,它提供了美观且易于使用的单选按钮组。以下是如何使用该插件的基本步骤。

1. 添加依赖

首先,在 pubspec.yaml 文件中添加 elegant_radio_button_group 插件的依赖:

dependencies:
  flutter:
    sdk: flutter
  elegant_radio_button_group: ^1.0.0  # 请使用最新版本

然后运行 flutter pub get 来获取依赖。

2. 导入包

在需要使用 elegant_radio_button_group 的 Dart 文件中导入该包:

import 'package:elegant_radio_button_group/elegant_radio_button_group.dart';

3. 使用 ElegantRadioButtonGroup

ElegantRadioButtonGroup 是一个可以显示单选按钮组的小部件。你可以通过传递一组选项来创建它,并监听用户的选择。

以下是一个简单的示例:

import 'package:flutter/material.dart';
import 'package:elegant_radio_button_group/elegant_radio_button_group.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: Text('Elegant Radio Button Group Example'),
        ),
        body: Center(
          child: RadioButtonGroupExample(),
        ),
      ),
    );
  }
}

class RadioButtonGroupExample extends StatefulWidget {
  @override
  _RadioButtonGroupExampleState createState() => _RadioButtonGroupExampleState();
}

class _RadioButtonGroupExampleState extends State<RadioButtonGroupExample> {
  String? _selectedValue;

  final List<String> _options = [
    'Option 1',
    'Option 2',
    'Option 3',
    'Option 4',
  ];

  @override
  Widget build(BuildContext context) {
    return Column(
      mainAxisAlignment: MainAxisAlignment.center,
      children: [
        ElegantRadioButtonGroup(
          items: _options,
          selectedValue: _selectedValue,
          onChanged: (value) {
            setState(() {
              _selectedValue = value as String?;
            });
          },
        ),
        SizedBox(height: 20),
        Text(
          'Selected: ${_selectedValue ?? 'None'}',
          style: TextStyle(fontSize: 18),
        ),
      ],
    );
  }
}

4. 参数说明

  • items: 单选按钮组的选项列表,类型为 List<String>
  • selectedValue: 当前选中的值,类型为 String?
  • onChanged: 当用户选择某个选项时的回调函数,参数为选中的值。

5. 自定义样式

ElegantRadioButtonGroup 也支持自定义样式,比如按钮的颜色、大小等。你可以通过传递 activeColortextStyle 等参数来实现。

ElegantRadioButtonGroup(
  items: _options,
  selectedValue: _selectedValue,
  onChanged: (value) {
    setState(() {
      _selectedValue = value as String?;
    });
  },
  activeColor: Colors.blue,
  textStyle: TextStyle(fontSize: 16, color: Colors.black87),
);
回到顶部