Алфавит флага Международного кода сигналов используется судами для связи, особенно для статических сигналов.
Ваша задача - написать программу или функцию, которая будет принимать строку из STDIN или в качестве аргумента и отображать соответствующий текст в алфавитном флаге ICS. Если ваш язык не отображается на экране, сохранение в файл приемлемо.
Ваша программа или функция должны поддерживать буквы AZ в верхнем и нижнем регистре, а также пробел и перевод строки . Поведение с другими персонажами не определено.
Дисплей должен быть достаточно большим, чтобы отображать, по меньшей мере, 8 флагов по горизонтали и 6 флагов по вертикали. Поведение не определено, если правый край достигнут до того, как получена новая строка, или если сообщение слишком длинное, чтобы поместиться на дисплее вертикально.
Алфавит флага показан ниже (латинские буквы приведены только для справки, они не требуются при выводе).
Габаритные размеры
Не существует универсально согласованного стандарта для размеров этих флагов, поэтому для целей этой задачи должно применяться следующее:
Флаги должны быть 60x60 пикселей, с промежутком в 30 пикселей между ними как по горизонтали, так и по вертикали.
Обрезка ласточкиного хвоста на А и В должна иметь глубину 15 пикселей.
Все остальные линии должны быть горизонтальными, вертикальными или под углом 45 градусов.
Элементы должны быть расположены путем деления флага на воображаемую сетку NxN со стороной 3,4,5 или 6 квадратов. Обратитесь к изображению выше, но для уточнения:
A, E, H, K, L и U основаны на сетке 2x2: ширина каждой цветовой зоны должна составлять 30 пикселей. Также точки алмаза в F должны быть на полпути вдоль каждой стороны флага.
J и T основаны на сетке 3x3: каждая полоса должна быть 20 пикселей.
P, N и S основаны на сетке 4x4. Также диагональные линии Y должны разделить края флага на 4.
C, D, R и X должны быть основаны на сетке 5x5. Ширина полос и крестов должна составлять 12 пикселей.
G, W, M, V основаны на сетке 6x6. Полосы G и границы W должны иметь ширину 10 пикселей. Крестики на M и V должны покрывать первые и последние 10 пикселей каждого края флага, оставляя треугольные зоны размером 40 пикселей по длинному краю.
Круг I должен быть в центре флага и иметь диаметр 30 пикселей.
Ошибка в +/- 1 пиксель из приведенного выше текста допускается. Если ваш язык поддерживает только масштабируемую графику, вы можете интерпретировать «пиксели» как «единицы».
Цвета
Цвета должны быть красным, белым, синим, желтым и черным в соответствии с вашим языком или документацией. Если ваш язык не определяет цвета, вы можете использовать следующее: красный FF0000, белый FFFFFF, синий 0000FF, желтый FFFF00, черный 0000000.
Фон должен быть серым (каналы r, g и b равны, интенсивность между 25% и 75%.)
Скоринг / лазейки
Это кодегольф. Самый короткий код в байтах побеждает.
Стандартные лазейки запрещены.
Нельзя использовать встроенные или библиотечные функции для отображения флагов. Вывод должен быть нетекстовым (и, в частности, символы юникода не должны использоваться для построения формы флага).
пример
JFK got
my VHS
PC
and XLR
web quiz
должен произвести следующее
источник
Ответы:
CJam, 464 байта
Вы думали, что у CJam нет функций манипулирования изображениями? Ну, ты думал правильно! Но я не позволил этому остановить меня.
Эта программа наилучшим образом выводит изображение, которое может CJam: в виде текста, представляющего изображение при сохранении в виде файла PPM . Кстати, даже не пытайтесь запустить его с онлайн-переводчиком; ты взорвешь стек Запустите его с интерпретатором Java и передайте вывод в файл с помощью команды вроде
java -jar cjam-0.6.4.jar flags.cjam > flags.ppm
. После того как вы предоставили свои данные, отправьте EOF (возможно, сразу после новой строки) с помощью ctrl + D в Unix или ctrl + Z в Windows.Образец
Если это действительно желательно, я могу попытаться вставить оригинальный источник изображения ~ 3MB куда-нибудь. Но вот результат, открытый в GIMP и связанный с PNG:
объяснение
Заголовок изображения, легко идентифицируемый в источнике, состоит из магического числа, ширины, высоты и максимального значения канала. Таким образом, на выходе получается изображение размером 690 * 690 (достаточно для флагов размером 8 * 8 60px с интервалом 30 пикселей между ними) с каждым значением R, G и B в диапазоне от 0 до 4.
Данные изображения инициализируются в виде массива 690 * 690 * 3, заполненного 3, что делает все изображение светло-серым. Затем ввод читается, преобразуется в верхний регистр и разбивается на строки. Строки обрабатываются в цикле, увеличивая координату Y флага на 90 на каждой итерации, и в каждой строке каждый символ обрабатывается в цикле, увеличивая координату X флага на 90 на каждой итерации. Теперь волшебство начинается.
Каждый символ сопоставляется с функцией пикселя флага, которая при вызове возвращает цвет пикселя в позиции (X, Y) на флаге. Вот куда делась большая часть тяжелой работы: кратко описать 26 изображений как математические функции. Каждая из этих функций возвращает значение цвета от 8 до 15. Этот диапазон использует тот факт, что при преобразовании в базу 2 результирующий битовый массив можно интерпретировать как [1, R, G, B]. Первый элемент может быть удален, а остальные умножены на 4, чтобы легко получить значение пикселя в желаемом формате, который охватывает все возможные цвета флага (а также зеленый, голубой и пурпурный). Также хорошо получается, что есть односимвольные переменные, инициализированные до 10-15, и так как переменным не нужно место для синтаксического разделения их,
Как только функция извлечена, нужно просто выполнить итерации по X и Y от 0 до 60, вызвать функцию на каждом шаге и записать результат обратно в массив данных изображения. Проницательный наблюдатель может заметить, что значения цвета, возвращаемые каждой функцией флага, не допускают серого. Так что есть немного дополнительной логики, чтобы пропустить пробелы. Но есть все еще сокращения 'ласточкиного хвоста' на 'A' и 'B'. Так что здесь тоже есть немного дополнительной логики. Если значение символа меньше, чем «C», значение устанавливается таким образом, что верхняя граница в цикле X изменяется правильно относительно Y, и области выреза никогда не рисуются.
В целом, я очень доволен тем, как это получилось. Это заняло много работы, но было весело. Некоторые флаги не совсем соответствуют эталонному изображению, но я думаю, что все фигуры находятся в пределах 1 пикселя от цели (если какие-либо отклонены более чем на это, дайте мне знать, и я исправлю их). И, безусловно, потенциал для оптимизации еще есть, поскольку между функциями 26 флагов существует значительная избыточность.
Интересная первая попытка, 559 байт
Хотя я так и не закончил, я тоже выложу, потому что это довольно интересно. Вместо того, чтобы моделировать каждый флаг функцией (X, Y) → цвет, флаги рисуются в виде композиции простых фигур. Но я беспокоился о необходимости написания значительного количества кода рендеринга для каждой отдельной фигуры. После долгих размышлений я понял, что могу отрисовать их все, с некоторым умным наложением и наложением, только с одной псевдо-формой: все точки в пределах определенного расстояния от указанной точки, где определение «расстояния» является переменным. Расстояние на шахматной доске дает квадрат, расстояние на Манхэттене - ромб, а евклидово - круг. Это означало, что каждая фигура имела одинаковые пять параметров (цвет, режим расстояния, х, у,
источник
PHP, 811 байт
Сжатый BLOB-объект содержит код SVG для каждого из 26 флагов. Затем простой цикл извлекает и выводит изображение SVG, соответствующее каждому символу ввода.
Пример вывода для «Это
\n
тест»:( Вы можете попробовать его на ideone , хотя он не будет отображать страницу для вас.)
источник