Russian Qt Forum

Qt => 2D и 3D графика => Тема начата: juvf от Январь 20, 2009, 16:18



Название: Проблема с шрифтами
Отправлено: juvf от Январь 20, 2009, 16:18
Написал программу на Qt4.4.0 под FreeBSD7.0 в KDE. Установил на др. ЭВМ FreeBSD7.0, Xorg и оконный менеджер IceWM. Запустил на этой эвм свою программу - всё работает, только шрифты какие-то другие, размер не тот, быквы как-то по другому отображаются, не так как у меня на компе. Как будьто там другие шрифты используются.

Мою программу предпологается запускать под любой ос и с любым оконным менеджером (kde, gnom, icewm, iwm и тп) в том числе и под виндой. Как сделать так, чтоб не зависимо от ос и wm, и не зависимо от наличия или отсутствия того или иного шрифта в ос шрифты в моей программе оттображались одинакого? Думаю, что нужно в код программы включить нужные шрифты. Как-то это можно сделать?


Название: Re: Проблема с шрифтами
Отправлено: lit-uriy от Январь 20, 2009, 16:52
вроде в Qt нельзя конкретный шрифт определить, а только семейство. Хотя могу ошибаться.


Название: Re: Проблема с шрифтами
Отправлено: BaltikS от Январь 20, 2009, 17:37
Я б ещё глянул утилитку qtconfig  ;)


Название: Re: Проблема с шрифтами
Отправлено: Dendy от Январь 20, 2009, 17:59
Тогда только таскать шрифт вместе с программой (вариант: сделать зависимость от пакета с нужным шрифтом) и при запуске программы добавляеть его с помощью:

int QFontDatabase::addApplicationFont ( const QString & fileName )
int QFontDatabase::addApplicationFontFromData ( const QByteArray & fontData )


Название: Re: Проблема с шрифтами
Отправлено: lit-uriy от Январь 20, 2009, 18:00
2 BaltikS, относительно линя ты прав, а вот в виндовозе нет такой.


Название: Re: Проблема с шрифтами
Отправлено: Rcus от Январь 20, 2009, 18:21
А я бы вообще ничего не стал менять, ибо Qt делает все чтобы выглядеть нативно. Более чем уверен что некоторые маководы съедят заживо если вместо Lucida Grande приложение будет использовать левый шрифт. В Висте тоже лучше когда приложение использует системный шрифт Segoi UI. А под GNU/Linux Qt даже при запуске в рабочем окружении GNOME использует системные шрифты и палитру.

К чему это я... Не ломайте то, что работает :)


Название: Re: Проблема с шрифтами
Отправлено: Dendy от Январь 20, 2009, 18:40
Согласен с предыдущим оратором. Стандартные формы должны рисоваться следуя Look'n'Feel целевой системы. Тем не менее есть нестандартное рисование, результаты которого обязаны выглядеть везде одинаково. Для этого, собственно, и предусмотрен QFontDatabase.


Название: Re: Проблема с шрифтами
Отправлено: juvf от Январь 21, 2009, 12:28
Чтоб прояснить суть проблемы в прикреплении два скриншота.
 Один сделан с десктоповой машины, т.е. на которотую установленно KDE, Qt, и всяких прочий софт для комфортной работы, типа браузеры, аськи, ООО и т.п.
Второй сделан с ЭВМ на которой стоит только ос, Xorg и IceWM (оконный менеджер).

То что видно на картинке(темносерый фон) - это QScene и на ней графические элементы. Меня особо не волнует, то что меню "Help" выглядит по разному. Меня волнует, то что "ПАР-10" выглядит по разному. "ПАР-10" это QGraphicsTextItem лежащий на QScene, в котором есть текст, шрифт указан Helevetica жырный. В kde цыфра 10 какая-то маленькая, а в icewm слово ПАР какое-то маленькое и жирное. Я уже даже не цепляюсь к тому, что в ПАР даже буквы разные, например буква "А" написанна по разному. Пусть хотябы толшина и высота букв будет одинакова. А если сравнить слова "ПРИВОД", "Комплект 2", "П200", "Охрана" и т.д..... Неприятно как-то

На обоих ЭВМ установленна FreeBSD7.0. Я подозреваю, что на десктоповой машине возможно шрифт Helevetica - какойто другой. Возможно он был именён KDE или какой-нибудь оперой. Но как это можно выяснить? Где в FreeBSD лежит шрифт Helevetica? Как его можно перенести на др ЭВМ?

Но не хотелось бы тоскать за программой шрифты. Как то можно заставить QGraphicsTextItem используя один и тотже шрифт на разных ЭВМ (и даже в разных ОС) рисовать текст одинакого не смотря ни на какие настройки системы?


Название: Re: Проблема с шрифтами
Отправлено: Detonator от Январь 21, 2009, 12:47
У меня прога под виндовс, но в нужном мне месте чтобы под любыми виндами выглядело одинаково я таскаю фонт в ресурсах и отрисовываю нестандартным растеризатором (я использую комерческий DType). В основе Qt вроде используется FreeType - попробуй через него, важен полный контроль над процессом растеризации. Правда возможны серьезные проблемы если желаешь чтобы на принтере было точно как на экране.


Название: Re: Проблема с шрифтами
Отправлено: alex12 от Январь 21, 2009, 13:41
Рисование мнемосхем -- дело серьезное  ;). Думаю, что без встраивания используемого шрифта в проект, добиться одинакового отображения невозможно. Это единственное решение, которое позволит рисовать пиксель в пиксель. Тем более, что количество поддерживаемых ОС велико.

У меня, например, в одном проекте съехали шрифты при переходе с openSUSE 11.0 на 11.1.


Название: Re: Проблема с шрифтами
Отправлено: juvf от Январь 21, 2009, 16:25
Цитировать
Рисование мнемосхем -- дело серьезное
базару нет

Ну я вот тоже думаю что нужно как-то шрифт встроить в проект. Но как?

А вот еще какая мысль меня посетила: Вместе с программой (назову её скада) будет поставляться редактор мнемосхем (РМС). У диспетчера будет скада крутиться на компе в режиме киоска, например под FreeBSD. Схемы будут рисовать ИТР на другой ЭВМ. Например инженер работает под Виндой (линуксом) - не беда. Грузи РМС в винде(линуксе) и рисуй схему. Потом закидывай её диспетчеру и наслаждайся жызнью.

1) Если на проблему шрифтов положыть - но скада получится несерьёзная.
2) Если шрифт встроить в программу, то пользователи будут ограниченны в количестве шрифтов встроенных в программу. Т.е. ИТР не сможет нарисовать схему шрифтом из винды(линукса) "АляЗашибатыйШрифт".
3) Еще может как-то сделать так, чтоб все шрифты хранились в файле схемы. Только вот Qt должна прорисовывать его на любой ос одинакого, пиксель к пикселю. Но эта задача по мойму еще сложнее чем задача 2.

Думаю что нужно как-то смотреть в сторону 2. Кто-нибудь может подсказать как можно шрифты воткнуть в проект?



Название: Re: Проблема с шрифтами
Отправлено: alex12 от Январь 21, 2009, 17:57
Это же Скада! ИМХО здесь шрифты должны быть максимально читаемы. Много шрифтов не надо. У нас (фирмы) очень большой опыт в разработке и внедрении скад. Мы специально сделали свой собственный шрифт с аккуратно подобранным начертанием символов, именно чтобы они хорошо читались оператором. Поэтому мне кажется, что нужно выбрать наиболее подходящий шрифт и его внедрить. Ну не один, конечно, а несколько разных типов: с засечками, без засечек, моноширинный.

Кроме шрифтов на скриншотах еще полно артефактов, или это особенности сжатия картинок...


Название: Re: Проблема с шрифтами
Отправлено: Detonator от Январь 21, 2009, 18:35
Цитировать
Только вот Qt должна прорисовывать его на любой ос одинакого, пиксель к пикселю.

Не Qt должна а вы сами должны.
Я же выше написал - используйте стороннюю либу. Будет результат пиксель в пиксель на любой системе.
В Qt такого нет.

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


Название: Re: Проблема с шрифтами
Отправлено: Dendy от Январь 21, 2009, 19:16
Уже выше писал про QFontDatabase. Сам не использовал, но теоретически не вижу проблем.

В Qt такого нет.

Опять же, чем не устраивает QFontDatabase?


Название: Re: Проблема с шрифтами
Отправлено: Detonator от Январь 21, 2009, 20:00
Опять же, чем не устраивает QFontDatabase?

При использовании кастомного растеризатора фонт нужно грузить его средствами.
А QFontDatabase делает его доступным лишь для самой Qt которая нормального контроля над рендерингом и не дает.


Название: Re: Проблема с шрифтами
Отправлено: Dendy от Январь 21, 2009, 20:32
Вопрос был не про это. Чем не устраивает использование FreeType, который использует Qt?


Название: Re: Проблема с шрифтами
Отправлено: Detonator от Январь 21, 2009, 21:09
когда я его смотрел последний раз (года два назад), качество вывода мелкого текста у FreeType было неудовлетворительным.
Потому тогда я выбрал другую библиотеку для растеризации. Возможно сейчас FreeType стал получше, не проверял, но вроде их ограничивал патент на технологию хинтинга и не техническая возможность его реализовать.


Название: Re: Проблема с шрифтами
Отправлено: juvf от Январь 22, 2009, 08:38
Цитировать
ИМХО здесь шрифты должны быть максимально читаемы. Много шрифтов не надо.

Ну тут наши имхи совподают. я тоже думаю что для скады не нужны тонны шрифтов. лучше 1 хороший без проблемный, чем 1000 красивых с проблемой отображения.

Цитировать
Кроме шрифтов на скриншотах еще полно артефактов, или это особенности сжатия картинок...
это и особенности сжатия, и мнемосхема пока еще сырая

Цитировать
Уже выше писал про QFontDatabase. Сам не использовал, но теоретически не вижу проблем.
QFontDatabase предоставляет информацию о всех установленных шрифтах. Как это может помочь теоретически?
2 машины, с одного релиза установленна ос и Х-ы. Разные только оконные менеджеры. На обоих машинах есть фонт Helvetica, но рисуются они по разному. Может они при одинаковом названии всё же разные? Щя попробую встроить шрифт с одной ЭВМ в проект и его юзать на обоих ЭВМ, может получится.

Цитировать
В основе Qt вроде используется FreeType - попробуй через него
это как? в асистанте про это ни нашол, в qdemo тоже нет. В инете как-то скучно про практическое применение написанно. Где можно почитать про использование FreeType в программах написанных на Qt?




Название: Re: Проблема с шрифтами
Отправлено: Detonator от Январь 22, 2009, 11:09
Почитай документацию по ней и покопайся в исходниках чтобы посмотреть как что вызываеться из Qt .
C:\Qt\4.5.0\src\3rdparty\freetype\
http://freetype.sourceforge.net/freetype2/index.html


Название: Re: Проблема с шрифтами
Отправлено: Dendy от Январь 22, 2009, 15:33
QFontDatabase предоставляет информацию о всех установленных шрифтах. Как это может помочь теоретически?

Не только позволяет просматривать шрифты в системе, а добавлять свои на этапе выполнения. Читайте документацию внимательней.