06.04.2010, 01:00
|
|
Профессор
|
|
Регистрация: 16.09.2009
Сообщений: 253
|
|
HTML партитуры
ХРИСТОС ВОСКРЕСЕ!
Странно как-то. Вот смотришь, всё так развивается! Уже и 3D-онлайн на страница сколько лет, да потихоньку переливается из VRML и всяких x3D в простые JS-скрипты с саnvаs-тэгом, о чём я недавно всё тут прожужжал...
А вот со звуком, застой какой-то. Ни тэга нормального, ни средств приличных...
Ну можно там миди подключить, mp3 к странице. Но динамически генерировать - никак!
SWF скажите? Но так давайте ещё предложите голую html-страницу сделать и тупо весь интерактивный динамичный интерфейс во флэш сделать!
Мне это никак не подходит...
На днях закончил для code.google ассемблер. Ещё с прошлого года писал. Установил Chrome, FireFox, Opera - с потом и терпением везде заставил работать. А вот в IE - глючит. Если раньше я писал только под IE, то за год - разучился. Даже регулярные выражения еле нашёл где глючат. Везде работают, а в IE - скобки лишние пришлось добавить...
И вот. Товарищи!
Что за дела со звуком? Будет ли алгоритмическая поддержка звука в HTML с динамической генерацией в JS в ближайщее десятилетие? Что-то всё зациклилось на визуальных наворотах.
Когда в Си я изучал DirectX, звук одолеть так и не смог. Писк - визг получал, а дальше. Сцена OpenGL легче давалась. Игрушки делал. А звук...
Используя Bass/FMod библиотеки чувствуешь себя легче, как и с OpenAL. Но без них, тёмный лес!
P.S.: Был ещё некий SOL - один из вариантов цифрового представления музыки до появления трэкерной и стандарта MIDI. Партитуры выглядили как листинг языка программирования и имели соответственный синтаксис. Вот часть этого архива:
"HARMONIOUS BLACKSMITH" G.F. HANDEL
"BOURREE" G.F. HANDEL
"SARABANDE" JOHANN JAKOB DE NEUFVILLE
...
Файлы с расширением .asc можно просмотреть и писать прямо Блокнотом.
В СССР музыкальный интерпретатор таких партитур был адаптирован под популярный в те годы радиолюбительский компьютер РАДИО-86РК в программе Музыкальная система.
С помощью эмулятора мне удалось прослушать практически все композиции с того сайта, а их - несколько десятков! Увы, так легко загружать их в эмулятор мне не удалось и пришлось написать JavaScript для адаптации оригинальных партитур под формат листингов советского ПК. Захватывает то, что партитуры могут длиться до 10 минут! И это без привычного нам визуального набора нот. Как можно видеть, практически все партитуры датируются концом 70-ых.
Увы, но мне не известно ничего об отечественных партитурах.Сам я пытался написать на Си интерпретатор этих листингов. Но дальше проигрывания простых рядов нот не дошёл, так-как в конец запутался с пониманием всяких музыкальных терминов, как триоль или нота с точкой.
Последний раз редактировалось Paguo-86PK, 06.04.2010 в 01:18.
Причина: Ссылки поправил
|
|
06.04.2010, 08:14
|
|
|
Регистрация: 10.07.2008
Сообщений: 3,873
|
|
<audio>
|
|
06.04.2010, 10:46
|
|
Пионэр
|
|
Регистрация: 16.11.2009
Сообщений: 1,322
|
|
Хороший вопрос, однако!
К сожалению (или к счастью?), html рассчитан на страницы. Ну, как в газете или журнале. Голосовой браузер прочитает Вам этот журнал. Какой-нибудь там проектор - покажет презентацию на его основе.
Но страницы останутся страницами.
Мне попадалось приложение на флеше, которое без посторонней помощи разбирало формат mod, транслировало его в wav, а затем воспроизводило. А, ведь, формат этот куда сложнее, чем midi!
|
|
11.04.2010, 05:26
|
|
Профессор
|
|
Регистрация: 16.09.2009
Сообщений: 253
|
|
Что за баги?
Хм. Написал скрипта два. Один из текста генерирует midi-поток и воспроизводится object-тэгом в FF и Opera. А вот в IE ну никак не работает, и в Chrome тоже. Но если линк на файл - звучит. Даже такой мизерный код не работает.
<html><head><title>sound</title>
</head><body><bgsound src="data:audio/mid;base64,TVRoZAAAAAYAAQADAGRNVHJrAAAAHwDAUACQUH9ggFAAAJBSf2CAUgAAkFR/YIBUAAD/LwBNVHJrAAAAEADAUQCQAACCIIAAAAD/LwBNVHJrAAAAEADAUgCQAACCIIAAAAD/LwAgIA=="/>
-</body>
Звук слышен лишь в Opera и FF.
В чём же дело?
А вот Audio-тэг понимает миди? В виде data:audio-mid нужно чтобы.
И с new Audio() никак не разобрался
Вот эта морзянка morseMid.zip
|
|
11.04.2010, 05:30
|
|
Тлен
|
|
Регистрация: 02.01.2010
Сообщений: 6,577
|
|
Ну ие не понимает data-url, а что с хромом хз, может он принципиально против звука)
Простой эксперемент: вводим тот же самый
data:audio/mid;base64,TVRoZAAAAAYAAQADAGRNVHJrAAAAHwDAUACQUH9 ggFAAAJBSf2CAUgAAkFR/YIBUAAD/LwBNVHJrAAAAEADAUQCQAACCIIAAAAD/LwBNVHJrAAAAEADAUgCQAACCIIAAAAD/LwAgIA==
в строку адреса и жмём энтер:
1.FF предложил сохранить.
2.Оpera воспроизвела(0_о).
3.Chrome сбросил.
4.IE6 не понял.
5. ....
6. profit!
Теперь попробуем картинку:
 Otka5AAAABlBMVEUAAAD///+l2Z/dAAAA/ElEQVR4Xu3UoY3EMBRFUY8WBKYEl5LSMqWlFJdgaBDFq3EJ+8i sdA748KKnX74BAAAAAAAAAAAAAAAAAMzP2Uap86P/74DAcrYwMMPAa15Z4Ge+00DJAlsa2J8wUO80MMLAkQbOHgZmSw NXFnhlgbXkLLDNEgaeMLCngXqHgWOkgR4GzvanwLICMwqsIaaB dxb4mSULbGlgf9LAXbId1BEGjjRw9jTQwsC8ssArC6yXmgZKFt ieMLCngXqngREGjh4GzjQwWxq4osB6qUlgDTEKbHHgCQP7HQbq CANHHOhh4GxhYF5pYBnfFBDIAQAAAAAAAAAAAAAAAADwCwgdT2 zNcD4sAAAAAElFTkSuQmCC
Везде кроме ie6 открывается.
Последующие исследование показали: chrome не желает понимать нетепичные data, т.е. text/javascript, text/css, image/png итд - понимает, а text/txt например - уже сбрасывает.
Последний раз редактировалось Aetae, 11.04.2010 в 05:46.
|
|
12.04.2010, 03:56
|
|
Профессор
|
|
Регистрация: 16.09.2009
Сообщений: 253
|
|
Спасибо! А есть ли более-менее кросс-браузерный метод?
Вот написал какрас скрипт, который рендерит те самые треки в midi-поток. И всё отлично работает Но только в Mozilla-FF и в Opera.
Как я понимаю, в IE эта проблема решается довольно легко с помощью ActiveX файловой системы: Сохраняем на диск C:/sol2midi.mid и передаём ссылку. Пока не попробовал, но сработать должно.
Это уже 3 браузера! А вот как с Chrome быть..?
Эм-ммм, в Chrome используя new Audio удалось воспроизвести лишь mp3. Ни mid, ни rmi не воспроизводятся, а wav выдаёт ошибку! Но, вот написал более-менее кросс-браузерный метод.
Работает в Mozilla-FF и Opera, а также и в IE с использованием ActiveX файловой системы.
Если проверите в IE, отпишите, у кого работает/нет?
<html><head><title>MIDI-song for FireFox / IE / Opera by Paguo-86PK from javascript.ru</title>
<script language="JavaScript">
String.prototype.toBase64 =
function (header) {
// Encodes data with MIME base64
// + original by: Tyler Akins (http://rumkin.com)
// + improved by: Bayron Guevara
var b64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
var enc = "", i = 0, o1, o2, o3, h1, h2, h3, h4, bits;
do { // pack three octets into four hexets
o1 = this.charCodeAt(i ++);
o2 = this.charCodeAt(i ++);
o3 = this.charCodeAt(i ++);
bits = o1 << 16 | o2 << 8 | o3;
h1 = bits >> 18 & 0x3f;
h2 = bits >> 12 & 0x3f;
h3 = bits >> 6 & 0x3f;
h4 = bits & 0x3f;
// use hexets to index into b64, and append result to encoded string
enc += b64.charAt(h1) + b64.charAt(h2) + b64.charAt(h3) + b64.charAt(h4);
} while (i < this.length);
switch(this.length % 3) {
case 1:
enc = enc.slice(0, -2) + "==";
break;
case 2:
enc = enc.slice(0, -1) + "=";
break;
}
return header + ";base64," + enc;
}
var
player = ( //////////////////////// Cross-browser midi-play method are here
function (fileName) {
try { //////////////////////////// Try to IE way
this.fso = new ActiveXObject("Scripting.FileSystemObject");
this.name = fileName;
this.play = function(stream) { // Flexable function for play sound
Player = document.getElementById("Media");
Player.FileName = ""; // document.getElementsByTagName("bgsound")[0].src="";
try { ////////////////////////// Save stream to HDD and play it
File = this.fso.CreateTextFile(this.name);
Enc = "\x00\x01\x02\x03\x04\x05\x06\x07\x08\x09\x0A\x0B\x0C\x0D\x0E\x0F"
+ "\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1A\x1B\x1C\x1D\x1E\x1F"
+ "\x20\x21\x22\x23\x24\x25\x26\x27\x28\x29\x2A\x2B\x2C\x2D\x2E\x2F"
+ "\x30\x31\x32\x33\x34\x35\x36\x37\x38\x39\x3A\x3B\x3C\x3D\x3E\x3F"
+ "\x40\x41\x42\x43\x44\x45\x46\x47\x48\x49\x4A\x4B\x4C\x4D\x4E\x4F"
+ "\x50\x51\x52\x53\x54\x55\x56\x57\x58\x59\x5A\x5B\x5C\x5D\x5E\x5F"
+ "\x60\x61\x62\x63\x64\x65\x66\x67\x68\x69\x6A\x6B\x6C\x6D\x6E\x6F"
+ "\x70\x71\x72\x73\x74\x75\x76\x77\x78\x79\x7A\x7B\x7C\x7D\x7E\x7F"
+ "\u0402\u0403\u201A\u0453\u201E\u2026\u2020\u2021\u20AC\u2030\u0409"
+ "\u2039\u040A\u040C\u040B\u040F\u0452\u2018\u2019\u201C\u201D\u2022"
+ "\u2013\u2014\x98\u2122\u0459\u203A\u045A\u045C\u045B\u045F\xA0\u040E"
+ "\u045E\u0408\xA4\u0490\xA6\xA7\u0401\xA9\u0404\xAB\xAC\xAD\xAE\u0407"
+ "\xB0\xB1\u0406\u0456\u0491\xB5\xB6\xB7\u0451\u2116\u0454\xBB\u0458"
+ "\u0405\u0455\u0457\u0410\u0411\u0412\u0413\u0414\u0415\u0416\u0417"
+ "\u0418\u0419\u041A\u041B\u041C\u041D\u041E\u041F\u0420\u0421\u0422"
+ "\u0423\u0424\u0425\u0426\u0427\u0428\u0429\u042A\u042B\u042C\u042D"
+ "\u042E\u042F\u0430\u0431\u0432\u0433\u0434\u0435\u0436\u0437\u0438"
+ "\u0439\u043A\u043B\u043C\u043D\u043E\u043F\u0440\u0441\u0442\u0443"
+ "\u0444\u0445\u0446\u0447\u0448\u0449\u044A\u044B\u044C\u044D\u044E\u044F";
for(i = 0; i < stream.length; ++ i)
File.write(Enc.charAt(stream.charCodeAt(i)));
File.close();
Player.FileName = this.name; // document.getElementsByTagName("bgsound")[0].src = this.name;
} catch(e) {
alert("Sorry...\r\nCan't played");
}
}
document.writeln("<object id='Media' classid='CLSID:22d6f312-b0f6-11d0-94ab-0080c74c7e95'"
+" width='200' height='40'>");
document.writeln("<param name='Filename' value=''>");
document.writeln("<param name='AutoStart' value='True'>");
document.writeln("<param name='AutoRewind' value='True'>");
document.writeln("<param name='ShowDisplay' value='False'>");
document.writeln("<param name='ShowControls' value='True'>");
document.writeln("<param name='ShowStatusBar' value='False'>");
document.writeln("</object><br>");
} catch(e) { ///////////////////// All other browsers (Mozilla FireFox / Opera)
this.play = function(stream) {
Player = document.getElementById("Media");
Player.data = "";
Player.data = stream.toBase64("data:audio/mid");
}
document.writeln("<object id='Media' type='audio/mid' width='200' height='40' autoplay>");
document.writeln("<param name='AutoStart' value='True'>");
document.writeln("<param name='AutoRewind' value='True'>");
document.writeln("<param name='ShowDisplay' value='False'>");
document.writeln("<param name='ShowControls' value='True'>");
document.writeln("<param name='ShowStatusBar' value='False'>");
document.writeln("</object><br>");
}
return this;
})("C:/_base64_.mid"); //////////// <-- Choice to IE-generated file at here
var
song = "\x4D\x54\x68\x64\x00\x00\x00\x06\x00\x01\x00\x03\x7F\xFF\x4D\x54"
+ "\x72\x6B\x00\x00\x00\x53\x00\xC0\x50\x00\x90\x00\x00\x82\x9D\x60"
+ "\x80\x00\x00\x00\x90\x37\x7F\xC7\x38\x80\x37\x00\x00\x90\x38\x7F"
+ "\xC7\x38\x80\x38\x00\x00\x90\x39\x7F\x88\xF7\x00\x80\x39\x00\x00"
+ "\x90\x00\x00\x84\xBB\x40\x80\x00\x00\x00\x90\x3A\x7F\xC7\x38\x80"
+ "\x3A\x00\x00\x90\x39\x7F\xC7\x38\x80\x39\x00\x00\x90\x3B\x7F\x88"
+ "\xF7\x00\x80\x3B\x00\x00\xFF\x2F\x00\x4D\x54\x72\x6B\x00\x00\x00"
+ "\x11\x00\xC0\x51\x00\x90\x00\x00\x9A\xE5\x00\x80\x00\x00\x00\xFF"
+ "\x2F\x00\x4D\x54\x72\x6B\x00\x00\x00\x11\x00\xC0\x52\x00\x90\x00"
+ "\x00\x9A\xE5\x00\x80\x00\x00\x00\xFF\x2F\x00\x20\x20";
</script>
</head>
<body>
<button onclick='player.play(song)'>Cross-browser playing test</button>
</body>
Последний раз редактировалось Paguo-86PK, 13.04.2010 в 05:22.
Причина: Опубликовал кросс-браузерный метод
|
|
22.04.2010, 00:40
|
|
Профессор
|
|
Регистрация: 16.09.2009
Сообщений: 253
|
|
О программистах думают вообще
На днях наткнулся на MusicXML и ужаснулся!
Это к чему же всё идёт? Скоро и exe-файлы будут в XML с чудовищной избыточностью!
На описание одной ноты целое древо из в 33 строки!
Тогда как раньше, как я уже писал, было проще. Почему не могут лишь доработать и обогатить, чем всё в XML пихать?
Я вот подумал. Этот Audio() в HTML-5 поддерживает только MP3 и никакие мидии не признаёт. Но это не главное... Ведь Audio объект включили в HTML из уже готовой и достаточно зрелой реализации некоего браузера. Не с потолка W3C же берёт всё, типо " да будет тэг! и стал тэг"...
А нету ли браузера с каким-либо плагином, хоть в любимом вашем Flash'е, где звуком можно оперировать в реальном масштабе времени, как в Си скажем. Открыть звуковое устройство, создать миди-поток и управлять в нём включением/выключением нот на лету, чтобы пользователь мог двигать мышью по струнам на экране, а они тут же брынчали. Ну вы поняли...
Вот с саnvаs'ом дело куда лучше: Интерактивность практически полная. А вот со звуком. Ни устройство не открыть, ничего. Воспроизвожу туда, не знаю куда. Даже не знаю, а воспроизводится ли вообще?
|
|
01.12.2010, 00:19
|
|
Профессор
|
|
Регистрация: 16.09.2009
Сообщений: 253
|
|
swf wav-form генерация
Сообщение от subzey
|
Хороший вопрос, однако!
...
Мне попадалось приложение на флеше, которое без посторонней помощи разбирало формат mod, транслировало его в wav, а затем воспроизводило. А, ведь, формат этот куда сложнее, чем midi!
|
Может Вы ошибаетесь?
Даже простой wav-писк не могу сгенерировать в Flash, так-как chr(0) в строку не вставляется. А ведь это ключевой символ!
Гуглил, проблема очень насущная...
|
|
01.12.2010, 08:32
|
х.з
|
|
Регистрация: 21.11.2010
Сообщений: 4,588
|
|
Сообщение от Paguo-86PK
|
Я вот подумал. Этот Audio() в HTML-5 поддерживает только MP3 и никакие мидии не признаёт. Но это не главное... Ведь Audio объект включили в HTML из уже готовой и достаточно зрелой реализации некоего браузера. Не с потолка W3C же берёт всё, типо "да будет тэг! и стал тэг"...
|
почитай спецификацию к аудио -а то тут такой сыр-бор развёл.видно что ничего о нём не читал.
напомнило театр одного актёра.....
Последний раз редактировалось dmitriymar, 01.12.2010 в 08:35.
|
|
|
|