Unverified Commit 1da7f1b9 authored by Shi-Hao Hong's avatar Shi-Hao Hong Committed by GitHub

Improve Radio Documentation with Example (#31294)

parent c7a09a41
...@@ -21,11 +21,64 @@ const double _kInnerRadius = 4.5; ...@@ -21,11 +21,64 @@ const double _kInnerRadius = 4.5;
/// be selected. The values are of type `T`, the type parameter of the [Radio] /// be selected. The values are of type `T`, the type parameter of the [Radio]
/// class. Enums are commonly used for this purpose. /// class. Enums are commonly used for this purpose.
/// ///
/// The radio button itself does not maintain any state. Instead, when the state /// The radio button itself does not maintain any state. Instead, selecting the
/// of the radio button changes, the widget calls the [onChanged] callback. /// radio invokes the [onChanged] callback, passing [value] as a parameter. If
/// Most widget that use a radio button will listen for the [onChanged] /// [groupValue] and [value] match, this radio will be selected. Most widgets
/// callback and rebuild the radio button with a new [groupValue] to update the /// will respond to [onChanged] by calling [State.setState] to update the
/// visual appearance of the radio button. /// radio button's [groupValue].
///
/// {@tool snippet --template=stateful_widget_scaffold}
///
/// Here is an example of Radio widgets wrapped in ListTiles, which is similar
/// to what you could get with the RadioListTile widget.
///
/// The currently selected character is passed into `groupValue`, which is
/// maintained by the example's `State`. In this case, the first `Radio`
/// will start off selected because `_character` is initialized to
/// `SingingCharacter.lafayette`.
///
/// If the second radio button is pressed, the example's state is updated
/// with `setState`, updating `_character` to `SingingCharacter.jefferson`.
/// This causes the buttons to rebuild with the updated `groupValue`, and
/// therefore the selection of the second button.
///
/// ```dart preamble
/// enum SingingCharacter { lafayette, jefferson }
/// ```
///
/// ```dart
/// SingingCharacter _character = SingingCharacter.lafayette;
///
/// Widget build(BuildContext context) {
/// return Center(
/// child: Column(
/// children: <Widget>[
/// ListTile(
/// title: const Text('Lafayette'),
/// leading: Radio(
/// value: SingingCharacter.lafayette,
/// groupValue: _character,
/// onChanged: (SingingCharacter value) {
/// setState(() { _character = value; });
/// },
/// ),
/// ),
/// ListTile(
/// title: const Text('Thomas Jefferson'),
/// leading: Radio(
/// value: SingingCharacter.jefferson,
/// groupValue: _character,
/// onChanged: (SingingCharacter value) {
/// setState(() { _character = value; });
/// },
/// ),
/// ),
/// ],
/// ),
/// );
/// }
/// ```
/// {@end-tool}
/// ///
/// Requires one of its ancestors to be a [Material] widget. /// Requires one of its ancestors to be a [Material] widget.
/// ///
...@@ -62,7 +115,7 @@ class Radio<T> extends StatefulWidget { ...@@ -62,7 +115,7 @@ class Radio<T> extends StatefulWidget {
/// The value represented by this radio button. /// The value represented by this radio button.
final T value; final T value;
/// The currently selected value for this group of radio buttons. /// The currently selected value for a group of radio buttons.
/// ///
/// This radio button is considered selected if its [value] matches the /// This radio button is considered selected if its [value] matches the
/// [groupValue]. /// [groupValue].
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment