Модераторы: Sardar, Aliance
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Математика в HTML, Пишу скрипт нужны идеи 
:(
    Опции темы
Rimch
Дата 9.6.2009, 13:57 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 43
Регистрация: 23.6.2007

Репутация: 1
Всего: 3



Уважаемые участники форума, на днях начал писать скрипт для верстки математических формул как в ТеХ.

На данный момент реализовано 2 вида формул, строчные и блочные:
  • Строчные формулы отображаются как привычные формулы в LaTeXе через $формула$
  • Блочные \[ формула\] - автоматически нумеруются (можно продумать ссылки).
Также реализована возможность возведения в степень ^, и нижний индекс _.
Еще имеется возможность написания дробей \frac{числитель}{знаменатель}

С работой скрипта можно ознакомиться http://sspa.bashtel.ru/Math/

Хочу посоветоваться с вами, как реализовать большие скобки и квадратные корни?

Да конечно можно не мучиться и пользоваться MathML, но он не работает в Opera, а для IE надо ставить плагин.
PM MAIL ICQ   Вверх
ksnk
Дата 9.6.2009, 18:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прохожий
****


Профиль
Группа: Комодератор
Сообщений: 6720
Регистрация: 13.4.2007
Где: СПб

Репутация: 2
Всего: 379



Возможно, если переделать верстку в div'ную, можно будет копировать полученные формулы прямо в Ворд. Пока такое не получается.

Еще, в Хроме куски формул с широким делением выше основного текста. А так - достаточно прилично выглядит уже сейчас!
Цитата(Rimch @  9.6.2009,  13:57 Найти цитируемый пост)
Хочу посоветоваться с вами, как реализовать большие скобки и квадратные корни?

В каком смысле? Как их нарисовать? или каким образом закодировать в html? Для html'я - обычные способы для рисования рамок - комплект объемлющих div'ов, формирующий корень или скобки , а внутри уже собственно формула.


--------------------
Человеку свойственно ошибаться, программисту свойственно ошибаться профессионально ! user posted image
PM MAIL WWW Skype   Вверх
solenko
Дата 9.6.2009, 18:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1473
Регистрация: 15.1.2006
Где: Украина

Репутация: нет
Всего: 67



Ссылка в тему http://www.vanav.com.ua/soft/unimath/


--------------------
Ла-ла-ла-ла
Заметьте, нет официального подтверждения, что это не просто четыре слога.
PM MAIL WWW ICQ Skype   Вверх
Rimch
Дата 9.6.2009, 19:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 43
Регистрация: 23.6.2007

Репутация: 1
Всего: 3



ksnk
Цитата(ksnk @  9.6.2009,  18:09 Найти цитируемый пост)
Еще, в Хроме куски формул с широким делением выше основного текста.

Эта проблема мне известна, тут дело в реализации Хромом свойства vertical-align у строчных элементов. Пока решения данной проблемы не нашел.

solenko, спасибо за ссылку
PM MAIL ICQ   Вверх
Rimch
Дата 9.6.2009, 20:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 43
Регистрация: 23.6.2007

Репутация: 1
Всего: 3



 Немного переписал скрипт. http://sspa.bashtel.ru/Math/
Возможности:
  • Возведение в степень a^b или  a^{b+c}
  • Нижний индекс a_b или a_{b+c}
  • Дробь \frac{числитель}{знаменатель} или \frac[em]{числитель}{знаменатель}, em - вертикальное относительное смещение 
  • Квадратный корень \sqrt{a} или \sqrt[em]{a}
  • Большие скобки 
    \lbig  == (          
    \rbig  == }
    \lvbig == {          
    \rvbig == }
    \l. == пусто
    \r. == пусто
  • Знаки \(sum|prod|int|cap|cup)\from{нижний предел}\to{верхний предел}
  • Пределы \(lim|max|min)\from{нижний предел}\to{верхний предел}

При печати опера и ослик ведут себя не очень хорошо по отношению к скобкам и рабикалам

Это сообщение отредактировал(а) Rimch - 16.6.2009, 20:16
PM MAIL ICQ   Вверх
Rimch
Дата 18.6.2010, 09:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 43
Регистрация: 23.6.2007

Репутация: 1
Всего: 3



В течении учебного года со студентами написали учебник по ЧМ с использование tex.js.
Вот ссылка на небольшую часть учебника  http://sspa.bashtel.ru/Math/

Это сообщение отредактировал(а) Rimch - 18.6.2010, 09:46
PM MAIL ICQ   Вверх
ksnk
Дата 18.6.2010, 18:24 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прохожий
****


Профиль
Группа: Комодератор
Сообщений: 6720
Регистрация: 13.4.2007
Где: СПб

Репутация: 2
Всего: 379



Сейчас все это выглядит уже вполне разумно и кроссбраузерно. 
imho, сейчас это,  за исключением пары опечаток в комментариях программы ;), неплохой инструмент для генерации математических текстов "с нуля". Кстати. Символ суммы не рисуется, а сделан символом. А что будет , если нужно "просуммировать" сложную многоэтажную формулу? Размер шрифта меняется?
И вообще, как-то слишком просто выглядит скрипт, надо будет повнимательнее поковырять его ;)

Насколько я понимаю, с родным тех'ом не особенно совместимы формулы? Только на уровне некоторых общих слов и принципов построения. Так что просто перегнать статью, написаную в техе (хотя бы формулы) запросто не удастся? Хотя это был бы очевидный следующий шаг в развитии проекта. Так как массово привлечь народ такой математикой (и скриптом), можно напечатав массу статей. А масса статей использует Тех для формул... если реализация всего многообразия теховских конструкций слишком тяжела для скрипта, то можно было бы сделать несложный конвертер в имеющийся формат - текст конвертируем с html, формулы - в формулы...


--------------------
Человеку свойственно ошибаться, программисту свойственно ошибаться профессионально ! user posted image
PM MAIL WWW Skype   Вверх
bars80080
Дата 18.6.2010, 19:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор воюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12004
Регистрация: 5.12.2007
Где: Königsberg

Репутация: нет
Всего: 315



Цитата(Rimch @  18.6.2010,  09:45 Найти цитируемый пост)
написали учебник по ЧМ

оказывается, это численные методы. никогда бы не подумал.
первая мысль - чемпионат мира, вторая - частотная модуляция

PM MAIL   Вверх
Rimch
Дата 18.1.2011, 13:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 43
Регистрация: 23.6.2007

Репутация: 1
Всего: 3



Возвращаясь к теме математические формулы в HTML.
Вот пример работы немного подправленного мною WYSIWYGа -  NicEdit.js  NicTexEdit, в котором можно набирать формулы в формате TeX и приводить к привычному виду кликая user posted image.

Остальные WYSIWYG тоже можно легко научить заменять выделенный текст на формулы, для этого в скрипте tex.js есть функция replaceSelectionFragment(), которая и делает преобразования независимо от  WYSIWYG

PM MAIL ICQ   Вверх
ksnk
Дата 18.1.2011, 17:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прохожий
****


Профиль
Группа: Комодератор
Сообщений: 6720
Регистрация: 13.4.2007
Где: СПб

Репутация: 2
Всего: 379



Некоторые замечания по программированию на JS:

Зачем нужны функции $ и $$? $$ используется один раз, а $ - ни разу (если не считать функции big, которая всегда по тексту вызывается без параметров). Если их вообще ликвидировать - интегрируемость с jQuery станет значительно прозрачнее.

Если выполнить вот такую функцию
Код

function doTexTable(str,st)
{a=st.replace(/(#|\&amp;)/ig,'</td><td class="eq">');
...
}

то у объекта window появится новое свойство .a с достаточно специфическим значением, а если выполнить вот такую
Код

function doTexTable(str,st)
{var a=st.replace(/(#|\&amp;)/ig,'</td><td class="eq">');
...

то такого свойства не появится.

Раз уж все равно юзера обязывают подключить css, то использовать в тексте такие конструкции 
Код

... style="margin-right:-0.25ex;display:inline;font-family:arial;font-weight:normal;font-size:150%;vertical-align:-50%;" ...

не очень красиво.

Это сообщение отредактировал(а) ksnk - 18.1.2011, 17:01


--------------------
Человеку свойственно ошибаться, программисту свойственно ошибаться профессионально ! user posted image
PM MAIL WWW Skype   Вверх
Rimch
Дата 18.1.2011, 17:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 43
Регистрация: 23.6.2007

Репутация: 1
Всего: 3



ksnk, спасибо за замечания.
Учтем и исправим. smile , завтра выложу обновлённую версию.
PM MAIL ICQ   Вверх
NormIridium
Дата 3.3.2011, 08:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 30.6.2008

Репутация: нет
Всего: нет



Rimch, жаль цитирование формул нет хорошего... я бы тогда это дело в движок форума встроил бы.

А еще я не люблю когда привязывают к JQ скрипты. 

Это сообщение отредактировал(а) NormIridium - 3.3.2011, 08:28
PM MAIL   Вверх
NormIridium
Дата 3.3.2011, 09:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 15
Регистрация: 30.6.2008

Репутация: нет
Всего: нет



Тема: http://sovety.blogspot.com/2009/03/latex-f...and-on-web.html

Вот себе забрал скриптик: http://www.math.union.edu/~dpvc/jsMath/dow...Math-fonts.html

Это сообщение отредактировал(а) NormIridium - 3.3.2011, 09:41
PM MAIL   Вверх
Google
  Дата 18.11.2017, 03:37 (ссылка)  





  Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Здесь публикуют скрипты, которые уже проверены в обсуждениях других тем (при этом полезно поставить ссылки на все смежные обсуждения) или переносятся кем-либо из модераторов по просьбе участников, если видно, что в результате обсуждения темы был написан полезный или интересный скрипт. Третий возможный вариант - участник форума публикует скрипт, заведомо известный как полезный и эффективный, для, возможно, небольшой доработки и обсуждения.
 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | JavaScript: Наши скрипты | Следующая тема »


 




[ Время генерации скрипта: 0.0907 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.