flutter_midi 0.0.3 copy "flutter_midi: ^0.0.3" to clipboard
flutter_midi: ^0.0.3 copied to clipboard

outdated

A FLutter Plugin to Play midi on iOS and Android.

example/lib/main.dart

import 'package:flutter/material.dart';

import 'package:flutter_midi/flutter_midi.dart';

void main() => runApp(new MyApp());

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => new _MyAppState();
}

class _MyAppState extends State<MyApp> {
  /// When [true] the note will be played for as long as the button is pressed
  /// The sound starts the second the button is touched.
  ///
  /// When [false] the sound will be play when the button is pressed.
  /// If the user cancels the touch on drag the sound will not be played.
  /// In this mode the sound will play for a default time.
  bool _toggle = true;

  @override
  void initState() {
    _initPlatformState();
    super.initState();
  }

  /// Need to Load the sound_font.SF2 file in memory to play midi without lag.
  void _initPlatformState() async {
    String _message = await FlutterMidi.prepare();
    print(_message);
    _message = await FlutterMidi.unmute();
    print(_message);
  }

  /// Starts playing the midi note
  void _playMidi(int midi) {
    FlutterMidi.playMidiNote(midi: midi)
        .then((dynamic message) => print(message))
        .catchError((dynamic e) => print(e));
  }

  /// Stops playing the midi note
  void _stopMidi() {
    FlutterMidi.stopMidiNote()
        .then((dynamic message) => print(message))
        .catchError((dynamic e) => print(e));
  }

  /// Creates a general resuable button that can toggle or just play a note.
  Widget _playButton({int midi, String name, bool toggle}) {
    return Container(
      color: Colors.blue,
      child: Listener(
        onPointerDown: (dynamic e) => toggle ? _playMidi(midi) : null,
        onPointerUp: (dynamic e) => toggle ? _stopMidi() : null,
        child: InkWell(
          onTap: toggle ? null : () => _playMidi(midi),
          child: Container(
            padding: const EdgeInsets.all(20.0),
            child: Text(
              name,
              style: const TextStyle(color: Colors.white),
            ),
          ),
        ),
      ),
    );
  }

  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      home: new Scaffold(
        appBar: new AppBar(
          title: const Text('Play Midi Note'),
        ),
        body: SingleChildScrollView(
          child: Center(
              child: Column(children: <Widget>[
            ListTile(
              title: const Text('Toggle Mode'),
              trailing: Switch(
                value: _toggle,
                onChanged: (bool value) => setState(() => _toggle = value),
              ),
            ),
            ButtonBar(mainAxisSize: MainAxisSize.min, children: <Widget>[
              _playButton(midi: 60, name: "C", toggle: _toggle),
              _playButton(midi: 64, name: "E", toggle: _toggle),
              _playButton(midi: 67, name: "G", toggle: _toggle),
            ]),
          ])),
        ),
      ),
    );
  }
}
45
likes
0
pub points
80%
popularity

Publisher

verified publisherrodydavis.com

A FLutter Plugin to Play midi on iOS and Android.

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter

More

Packages that depend on flutter_midi