|
|
@ -22,13 +22,6 @@
|
|
|
|
<input type="hidden" name="latitude" value="{{ latitude }}" />
|
|
|
|
<input type="hidden" name="latitude" value="{{ latitude }}" />
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<div class="recorder">
|
|
|
|
|
|
|
|
Recorder
|
|
|
|
|
|
|
|
<input type="button" class="start" value="Record" />
|
|
|
|
|
|
|
|
<input type="button" class="stop" value="Stop" />
|
|
|
|
|
|
|
|
<pre class="status"></pre>
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
<div id="audio">
|
|
|
|
<div id="audio">
|
|
|
|
<div class="record_controls">
|
|
|
|
<div class="record_controls">
|
|
|
|
<a class="record_btn audio_btn" id="record_btn" onclick="record_audio()" href="#"><span class="icon"></span>record</a>
|
|
|
|
<a class="record_btn audio_btn" id="record_btn" onclick="record_audio()" href="#"><span class="icon"></span>record</a>
|
|
|
@ -38,6 +31,7 @@
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div id="audio-player-container"></div>
|
|
|
|
<div id="audio-player-container"></div>
|
|
|
|
|
|
|
|
<ul id="playlist"></ul>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<input hidden="true" type="file" name="file" id="uploadedFile" accept="audio/*"><br>
|
|
|
|
<input hidden="true" type="file" name="file" id="uploadedFile" accept="audio/*"><br>
|
|
|
@ -64,14 +58,43 @@ var seconds_int;
|
|
|
|
var audio;
|
|
|
|
var audio;
|
|
|
|
var state = "empty";
|
|
|
|
var state = "empty";
|
|
|
|
var audio_context;
|
|
|
|
var audio_context;
|
|
|
|
|
|
|
|
var mimeType;
|
|
|
|
|
|
|
|
const recorder = new MicRecorder({
|
|
|
|
|
|
|
|
bitRate: 128
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const audioChunks = [];
|
|
|
|
|
|
|
|
|
|
|
|
function record_audio(){
|
|
|
|
function record_audio(){
|
|
|
|
if(state == "empty"){
|
|
|
|
if(state == "empty"){
|
|
|
|
navigator.mediaDevices.getUserMedia({ audio: true })
|
|
|
|
// navigator.mediaDevices.getUserMedia({ audio: true })
|
|
|
|
.then(stream => {
|
|
|
|
// .then(stream => {
|
|
|
|
mediaRecorder = new MediaRecorder(stream);
|
|
|
|
// mediaRecorder = new MediaRecorder(stream, {mimeType: 'audio/webm;codecs=opus'}); // , {mimeType:"audio/ogg"}
|
|
|
|
mediaRecorder.start();
|
|
|
|
// mediaRecorder.start();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// state = "recording";
|
|
|
|
|
|
|
|
// document.getElementById('stop_btn').style.display = 'block'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// seconds_int = setInterval(
|
|
|
|
|
|
|
|
// function () {
|
|
|
|
|
|
|
|
// document.getElementById("record_btn").innerHTML = seconds_rec + " s";
|
|
|
|
|
|
|
|
// seconds_rec += 1;
|
|
|
|
|
|
|
|
// }, 1000);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// mediaRecorder.addEventListener("dataavailable", event => {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// audioChunks.push(event.data);
|
|
|
|
|
|
|
|
// if(mediaRecorder.state == 'inactive') makeLink();
|
|
|
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// setTimeout(() => {
|
|
|
|
|
|
|
|
// stop_audio()
|
|
|
|
|
|
|
|
// }, 1000 * 60);
|
|
|
|
|
|
|
|
// });
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
recorder.start().then(() => {
|
|
|
|
|
|
|
|
|
|
|
|
state = "recording";
|
|
|
|
state = "recording";
|
|
|
|
document.getElementById('stop_btn').style.display = 'block'
|
|
|
|
document.getElementById('stop_btn').style.display = 'block'
|
|
|
@ -82,30 +105,40 @@ function record_audio(){
|
|
|
|
seconds_rec += 1;
|
|
|
|
seconds_rec += 1;
|
|
|
|
}, 1000);
|
|
|
|
}, 1000);
|
|
|
|
|
|
|
|
|
|
|
|
const audioChunks = [];
|
|
|
|
setTimeout(() => {
|
|
|
|
mediaRecorder.addEventListener("dataavailable", event => {
|
|
|
|
stop_audio()
|
|
|
|
audioChunks.push(event.data);
|
|
|
|
}, 1000 * 60);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}).catch((e) => {
|
|
|
|
|
|
|
|
console.error(e);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function blobToFile(theBlob, fileName){
|
|
|
|
|
|
|
|
//A Blob() is almost a File() - it's just missing the two properties below which we will add
|
|
|
|
|
|
|
|
theBlob.lastModifiedDate = new Date();
|
|
|
|
|
|
|
|
theBlob.name = fileName;
|
|
|
|
|
|
|
|
return theBlob;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function makeLink(){
|
|
|
|
|
|
|
|
const audioBlob = new Blob(audioChunks, {type: 'audio/webm;codecs=opus'});
|
|
|
|
|
|
|
|
|
|
|
|
mediaRecorder.addEventListener("stop", () => {
|
|
|
|
|
|
|
|
console.log("stopping");
|
|
|
|
|
|
|
|
const audioBlob = new Blob(audioChunks, {type: 'audio/mpeg'});
|
|
|
|
|
|
|
|
const audioUrl = URL.createObjectURL(audioBlob);
|
|
|
|
const audioUrl = URL.createObjectURL(audioBlob);
|
|
|
|
var sound = document.createElement('audio');
|
|
|
|
var sound = document.createElement('audio');
|
|
|
|
sound.id = 'audio-player';
|
|
|
|
sound.id = 'audio-player';
|
|
|
|
sound.controls = 'controls';
|
|
|
|
sound.controls = 'controls';
|
|
|
|
sound.src = audioUrl;
|
|
|
|
sound.src = audioUrl;
|
|
|
|
console.log(audioUrl)
|
|
|
|
console.log(audioBlob)
|
|
|
|
sound.type = 'audio/mpeg';
|
|
|
|
sound.type = 'audio/webm;codecs=opus';
|
|
|
|
document.getElementById("audio-player-container").innerHTML = sound.outerHTML;
|
|
|
|
document.getElementById("audio-player-container").innerHTML = sound.outerHTML;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let file = new File([audioBlob], "audio.webm",{ type:"audio/webm;codecs=opus",lastModifiedDate: new Date()});
|
|
|
|
let file = new File([audioBlob], "audio.mp3",{type:"audio/mpeg"});
|
|
|
|
|
|
|
|
let container = new DataTransfer();
|
|
|
|
let container = new DataTransfer();
|
|
|
|
container.items.add(file);
|
|
|
|
container.items.add(file);
|
|
|
|
document.getElementById("uploadedFile").files = container.files;
|
|
|
|
document.getElementById("uploadedFile").files = container.files;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
audio = new Audio(audioUrl);
|
|
|
|
audio = new Audio(audioUrl);
|
|
|
|
audio.addEventListener("ended", function(){
|
|
|
|
audio.addEventListener("ended", function(){
|
|
|
|
audio.currentTime = 0;
|
|
|
|
audio.currentTime = 0;
|
|
|
@ -116,25 +149,55 @@ function record_audio(){
|
|
|
|
var duration = audio.duration;
|
|
|
|
var duration = audio.duration;
|
|
|
|
$('.progress_bar').stop(true,true).animate({'width':(currentTime +.25)/duration*100+'%'},0,'linear');
|
|
|
|
$('.progress_bar').stop(true,true).animate({'width':(currentTime +.25)/duration*100+'%'},0,'linear');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
document.getElementById('play_btn').style.display = 'block'
|
|
|
|
document.getElementById('play_btn').style.display = 'block'
|
|
|
|
document.getElementById('redo_btn').style.display = 'block'
|
|
|
|
document.getElementById('redo_btn').style.display = 'block'
|
|
|
|
document.getElementById('stop_btn').style.display = 'none'
|
|
|
|
document.getElementById('stop_btn').style.display = 'none'
|
|
|
|
document.getElementById("record_btn").innerHTML = "recording…";
|
|
|
|
document.getElementById("record_btn").innerHTML = "recording…";
|
|
|
|
document.getElementById('record_btn').style.display = 'none'
|
|
|
|
document.getElementById('record_btn').style.display = 'none'
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function stop_audio(){
|
|
|
|
|
|
|
|
if(state == "recording"){
|
|
|
|
|
|
|
|
clearInterval(seconds_int);
|
|
|
|
|
|
|
|
state = "done";
|
|
|
|
|
|
|
|
recorder.stop().getMp3().then(([buffer, blob]) => {
|
|
|
|
|
|
|
|
console.log(buffer, blob);
|
|
|
|
|
|
|
|
const file = new File(buffer, 'music.mp3', {
|
|
|
|
|
|
|
|
type: blob.type,
|
|
|
|
|
|
|
|
lastModified: Date.now()
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
const li = document.createElement('li');
|
|
|
|
stop_audio()
|
|
|
|
var audioUrl = URL.createObjectURL(file)
|
|
|
|
}, 1000 * 60);
|
|
|
|
// const player = new Audio(audioUrl);
|
|
|
|
|
|
|
|
// player.controls = true;
|
|
|
|
|
|
|
|
// li.appendChild(player);
|
|
|
|
|
|
|
|
// document.querySelector('#playlist').appendChild(li);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let container = new DataTransfer();
|
|
|
|
|
|
|
|
container.items.add(file);
|
|
|
|
|
|
|
|
document.getElementById("uploadedFile").files = container.files;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
audio = new Audio(audioUrl);
|
|
|
|
|
|
|
|
audio.addEventListener("ended", function(){
|
|
|
|
|
|
|
|
audio.currentTime = 0;
|
|
|
|
|
|
|
|
document.getElementById("play_btn").innerHTML = '<span class="icon_p"></span>play'
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
audio.addEventListener("timeupdate", function() {
|
|
|
|
}
|
|
|
|
var currentTime = audio.currentTime;
|
|
|
|
|
|
|
|
var duration = audio.duration;
|
|
|
|
|
|
|
|
$('.progress_bar').stop(true,true).animate({'width':(currentTime +.25)/duration*100+'%'},0,'linear');
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
document.getElementById('play_btn').style.display = 'block'
|
|
|
|
|
|
|
|
document.getElementById('redo_btn').style.display = 'block'
|
|
|
|
|
|
|
|
document.getElementById('stop_btn').style.display = 'none'
|
|
|
|
|
|
|
|
document.getElementById("record_btn").innerHTML = "recording…";
|
|
|
|
|
|
|
|
document.getElementById('record_btn').style.display = 'none'
|
|
|
|
|
|
|
|
|
|
|
|
function stop_audio(){
|
|
|
|
}).catch((e) => {
|
|
|
|
clearInterval(seconds_int);
|
|
|
|
console.error(e);
|
|
|
|
mediaRecorder.stop();
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function redo_audio(){
|
|
|
|
function redo_audio(){
|
|
|
|