Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 06.04.2010, 01:00
Аватар для Paguo-86PK
Профессор
Отправить личное сообщение для Paguo-86PK Посмотреть профиль Найти все сообщения от Paguo-86PK
 
Регистрация: 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. Причина: Ссылки поправил
Ответить с цитированием
  #2 (permalink)  
Старый 06.04.2010, 08:14
Отправить личное сообщение для Octane Посмотреть профиль Найти все сообщения от Octane  
Регистрация: 10.07.2008
Сообщений: 3,873

<audio>
Ответить с цитированием
  #3 (permalink)  
Старый 06.04.2010, 10:46
Аватар для subzey
Пионэр
Отправить личное сообщение для subzey Посмотреть профиль Найти все сообщения от subzey
 
Регистрация: 16.11.2009
Сообщений: 1,322

Хороший вопрос, однако!

К сожалению (или к счастью?), html рассчитан на страницы. Ну, как в газете или журнале. Голосовой браузер прочитает Вам этот журнал. Какой-нибудь там проектор - покажет презентацию на его основе.
Но страницы останутся страницами.

Мне попадалось приложение на флеше, которое без посторонней помощи разбирало формат mod, транслировало его в wav, а затем воспроизводило. А, ведь, формат этот куда сложнее, чем midi!
Ответить с цитированием
  #4 (permalink)  
Старый 11.04.2010, 05:26
Аватар для Paguo-86PK
Профессор
Отправить личное сообщение для Paguo-86PK Посмотреть профиль Найти все сообщения от Paguo-86PK
 
Регистрация: 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
Ответить с цитированием
  #5 (permalink)  
Старый 11.04.2010, 05:30
Аватар для Aetae
Тлен
Отправить личное сообщение для Aetae Посмотреть профиль Найти все сообщения от Aetae
 
Регистрация: 02.01.2010
Сообщений: 6,584

Ну ие не понимает 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.
Ответить с цитированием
  #6 (permalink)  
Старый 12.04.2010, 03:56
Аватар для Paguo-86PK
Профессор
Отправить личное сообщение для Paguo-86PK Посмотреть профиль Найти все сообщения от Paguo-86PK
 
Регистрация: 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. Причина: Опубликовал кросс-браузерный метод
Ответить с цитированием
  #7 (permalink)  
Старый 22.04.2010, 00:40
Аватар для Paguo-86PK
Профессор
Отправить личное сообщение для Paguo-86PK Посмотреть профиль Найти все сообщения от Paguo-86PK
 
Регистрация: 16.09.2009
Сообщений: 253

О программистах думают вообще
На днях наткнулся на MusicXML и ужаснулся!
Это к чему же всё идёт? Скоро и exe-файлы будут в XML с чудовищной избыточностью!
На описание одной ноты целое древо из в 33 строки!
Тогда как раньше, как я уже писал, было проще. Почему не могут лишь доработать и обогатить, чем всё в XML пихать?

Я вот подумал. Этот Audio() в HTML-5 поддерживает только MP3 и никакие мидии не признаёт. Но это не главное... Ведь Audio объект включили в HTML из уже готовой и достаточно зрелой реализации некоего браузера. Не с потолка W3C же берёт всё, типо "да будет тэг! и стал тэг"...

А нету ли браузера с каким-либо плагином, хоть в любимом вашем Flash'е, где звуком можно оперировать в реальном масштабе времени, как в Си скажем. Открыть звуковое устройство, создать миди-поток и управлять в нём включением/выключением нот на лету, чтобы пользователь мог двигать мышью по струнам на экране, а они тут же брынчали. Ну вы поняли...

Вот с саnvаs'ом дело куда лучше: Интерактивность практически полная. А вот со звуком. Ни устройство не открыть, ничего. Воспроизвожу туда, не знаю куда. Даже не знаю, а воспроизводится ли вообще?
Ответить с цитированием
  #8 (permalink)  
Старый 01.12.2010, 00:19
Аватар для Paguo-86PK
Профессор
Отправить личное сообщение для Paguo-86PK Посмотреть профиль Найти все сообщения от Paguo-86PK
 
Регистрация: 16.09.2009
Сообщений: 253

swf wav-form генерация
Сообщение от subzey Посмотреть сообщение
Хороший вопрос, однако!
...
Мне попадалось приложение на флеше, которое без посторонней помощи разбирало формат mod, транслировало его в wav, а затем воспроизводило. А, ведь, формат этот куда сложнее, чем midi!
Может Вы ошибаетесь?
Даже простой wav-писк не могу сгенерировать в Flash, так-как chr(0) в строку не вставляется. А ведь это ключевой символ!
Гуглил, проблема очень насущная...
Ответить с цитированием
  #9 (permalink)  
Старый 01.12.2010, 08:32
х.з
Посмотреть профиль Найти все сообщения от dmitriymar
 
Регистрация: 21.11.2010
Сообщений: 4,588

Сообщение от Paguo-86PK
Я вот подумал. Этот Audio() в HTML-5 поддерживает только MP3 и никакие мидии не признаёт. Но это не главное... Ведь Audio объект включили в HTML из уже готовой и достаточно зрелой реализации некоего браузера. Не с потолка W3C же берёт всё, типо "да будет тэг! и стал тэг"...

почитай спецификацию к аудио -а то тут такой сыр-бор развёл.видно что ничего о нём не читал.
напомнило театр одного актёра.....

Последний раз редактировалось dmitriymar, 01.12.2010 в 08:35.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Переменные в HTML ibcmsm Общие вопросы Javascript 7 27.09.2011 14:35
Jquery манипулятор html JIEXA jQuery 6 18.03.2010 21:55
Динамические html элементы sky Элементы интерфейса 2 07.03.2010 11:58
Как сохранить динамически генерируемую html страничку? Антоныч Javascript под браузер 1 01.03.2010 17:03
Неверный результат в AJAX с получением HTML Raynor AJAX и COMET 3 17.12.2008 18:38