Pull to refresh

Comments 197

UFO just landed and posted this here
Правильно, просто люди по наитию сначала смотрят строку, а потом столбец.
Это в программёрстве всё наоборот. И считаем мы с нуля :)
Незнаю как у вас, но у нас в программировании сначала тоже смотрят строку, а потом столбец. А вот счет с нуля — это да.
Аналогично. Создаётся ощущение, что авторы скайпа матрицы не проходили.
а вы транспонируйте — и смотрите
ОМГ! Кто бы мог подумать! =)
UFO just landed and posted this here
UFO just landed and posted this here
Многовато лишних белых пикселов хранится…
Нет там не белые пискселы… там прозрачные… это я их покрасил, т.к. при заливке рисунка хостеру он их в черный цвет перекрашивал.
Прозрачные пиксели места не занимают! :)
Собственно, для единственного файла с флагами, с адекватным алгоритмом сжатия — и для быстрого парсинга — решение очень удачное. Например, если использовать lzw сжатие, строка прозрачных пикселов шириной в ширину одного флага, будет храниться как 1 символ (13-17 бит)
И в результате 20 мб. Для быстрого парсинга? ну-ну
20 мегов — это весь дистриб скайпы, а не одна картинка с флажками, если чо :)
Во первых, неясно назначение букв (ясна причина их появления, но не назначение)
Во вторых, приходится загружать в память эти 80-90кб.
Да, в некоторых случаях такой способ оправдан, но в случае скайпа… это сделано, потому что так удобнее дизайнеру, и совсем не программисту.
Хотя… кажется скайп отображает флаги стран рядом с номерами на страницах браузеров… тогда да, скорее всего такой метод оправдан…
Прошу прощения, но найдя флаг РФ по буквам RU и имея опыт разработки подсистем локализаций, я имею наглость подтверждать свои слова об удобстве парсинга из такого файла)
Взять хотя бы способы реализации вывода шрифтов под OpenGL. Самыми быстрыми являются текстурные шрифты, где нужные символы различных кодировок расположены в таком же файлике на своих местах. Так реализуются не только моноширинные, если что))
Да реализовывал я шрифты в OpenGL, даже утилиту писал, которая генерировала такие тектуры на лету, без файликов.

Собственно мой первый коммент был наличием в вашем слова парсинг.
Что вы парсить из этой картинки собираетесь? Текстовые названия стран?
Ох, прошу прощения, использовал термин не подумал. Я имел в виду «вытаскивать»…
Два месяца назад я тоже реализовывал текстурные шрифты на OpenGL, по тестам они рисовались в 5 раз быстрее шрифтов из glut. За 5 минут написал программку на шарпе, которая располага символы в нужном положении, сохраняла канву, затем другой программкой (тоже писал сам, но уже как внутриигровую утилиту на движке создаваемой игры) конвертировал картинку во внутриигровой формат с информацией по каждому символу внутри.
Отсюда вопрос, если Вы генерили текстуры, Вы делали шрифты моноширинными?
Нет, пользовался информацией о ширине, рисовал полоской вырожденных треугольников, да… давно это было. Сейчас уже нормальные библиотеки есть для таких целей… 5-ю способами умеют.

А почему вы спрашиваете?
Исключительно любопытство, отошел от компьютера, вспомнил Ваш пост, задумался… :)
не в голом же bmp эта картикна хранится ..)
в памяти она хранится именно в виде голого битмапа. по моим подсчётам это будет отжирать несколько метров оперативки.
Пересчитай ещё раз.
ну, если это в натуральную величину, то пол метра.
может быть всетаки «способ хранениЯ» ?))
исправили, да не везде ;) «И наткнулся на очень интересный способ хранение флагов стран:»
Этот способ по русски надо назвать — «МОРСКОЙ БОЙ»!!!
UFO just landed and posted this here
Я оригинал рисунка представил.
а буквы вы сами дорисовали? а то как-то избыточно еще и буквы в картинке хранить…
Я думаю буквы — это тоже информация, возможно они из этих букв составляют полное изображение индекса страны.
бквы скорее всего для удобства довбавления новых флажков в пейнте :)
Хм, интересно. И главное должно быть оптимально.
Только вот боюсь автор топика нарушил лицензию и теперь на него начнутся гонения
Не, я имею в виду белый флаг с красным крестом.
Тогда бы пришлось добавить и флаги Уэльса, Шотландии и Северной Ирландии, как участников того же королевства. Кроме того, у этих стран нет двухбуквенного кода ISO 3166-1 по той же причине.
К вопросу об русификации.

Русификация

Простите, не удержался.
Там должны быть красные флаги с серпом и молотом :D
И моя карма плавно опускается до нуля )
Моя тоже, минусующий мог бы хотя бы отписаться о причине минуса для приличия =)
Спасибо добрый человек =)
UFO just landed and posted this here
у вас есть телефон, позволяющий звонить в прошлое?
а вы ему письмо напишите! (ц) Почтальон Печкин. В домен su.
UFO just landed and posted this here
Видимо о русификации и того и другого
Русификация — программе, а население это национализация.
Судя по картинке imhost.ru защитил 10 стран от наступления )
Советую picamatic.com, он не оставляет уродских ватермарков на картинках, и у него очень удобный AJAX-интерфейс, вам понравится!
Но периодически тормозит страшно.
Пикматик однако не спасет те 10 стран от всеобщей национализации! :)
Класс! Обожаю такие решения! На мой взгляд — гениально!
И чо в этом гениального? Я вот не вижу ни одного плюса такого решения. А минусы очевидные, что нужно реализовывать алгоритм вырезания нужного флага.
Алгоритм реализован в каждом браузере, Гугль так же поступает с большим количеством картинок.

В нужном месте задаётся блок заданного размера, потом в него подставляется бэкграунд со смещением. Смещение в данном случае вычисляется за две арифметических операции.
На главной Google, давно это заметил…

Битблиттинг — базовая функция в графике, он при любом способе хранения картинок будет использоваться.
UFO just landed and posted this here
Интересная привычка — ковырять новую программу на наличие ресурсов %)
Или это вы только со скайпом так поступаете )?
Нет я обычно ковыряюсь только если понравилось какое-то цветовое решение, и нужно взять оригинальный цвет, а такие вещи как правило лежат в виде рисунков в ресурсах.
Цвет проще выхватить пипеткой прямо с окна программы, имхо.
Не кажется ли вам, что было бы интуитивней транспонировать таблицу? Я вот начал искать россию на пересечении R строки и U столбца. Я один такой?
Нет, я тоже. Математическое прошлое даёт о себе знать )
Так вроде координата по «х» и в математике первая…
В матрицах, как правило, первыми индексируются строки, вторыми — столбцы.
На картинке — матрица.
Ах, ну, да, приминительно к матрицам это так =)
Меня это, кстати, почему-то всегда напрягало, хотя обозначение вектора как столбца было приятнее, чем как строки.
У меня первая мысль была — таблица :) Видимо не математик
тоже математическое прошлое, но меня всегда бесила эта путаница :) (матрицы и координаты)
Ну да. Любому человеку свойственно найти нужную строку, а в ней — нужный столбец.

Однозначно, создатели скайпа — не люди. Инопланетянцы, разве что?
А в графике используется пара координат (x,y). Все нормально.
На PHP вытягивание флажка выглядит где-то так:
imagecopy($dst,$table,0,0,ord($code[0])-ord('A'),($code[1])-ord('A'),16,8);
строка обозначается Y координатой.
Исходя из рисунка, получается, что большинство стран называются на гласные буква A, еще пик названий приходится на начало(1-ая буква) длится 4 буквы, потом на вторую половину(12-13-ая буквы), и на вторую половину второй половины (19-20-ая буквы, длится 2 буквы). Так же между пиками(посередине-1) лежит по одной букве(G,P), которые также часто). Что-то я переморочился.., пятница, пора отдыхать…
ой, + куда-то пропал. «на гласные+буква А»
Хм, на флаге какой страны изображена буква S?
Хе-хе, самое интеренсое что оно на пересечении буквы S и S.
ss — Swati — SiSwati
Из Википедии.
Swati и SiSwati это язык.
Есть народность Swazi в южной африке входящая в состав Swaziland.
Есть страна Swaziland в которой на этом языке разговаривают, но флаг у неё совсем другой

p.s. Вики была проверена на эту тему первой =)
У Австрии (Austria) и Австралии (Australia) первые две буквы совпадают. Флаг Австралии на картинке есть, а как же быть с Австрией?
У австрии .at, у Австралии .au
Австралия – AU, австрия – AT
Если быть еще более точным, то шифруются в соответствии с ISO 3166-1-alpha-2, в соответствии с которым уже были созданны «доменные коды».
наоборот :) доменные коды — по кодам стран :)
Естественно. Я имел в виду не страны вообще, а страны на этой картинке.
Насколько я помню, координатный метод хранения мелких ихображений в одном большом паке (aka файле) применяется давно. Способ конечно хорош, но все новое — это давно и хорошо забытое старое. Аналогичный способ хранения линейной картинки с типами файлов юзается в статье про стилизованные файл-инпуты. В общем, идея хороша, но не нова и применяется весьма успешно.

Да что там далеко ходить — неужели никто не помнит процесс сжатия шрифтов в Играх? Та же картинка с координатным методом выборки необходимого символа. Основной вопрос — в построении координат. Но это уже к Скайпу.
неа, ещё на O и Q только по одной стране.
UFO just landed and posted this here
UFO just landed and posted this here
это кто ж пишет «Rumania», интересно знать ))
UFO just landed and posted this here
устаревший словарь значит… раньше действительно так писали.
На двухбуквенные сокращения стран вроде международный стандарт есть или что-то в этом роде.
UFO just landed and posted this here
UFO just landed and posted this here
UFO just landed and posted this here
Даже Антарктида присутствует, политкорректно однако…
Раскрыта попытка заговора!

Skype собирается основать собственное государство с кодом SS (неонацизм?)
Где в skypeland вторая s?
Кому-то было очень нечего делать…
Да людям вообще нечего делать. Вместо того, чтобы картошку сажать, они программы пишут. А потом вот кризис. Ужас.
Я вообще считаю, что зря с деревьев слезли. Пробовал обратно, но сотни миллионов лет эволюции сделали своё чёрное дело…

Как я могу судить по всеобщему восхищению — этот способ хранения флагов достаточно нетривиален. Нетривиальность означает, что программисты сами на себя призывают дополнительный геморрой, зато потом с этого имеют дополнительный профит. Сколько там им было геморроя я не знаю, но вот кол-во профита, мне кажется, равно нулю. Что они выиграли-то? Сэкономили пару килобайт на диске? Пару десятков килобайт в памяти? Одну стодвадцатьвосьмую пиконаносекунды на времени обработки?
Хм, допустим на веб странице 30 флагов отображается, на каждый файл по 2 запроса возьмем для примера — 60 запросов. Это не так мало, время загрузки у пользователя будет заметно меньше при одном файле.
Какая веб-страница, речь идёт о гуишной программе.
Ну тогда — меньше фрагментация)
Так ведь и то не факт — даже если хранить по одному флажку, они же не лежат на диске в виде ru.bmp, us.bmp и т. д., а запихнуты все вместе в один файл ресурсов :)
Обычно иконки в гуевых программах хранятся именнов таком виде. И сам я применяю такой же метод, если на сайте есть куча иконок одинакового формата.
Понт не в спрайте, а в координатах.
Мне кажется, или там две Австралии (au и cx)?
CX — en.wikipedia.org/wiki/Christmas_Island
Правда флаг другой
Рождественский остров! Звучит!
остров Рождества на самом деле :)
А что такое UM?
Тут en.wikipedia.org/wiki/Country_code_top-level_domain нет ничего о «нём»
United States Minor Islands что бы это ни было.
Чтоб они были здоровы
UFO just landed and posted this here
в русской вики старая инфа, домена .um нет на root-ах уже (убрали в январе 2007-го).
В английской Wikipedia то же самое, в статье не список доменов.
А буквочки тоже в исходном файле были? Это специально для удобства «ковыряния»? (Вряд ли при вытаскивании нужного флага программа ищет буквы.)
класс, кто преобразует в координаты для css спрайтов?
Скайп всегда отличался своей кривизной. Удобно лишь для каких-нибудь дизайнеров, и все +) С точки зрения программинга — во всех смыслах неудачно.

А еще не знают, что для пнгшек есть pngout…
вообще, скайп довольно сложно оценивать с точки зрения программинга… (см.)

Чем Вы обоснуете своё утверждение о неудачности скайпа с точки зрения программинга?
Скайп обладает богомерзким интерфейсом, чем собсно и отталкивает. Ну не могут нормально писаные проги обладать таким интерфейсом.

Возвращаясь к портянке флагов — места на диске жрет больше, в памяти жрет больше, вычисление координат работает не шибко быстро. Если я упускаю преимущества — велком.

А еще ковырях j2me клиент — кокашычка +)
Богомерзкий интерфейс — дело субъективное. и вообще: внешность и программная реализация — всё таки разные вещи. Не стоит их смешивать.

Про одну картинку в компиленой программе не могу сказать. Может и места занимает меньше (за счёт общего заголовка и сжатия). Может один объект удобнее хранить. Не знаю, не видел внутренностей.

В web css-спрайты довольно приятная штука и много чего может сэкономить (особенно когда картинок такая туча).
А если вам нужно показать 100 флажков рядом — нужно открыть 100 файлов. Вы уверены что с точки зрения программинга и потребления ресурсов это решение неудачное?
таки я нигде не написал, что надо именно 100 файлов.
Кстати, очень, между прочим удобно с точки зрения организации данных :)

Универсальная штука.

Вы знаете, что большинство интерфейсных JS фреймворков использует подобное. То есть рисуется некоторое изображение с изображением например иконок, и потом используется всего лишь один ресурс/изображение, а не грузится каждый раз новое. С точки зрения организации данных и процессов/выделения памяти на процесс этот вариант достаточно удобен. То есть программистами всего лишь должна быть доработана система выделения части изображения из исходного.

Кто вам говорит, что картинки вырезаются?

Image Mapping

Короче говоря, я к тому что не следует делать поспешных выводов.
По мне так skype, как ПО выполнен очень грамотно и явно делается разумными программистами.
обоснуйте минус, я бы хоть поспорил за свою точку зрения!
Заглянул и я в ресурсы скайпа с вашей подачи. Порадовали language-neutral битмапки :)
Видимо при создании проекта Delphi их автоматически добавил в ресурсы, а убрать забыли :)
Прикольно — думал, что Win версия Skype разработана на C++, т.к. Linux версия на C++ с Qt, а для Maс OS X на Objective-C с Cocoa, а оказалось — на Delphi.
Получается, что нет — именно на Delphi. Интересно!
а разве не на c++ qt на всех платформах?
Скажу как «самизнаетекто» — охуенно!
класс, теперь все флаги на странице будут загружаться одновременно.
Вот вариант использования данной картинки для веба. Автор не зарегистрирован на хабре, попросил меня выложить.

pliper.ru/flags/flags.html
что такое EO, позвольте узнать? :)
тут вообще-то флаги *стран*, а не языков.
Я конечно чувствую себя необразованным холопом, НО — где же эта страна находится?
Читал в вика чёрным по русски — Эсперанти́да — неформальное название для сообщества людей, говорящих на эсперанто, и их культуры.
Пардон, дал ссылку на статью-эмбрион.

На эсперанто «Эсперантида» — Esperanto-lando, Esperantujo или Esperantio — это слова, образованные с суффиксом, при помощи которого образуются названия стран.

Эсперантида — воображаемая страна, географически охватывающая весь мир, жители которой — все говорящие на международном языке (это несколько миллионов человек).

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

А находится она в сердце =)
UFO just landed and posted this here
Я вот понять не могу, а UM это флаг какой страны?
UFO just landed and posted this here
Почитайте Крис Касперски, «Skype – скрытая угроза», будет не смешно. Т.е. я догадывался, что она использует чужие реальники как промежуточные сервера, но и не подозревал насколько это подозрительная, хитрая и запутанная система.
Почитайте лучше Vanilla Skype (часть 1, часть 2). А Касперски вообще мастер делать из мухи слона и видеть вещи там, где их нет :)

А то, что Skype может гнать через вас траффик написано в EULA, да кто ж его читает?
а вот только я не понял, а что это за флаг по SS?
UFO just landed and posted this here
.ad{background-position:-16px -44px;}
.ae{background-position:-16px -55px;}
.af{background-position:-16px -66px;}
.ag{background-position:-16px -77px;}
.ai{background-position:-16px -99px;}
.al{background-position:-16px -132px;}
.am{background-position:-16px -143px;}
.an{background-position:-16px -154px;}
.ao{background-position:-16px -165px;}
.aq{background-position:-16px -187px;}
.ar{background-position:-16px -198px;}
.as{background-position:-16px -209px;}
.at{background-position:-16px -220px;}
.au{background-position:-16px -231px;}
.aw{background-position:-16px -253px;}
.ax{background-position:-16px -264px;}
.az{background-position:-16px -286px;}
.ba{background-position:-32px -11px;}
.bb{background-position:-32px -22px;}
.bd{background-position:-32px -44px;}
.be{background-position:-32px -55px;}
.bf{background-position:-32px -66px;}
.bg{background-position:-32px -77px;}
.bh{background-position:-32px -88px;}
.bi{background-position:-32px -99px;}
.bj{background-position:-32px -110px;}
.bl{background-position:-32px -132px;}
.bm{background-position:-32px -143px;}
.bn{background-position:-32px -154px;}
.bo{background-position:-32px -165px;}
.br{background-position:-32px -198px;}
.bs{background-position:-32px -209px;}
.bt{background-position:-32px -220px;}
.bv{background-position:-32px -242px;}
.bw{background-position:-32px -253px;}
.by{background-position:-32px -275px;}
.bz{background-position:-32px -286px;}
.ca{background-position:-48px -11px;}
.cc{background-position:-48px -33px;}
.cd{background-position:-48px -44px;}
.cf{background-position:-48px -66px;}
.cg{background-position:-48px -77px;}
.ch{background-position:-48px -88px;}
.ci{background-position:-48px -99px;}
.ck{background-position:-48px -121px;}
.cl{background-position:-48px -132px;}
.cm{background-position:-48px -143px;}
.cn{background-position:-48px -154px;}
.co{background-position:-48px -165px;}
.cr{background-position:-48px -198px;}
.cu{background-position:-48px -231px;}
.cv{background-position:-48px -242px;}
.cx{background-position:-48px -264px;}
.cy{background-position:-48px -275px;}
.cz{background-position:-48px -286px;}
.de{background-position:-64px -55px;}
.dj{background-position:-64px -110px;}
.dk{background-position:-64px -121px;}
.dm{background-position:-64px -143px;}
.do{background-position:-64px -165px;}
.dz{background-position:-64px -286px;}
.ec{background-position:-80px -33px;}
.ee{background-position:-80px -55px;}
.eg{background-position:-80px -77px;}
.eh{background-position:-80px -88px;}
.er{background-position:-80px -198px;}
.es{background-position:-80px -209px;}
.et{background-position:-80px -220px;}
.fi{background-position:-96px -99px;}
.fj{background-position:-96px -110px;}
.fk{background-position:-96px -121px;}
.fm{background-position:-96px -143px;}
.fo{background-position:-96px -165px;}
.fr{background-position:-96px -198px;}
.ga{background-position:-112px -11px;}
.gb{background-position:-112px -22px;}
.gd{background-position:-112px -44px;}
.ge{background-position:-112px -55px;}
.gf{background-position:-112px -66px;}
.gg{background-position:-112px -77px;}
.gh{background-position:-112px -88px;}
.gi{background-position:-112px -99px;}
.gl{background-position:-112px -132px;}
.gm{background-position:-112px -143px;}
.gn{background-position:-112px -154px;}
.gp{background-position:-112px -176px;}
.gq{background-position:-112px -187px;}
.gr{background-position:-112px -198px;}
.gs{background-position:-112px -209px;}
.gt{background-position:-112px -220px;}
.gu{background-position:-112px -231px;}
.gw{background-position:-112px -253px;}
.gy{background-position:-112px -275px;}
.hk{background-position:-128px -121px;}
.hm{background-position:-128px -143px;}
.hn{background-position:-128px -154px;}
.hr{background-position:-128px -198px;}
.ht{background-position:-128px -220px;}
.hu{background-position:-128px -231px;}
.id{background-position:-144px -44px;}
.ie{background-position:-144px -55px;}
.il{background-position:-144px -132px;}
.im{background-position:-144px -143px;}
.in{background-position:-144px -154px;}
.io{background-position:-144px -165px;}
.iq{background-position:-144px -187px;}
.ir{background-position:-144px -198px;}
.is{background-position:-144px -209px;}
.it{background-position:-144px -220px;}
.je{background-position:-160px -55px;}
.jm{background-position:-160px -143px;}
.jo{background-position:-160px -165px;}
.jp{background-position:-160px -176px;}
.ke{background-position:-176px -55px;}
.kg{background-position:-176px -77px;}
.kh{background-position:-176px -88px;}
.ki{background-position:-176px -99px;}
.km{background-position:-176px -143px;}
.kn{background-position:-176px -154px;}
.kp{background-position:-176px -176px;}
.kr{background-position:-176px -198px;}
.kw{background-position:-176px -253px;}
.ky{background-position:-176px -275px;}
.kz{background-position:-176px -286px;}
.la{background-position:-192px -11px;}
.lb{background-position:-192px -22px;}
.lc{background-position:-192px -33px;}
.li{background-position:-192px -99px;}
.lk{background-position:-192px -121px;}
.lr{background-position:-192px -198px;}
.ls{background-position:-192px -209px;}
.lt{background-position:-192px -220px;}
.lu{background-position:-192px -231px;}
.lv{background-position:-192px -242px;}
.ly{background-position:-192px -275px;}
.ma{background-position:-208px -11px;}
.mc{background-position:-208px -33px;}
.md{background-position:-208px -44px;}
.mf{background-position:-208px -66px;}
.mg{background-position:-208px -77px;}
.mh{background-position:-208px -88px;}
.mk{background-position:-208px -121px;}
.ml{background-position:-208px -132px;}
.mm{background-position:-208px -143px;}
.mn{background-position:-208px -154px;}
.mo{background-position:-208px -165px;}
.mp{background-position:-208px -176px;}
.mq{background-position:-208px -187px;}
.mr{background-position:-208px -198px;}
.ms{background-position:-208px -209px;}
.mt{background-position:-208px -220px;}
.mu{background-position:-208px -231px;}
.mv{background-position:-208px -242px;}
.mw{background-position:-208px -253px;}
.mx{background-position:-208px -264px;}
.my{background-position:-208px -275px;}
.mz{background-position:-208px -286px;}
.na{background-position:-224px -11px;}
.nc{background-position:-224px -33px;}
.ne{background-position:-224px -55px;}
.nf{background-position:-224px -66px;}
.ng{background-position:-224px -77px;}
.ni{background-position:-224px -99px;}
.nl{background-position:-224px -132px;}
.no{background-position:-224px -165px;}
.np{background-position:-224px -176px;}
.nr{background-position:-224px -198px;}
.nu{background-position:-224px -231px;}
.nz{background-position:-224px -286px;}
.om{background-position:-240px -143px;}
.pa{background-position:-256px -11px;}
.pe{background-position:-256px -55px;}
.pf{background-position:-256px -66px;}
.pg{background-position:-256px -77px;}
.ph{background-position:-256px -88px;}
.pk{background-position:-256px -121px;}
.pl{background-position:-256px -132px;}
.pm{background-position:-256px -143px;}
.pn{background-position:-256px -154px;}
.pr{background-position:-256px -198px;}
.ps{background-position:-256px -209px;}
.pt{background-position:-256px -220px;}
.pw{background-position:-256px -253px;}
.py{background-position:-256px -275px;}
.qa{background-position:-272px -11px;}
.re{background-position:-288px -55px;}
.ro{background-position:-288px -165px;}
.ru{background-position:-288px -231px;}
.rw{background-position:-288px -253px;}
.sa{background-position:-304px -11px;}
.sb{background-position:-304px -22px;}
.sc{background-position:-304px -33px;}
.sd{background-position:-304px -44px;}
.se{background-position:-304px -55px;}
.sg{background-position:-304px -77px;}
.sh{background-position:-304px -88px;}
.si{background-position:-304px -99px;}
.sj{background-position:-304px -110px;}
.sk{background-position:-304px -121px;}
.sl{background-position:-304px -132px;}
.sm{background-position:-304px -143px;}
.sn{background-position:-304px -154px;}
.so{background-position:-304px -165px;}
.sr{background-position:-304px -198px;}
.st{background-position:-304px -220px;}
.sv{background-position:-304px -242px;}
.sy{background-position:-304px -275px;}
.sz{background-position:-304px -286px;}
.tc{background-position:-320px -33px;}
.td{background-position:-320px -44px;}
.tf{background-position:-320px -66px;}
.tg{background-position:-320px -77px;}
.th{background-position:-320px -88px;}
.tj{background-position:-320px -110px;}
.tk{background-position:-320px -121px;}
.tl{background-position:-320px -132px;}
.tm{background-position:-320px -143px;}
.tn{background-position:-320px -154px;}
.to{background-position:-320px -165px;}
.tr{background-position:-320px -198px;}
.tt{background-position:-320px -220px;}
.tv{background-position:-320px -242px;}
.tw{background-position:-320px -253px;}
.tz{background-position:-320px -286px;}
.ua{background-position:-336px -11px;}
.ug{background-position:-336px -77px;}
.um{background-position:-336px -143px;}
.us{background-position:-336px -209px;}
.uy{background-position:-336px -275px;}
.uz{background-position:-336px -286px;}
.va{background-position:-352px -11px;}
.vc{background-position:-352px -33px;}
.ve{background-position:-352px -55px;}
.vg{background-position:-352px -77px;}
.vi{background-position:-352px -99px;}
.vn{background-position:-352px -154px;}
.vu{background-position:-352px -231px;}
.wf{background-position:-368px -66px;}
.ws{background-position:-368px -209px;}
.ye{background-position:-400px -55px;}
.yt{background-position:-400px -220px;}
.za{background-position:-416px -11px;}
.zm{background-position:-416px -143px;}
.zw{background-position:-416px -253px;}
судя по всему человек проделал хорошую работу — css стили, для использования этой картинки как спрайта на веб страницах
хотя нет, выше по комментариям есть ссылка на пример
2 строчки javascript для вытаскивания нужного флага — это реально классная идея)
а как вы иначе собираетесь спрайт вставлять если javascript отключен?
Ну есть разные варианты, красивые и не очень, дело даже не в этом.
Вопрос в том, нафига такой коммент то было писать сюда?
Это может быть интересно. Какие? Генерировать css с помощью php? Если вам пустое место важней технического решения, закидаете минусами — оно само спрячется
Да ладно вам прибедняться, минусами…
Варианты:

<div class="flag" style="background-position:-416px -253px;">&nbsp;</div>


и прочие вещи, связанные с style.

Совершенно верно, ваш метод красивее, правильнее и я бы заставил верстальщика сделать именно так, но писать весь css тут — напрасно :)
ояебу! реальни!
только мне кажется что там 2 флага сша? UM и US. Вечно они выделиться хотят)
Вон оно как оказывается: .um — национальный домен верхнего уровня для Американских Внешних Малых островов.
Кто меня минусует, отписывайтесь! :(
Должно быть либо везде Украина, либо пустое поле, а так ни туда и не сюда

а есть какие-нибудь права на использование этих иконок?
Sign up to leave a comment.

Articles