2021-04-07 12:35:25 +02:00
< ? php
ini_set ( 'display_errors' , 1 );
ini_set ( 'display_startup_errors' , 1 );
error_reporting ( E_ALL );
session_start ();
$root = realpath ( $_SERVER [ " DOCUMENT_ROOT " ]);
$version = " 1.0 " ;
?>
<! DOCTYPE html >
< html lang = " en " >
< head >
< meta charset = " UTF-8 " >
< meta http - equiv = " X-UA-Compatible " content = " IE=edge " >
< meta name = " viewport " content = " width=device-width, initial-scale=1.0 " >
< title > Larynx | Chiro - Canto </ title >
< link rel = " stylesheet " type = " text/css " href = " /styles/style.css " >
2021-04-18 16:59:01 +02:00
< link rel = " import " href = " /scripts/bower_components/polymer/polymer.html " >
< link rel = " import " href = " ./g-spectrogram-controls.html " >
< link rel = " import " href = " ./g-oscillator.html " >
2021-04-07 12:35:25 +02:00
</ head >
2021-04-16 19:14:52 +02:00
< ? php
include ( " $root /analytics/owa.php " );
include ( " $root /analytics/matomo.php " );
?>
2021-04-07 12:35:25 +02:00
< body >
< ? php include ( " $root /menu.php " ); ?>
< ? php include ( " $root /header.php " ); ?>
< section >
< h2 > Larynx </ h2 >
< p > A web tool for bat sound analysis </ p >
2021-04-09 14:29:00 +02:00
< a href = " #larynx " >
< div class = " arrow bounce " ></ div >
</ a >
2021-04-07 12:35:25 +02:00
</ section >
< div id = " larynx " >
< h2 > Larynx v < ? = $version ?> </h2>
2021-04-18 16:59:01 +02:00
< ? php
require " $root /database/credentials.php " ;
// Connect the database
try {
$db = new PDO ( " mysql:host= $host ;dbname= $database ;charset=utf8 " ,
$user ,
$password ,
array ( PDO :: ATTR_ERRMODE => PDO :: ERRMODE_EXCEPTION
));
} catch ( Exception $e ) {
die ( " Error : " . $e -> getMessage ());
}
if ( isset ( $_GET [ 'record' ])) {
$req = $db -> prepare ( 'SELECT id, recordist_name, file_name, license, species, sound_type, date, time FROM `records` WHERE id=:id' );
$req -> execute ( array (
" id " => $_GET [ 'record' ]
));
} else {
$req = $db -> prepare ( 'SELECT id, recordist_name, file_name, license, species, sound_type, date, time FROM `records` ORDER BY date DESC, time DESC LIMIT 1' );
$req -> execute ();
}
if ( $data = $req -> fetch ()) {
// print_r($data);
?>
< audio src = " <?= " / storage / records / " . $data['file_name'] ?> " id = " audio " controls ></ audio >
2021-04-07 12:35:25 +02:00
< div class = " spectrogram " >
< div id = " waveform " ></ div >
< div id = " wave-spectrogram " >
<!-- < canvas id = " spectrogram " ></ canvas > -->
</ div >
< div class = " container row " >
< div class = " measures " >
T :
< span id = " cursor-time " ></ span >
2021-04-09 14:29:00 +02:00
s F :
2021-04-07 12:35:25 +02:00
< span id = " cursor-frequency " ></ span >
kHz
</ div >
< div class = " controls " >
< input type = " button " name = " play " value = " play " id = " play " >
< input type = " button " value = " pause " id = " pause " >
< input type = " button " value = " restart " id = " restart " >
</ div >
</ div >
< p class = " license " >< ? = $data [ 'license' ] ?> <?=$data['recordist_name']?></p>
2021-04-09 14:29:00 +02:00
< div class = " settings " >
< input type = " checkbox " name = " exp_x10 " id = " exp_x10 " >
< label for = " exp_x10 " > exp x10 </ label >
</ div >
2021-04-07 12:35:25 +02:00
</ div >
</ div >
< ? php include ( " $root /footer.php " ); ?>
</ body >
< script src = " /scripts/script.js " ></ script >
< script src = " https://unpkg.com/wavesurfer.js " ></ script >
< script src = " https://unpkg.com/wavesurfer.js/dist/plugin/wavesurfer.spectrogram.min.js " type = " text/javascript " ></ script >
< script src = " https://cdnjs.cloudflare.com/ajax/libs/p5.js/0.5.16/p5.js " ></ script >
< script src = " https://cdnjs.cloudflare.com/ajax/libs/p5.js/0.5.16/addons/p5.sound.js " ></ script >
2021-04-19 20:34:09 +02:00
< script src = " scripts/spectro.js " ></ script >
2021-04-15 12:29:53 +02:00
<!-- < script src = " scripts/piano.js " ></ script > -->
2021-04-18 16:59:01 +02:00
</ html >
< ? php
} else {
$_SESSION [ 'error_msg' ] = " Error: Can't retrieve audio from database in Larynx " ;
header ( 'Location: /' );
}
?>