/*
* @name Song
* @frame 720, 430
* @description Play a song.
* You will need to include the
* <a href="http://p5js.org/reference/#/libraries/p5.sound">p5.sound
* library</a> for this example to work in your own project.
*/
// The midi notes of a scale
var notes = [ 60, 62, 64, 65, 67, 69, 71];
// For automatically playing the song
var index = 0;
var song = [
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
//deuxieme
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 2, duration: 500, display: "B" },
{ note: 1, duration: 500, display: "A" },
{ note: 0, duration: 500, display: "G" },
/*
{ note: 4, duration: 300, display: "D" }, //re
{ duration: 100, display: "G" }, //sol
{ note: 1, duration: 100, display: "A" }, //la
{ note: 2, duration: 100, display: "B" },//si
{ note: 3, duration: 100, display: "C" },//do
{ note: 4, duration: 300, display: "D" },//re
{ note: 0, duration: 300, display: "G" },
{ note: 0, duration: 300, display: "G" }*/
];
var trigger = 0;
var autoplay = false;
var osc;
function setup() {
createCanvas(720, 400);
var div = createDiv("Click to play notes or ")
div.id("instructions");
var button = createButton("play song automatically.");
button.parent("instructions");
// Trigger automatically playing
button.mousePressed(function() {
if (!autoplay) {
index = 0;
autoplay = true;
}
});
// A triangle oscillator
osc = new p5.TriOsc();
// Start silent
osc.start();
osc.amp(0);
}
// A function to play a note
function playNote(note, duration) {
osc.freq(midiToFreq(note));
// Fade it in
osc.fade(0.5,0.2);
// If we sest a duration, fade it out
if (duration) {
setTimeout(function() {
osc.fade(0,0.2);
}, duration-50);
}
}
function draw() {
// If we are autoplaying and it's time for the next note
if (autoplay && millis() > trigger){
playNote(notes[song[index].note], song[index].duration);
trigger = millis() + song[index].duration;
// Move to the next note
index ++;
// We're at the end, stop autoplaying.
} else if (index >= song.length) {
autoplay = false;
}
// Draw a keyboard
// The width for each key
var w = width / notes.length;
for (var i = 0; i < notes.length; i++) {
var x = i * w;
// If the mouse is over the key
if (mouseX > x && mouseX < x + w && mouseY < height) {
// If we're clicking
if (mouseIsPressed) {
fill(100,255,200);
// Or just rolling over
} else {
fill(127);
}
} else {
fill(200);
}
// Or if we're playing the song, let's highlight it too
if (autoplay && i === song[index-1].note) {
fill(100,255,200);
}
// Draw the key
rect(x, 0, w-1, height-1);
}
}
// When we click
function mousePressed() {
// Map mouse to the key index
var key = floor(map(mouseX, 0, width, 0, notes.length));
playNote(notes[key]);
}
// Fade it out when we release
function mouseReleased() {
osc.fade(0,0.5);
}
* @name Song
* @frame 720, 430
* @description Play a song.
* You will need to include the
* <a href="http://p5js.org/reference/#/libraries/p5.sound">p5.sound
* library</a> for this example to work in your own project.
*/
// The midi notes of a scale
var notes = [ 60, 62, 64, 65, 67, 69, 71];
// For automatically playing the song
var index = 0;
var song = [
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
//deuxieme
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration: 500, display: "C" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 5, duration: 500, display: "E" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 4, duration: 500, display: "D" },
{ note: 3, duration:500, display: "C" },
{ note: 4, duration: 500, display: "D" },
{ note: 2, duration: 500, display: "B" },
{ note: 1, duration: 500, display: "A" },
{ note: 0, duration: 500, display: "G" },
/*
{ note: 4, duration: 300, display: "D" }, //re
{ duration: 100, display: "G" }, //sol
{ note: 1, duration: 100, display: "A" }, //la
{ note: 2, duration: 100, display: "B" },//si
{ note: 3, duration: 100, display: "C" },//do
{ note: 4, duration: 300, display: "D" },//re
{ note: 0, duration: 300, display: "G" },
{ note: 0, duration: 300, display: "G" }*/
];
var trigger = 0;
var autoplay = false;
var osc;
function setup() {
createCanvas(720, 400);
var div = createDiv("Click to play notes or ")
div.id("instructions");
var button = createButton("play song automatically.");
button.parent("instructions");
// Trigger automatically playing
button.mousePressed(function() {
if (!autoplay) {
index = 0;
autoplay = true;
}
});
// A triangle oscillator
osc = new p5.TriOsc();
// Start silent
osc.start();
osc.amp(0);
}
// A function to play a note
function playNote(note, duration) {
osc.freq(midiToFreq(note));
// Fade it in
osc.fade(0.5,0.2);
// If we sest a duration, fade it out
if (duration) {
setTimeout(function() {
osc.fade(0,0.2);
}, duration-50);
}
}
function draw() {
// If we are autoplaying and it's time for the next note
if (autoplay && millis() > trigger){
playNote(notes[song[index].note], song[index].duration);
trigger = millis() + song[index].duration;
// Move to the next note
index ++;
// We're at the end, stop autoplaying.
} else if (index >= song.length) {
autoplay = false;
}
// Draw a keyboard
// The width for each key
var w = width / notes.length;
for (var i = 0; i < notes.length; i++) {
var x = i * w;
// If the mouse is over the key
if (mouseX > x && mouseX < x + w && mouseY < height) {
// If we're clicking
if (mouseIsPressed) {
fill(100,255,200);
// Or just rolling over
} else {
fill(127);
}
} else {
fill(200);
}
// Or if we're playing the song, let's highlight it too
if (autoplay && i === song[index-1].note) {
fill(100,255,200);
}
// Draw the key
rect(x, 0, w-1, height-1);
}
}
// When we click
function mousePressed() {
// Map mouse to the key index
var key = floor(map(mouseX, 0, width, 0, notes.length));
playNote(notes[key]);
}
// Fade it out when we release
function mouseReleased() {
osc.fade(0,0.5);
}
Aucun commentaire:
Enregistrer un commentaire