forked from: forked from: SoundFork
♥0 |
Line 51 |
Modified 2009-10-23 07:38:28 |
MIT License
archived:2017-03-30 05:34:10
ActionScript3 source code
/**
* Copyright fukt ( http://wonderfl.net/user/fukt )
* MIT License ( http://www.opensource.org/licenses/mit-license.php )
* Downloaded from: http://wonderfl.net/c/32yE
*/
// forked from failrate's forked from: SoundFork
// forked from murderdeathkitty's SoundFork
// forked from murderdeathkitty's flash on 2009-7-17
package {
import flash.display.*;
import flash.events.*;
import flash.media.*;
import flash.utils.*;
import flash.net.*;
public class SoundFork extends Sprite {
private var sound: Sound;
private var channel: SoundChannel
private var freq1:Number = 100;
private var freq2:Number = 100;
public function SoundFork(): void
{
addEventListener(Event.ADDED_TO_STAGE, start);
addEventListener(Event.REMOVED_FROM_STAGE, stop);
}
public function start(e: Event = null): void
{
sound = new Sound();
sound.addEventListener(SampleDataEvent.SAMPLE_DATA, generate);
channel = sound.play();
}
public function stop(e: Event = null): void
{
if(channel != null){
channel.stop();
channel = null;
}
}
//replace this with your own sound!!!
//output is 44100 hz, stereo. values between -1 and 1
private function generate(e: SampleDataEvent): void
{
var data: ByteArray = e.data;
var i: Number;
var output: Number;
var envelope:Number =0;
freq1 += Math.random() * 4.0 - 1.0;
if ( freq1 <= 60 ) { freq1 = 60; }
if ( freq1 >= 1000 ) { freq1 = 1000; }
freq2 += Math.random() * 2.0 - 1.0;
if ( freq2 <= 60 ) { freq2 = 60; }
if ( freq2 >= 1000 ) { freq2 = Math.round(Math.random()*1000); }
for(i = 0; i < Math.round(Math.random()*2028); ++i){
if ( i < 1024 ) { envelope += 1.0/1024; }
else { envelope -= 1.0/1024; }
output = (Math.sin(i/freq1) * envelope/2) + (Math.sin(i/freq2) * envelope/2);
data.writeFloat(output);//left
data.writeFloat(output);//right
}
}
}
}