# Xylophone

# 0. Final Product

  • Xylophone made with flutter.
  • 위에서부터 도레미파솔라시.

image-20220127103829420

# 1. Import

pubspec.yaml

flutter:

  uses-material-design: true

  assets:
    - assets/


1
2
3
4
5
6
7
8
  • wav 파일들을 assets안에 보관

# 2. Audio

import 'package:audioplayers/audio_cache.dart';

final player = AudioCache();
              player.play('note$noteNumber.wav');
1
2
3
4

# 2. Main

main.dart

import 'package:flutter/material.dart';
import 'package:english_words/english_words.dart';
import 'package:audioplayers/audio_cache.dart';

void main() => runApp(XylophoneApp());

class XylophoneApp extends StatelessWidget {
  
  Widget build(BuildContext context) {
    Expanded buildKey(Color color, int noteNumber) {
      return Expanded(
        child: TextButton(
            child: Text(''),
            style: TextButton.styleFrom(backgroundColor: color),
            onPressed: () {
              final player = AudioCache();
              player.play('note$noteNumber.wav');
              print('pressed');
            }),
      );
    }

    return MaterialApp(
      home: Scaffold(
        backgroundColor: Colors.black,
        body: SafeArea(
          child: Center(
            child: Column(
                crossAxisAlignment: CrossAxisAlignment.stretch,
                children: [
                  buildKey(Colors.red, 1),
                  buildKey(Colors.orange, 2),
                  buildKey(Colors.yellow, 3),
                  buildKey(Colors.green, 4),
                  buildKey(Colors.blue, 5),
                  buildKey(Colors.blue.shade900, 6),
                  buildKey(Colors.purple, 7)
                ]),
          ),
        ),
      ),
    );
  }
}

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45