Загрузите изображение в этот фрагмент стека и наведите на него указатель мыши. Будет нарисована черная кривая, которая следует за углом оттенка , начиная с точки курсора:
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script><style>canvas{border:1px solid black;}</style>Load an image: <input type='file' onchange='load(this)'><br><br>Max length <input id='length' type='text' value='300'><br><br><div id='coords'></div><br><canvas id='c' width='100' height='100'>Your browser doesn't support the HTML5 canvas tag.</canvas><script>function load(t){if(t.files&&t.files[0]){var e=new FileReader;e.onload=setupImage,e.readAsDataURL(t.files[0])}}function setupImage(t){function e(t){t.attr("width",img.width),t.attr("height",img.height);var e=t[0].getContext("2d");return e.drawImage(img,0,0),e}img=$("<img>").attr("src",t.target.result)[0],ctx=e($("#c")),ctxRead=e($("<canvas>"))}function findPos(t){var e=0,a=0;if(t.offsetParent){do e+=t.offsetLeft,a+=t.offsetTop;while(t=t.offsetParent);return{x:e,y:a}}return void 0}$("#c").mousemove(function(t){function e(t,e){var a=ctxRead.getImageData(t,e,1,1).data,i=a[0]/255,r=a[1]/255,o=a[2]/255;return Math.atan2(Math.sqrt(3)*(r-o),2*i-r-o)}if("undefined"!=typeof img){var a=findPos(this),i=t.pageX-a.x,r=t.pageY-a.y;$("#coords").html("x = "+i.toString()+", y = "+r.toString());var o=parseInt($("#length").val());if(isNaN(o))return void alert("Bad max length!");for(var n=[i],f=[r],h=0;n[h]>=0&&n[h]<this.width&&f[h]>=0&&f[h]<this.height&&o>h;)n.push(n[h]+Math.cos(e(n[h],f[h]))),f.push(f[h]-Math.sin(e(n[h],f[h]))),h++;ctx.clearRect(0,0,this.width,this.height),ctx.drawImage(img,0,0);for(var h=0;h<n.length;h++)ctx.fillRect(Math.floor(n[h]),Math.floor(f[h]),1,1)}});</script>
Я тестировал этот фрагмент только в Google Chrome.
Например, когда курсор находится над красным, кривая имеет наклон 0 °, но когда она выше желтого, она имеет наклон 60 °. Кривая продолжается для указанной длины, непрерывно изменяя свой наклон в соответствии с оттенком.
Загрузите это изображение, и когда вы наводите курсор на него, линия вокруг курсора должна сделать полный оборот против часовой стрелки:
Это и это другие аккуратные образы, чтобы попробовать. (Вам необходимо сохранить их, а затем загрузить их с фрагментом кода. Они не могут быть связаны напрямую из-за ограничений перекрестного происхождения.)
Вот не уменьшенная версия фрагмента:
Вызов
Напишите программу, которая делает то, что делает фрагмент, но не в интерактивном режиме. Возьмите изображение и координаты (x, y) в границах изображения и максимальную длину кривой. Выведите то же изображение с добавленной черной кривой, которая следует за углами оттенков, начиная с (x, y) и заканчивая, когда оно достигло максимальной длины или достигло границы изображения.
В частности, начните кривую с (x, y) и измерьте угол оттенка там. Перейдите на одну единицу (ширину одного пикселя) в этом направлении, отметив, что ваша новая позиция, скорее всего, не является целочисленной координатой . Отметьте другую точку на кривой и двигайтесь снова, используя оттенок от ближайшего пикселя (используя что-то вроде floor
или round
, я не буду проверять это точно). Продолжайте так до тех пор, пока кривая не выйдет за пределы или не превысит максимальную длину. Чтобы закончить, нанесите все точки кривой как отдельные черные пиксели (опять же, используйте ближайшие пиксели), наложенные на изображение, и выведите это новое изображение.
«Угол оттенка» - это просто оттенок :
hue = atan2(sqrt(3) * (G - B), 2 * R - G - B)
Обратите внимание, что для значений оттенков серого, которые технически не имеют оттенка, возвращается 0, но это нормально.
(Эта формула использует atan2
большинство встроенных математических библиотек. R, G, B - от 0 до 1, а не от 0 до 255.)
- Вы можете использовать любой распространенный формат изображения без потерь, а также любые библиотеки изображений.
- Возьмите ввод из stdin или из командной строки или напишите функцию с аргументами для имени файла изображения, x и y и максимальной длины.
- Максимальная длина, а x и y всегда являются неотрицательными целыми числами. Вы можете предположить, что x и y находятся в диапазоне.
- Сохраните выходное изображение с выбранным вами именем или просто отобразите его.
- Ваша реализация не обязательно должна соответствовать фрагменту. Несколько пикселей в немного разных местах из-за немного другого метода округления / вычисления - это хорошо. (В хаотических случаях это может привести к появлению кривых, которые в основном отличаются друг от друга, но пока они выглядят правильно, это нормально.)
счет
Наименьшая подача в байтах побеждает.
источник
Ответы:
МАТЛАБ, 136
Скопировал большую часть настроек и тому подобное из @sanchises, но я вместо этого использую
streamline
для вычисления и рисования пути. Он сглаживает линию и использует билинейную интерполяцию, а не ближайший сосед, как указано.источник
C с SDL,
549516 байтЯ начну эту вечеринку! Почему-то мне захотелось попробовать свои силы в гольфе сегодня вечером. То, что вы, ребята, делаете сложно ... Если есть что-то, чего я не вижу на этом сайте, это SDL. Возможно, я только что узнал почему. Этот конкретный фрагмент соответствует как SDL2, так и SDL1.2, но является жестоким. Называется как
f("imagename.bmp", xcoord, ycoord, max_length);
. Сохраняет файл с тем же именем, которое указано в аргументах. Вывод, похоже, очень похож на фрагмент кода OP, но «нечеткий». Я могу попытаться исправить это чуть позже.Здесь все распутано:
Я должен отметить, что была предпринята осторожность, чтобы сделать его кроссплатформенным - в интересах честности, было неудобно жестко кодировать его для моей машины, даже если оно отрезало значительное количество байтов. Тем не менее, я чувствую, что пара вещей здесь излишни, и я посмотрю на это позже.
РЕДАКТИРОВАТЬ-------
В конце концов, это графический вывод ... Я буду обновлять изображения, которые мне периодически будут интересны.
f("HueTest1.bmp", 270, 40, 200);
f("HueTest2.bmp", 50, 50, 200);
f("HueTest3.bmp", 400, 400, 300);
источник
Python,
203172Образец вывода:
Позвонить с
f("image.jpg", 400, 400, 300)
Я потратил много символов на импорт, если у кого-то есть предложения по его улучшению. Может не работать в 3.0
источник
sqrt(3) -> 3**.5
? Я ничего не могу придумать для импорта, хотя.МАТЛАБ,
186172Игра включена ! Вызовите как
t('YourImage.ext',123,456,100')
для изображения любого типа, поддерживаемого MATLAB, начиная с (x, y) = (123 456) и максимальной длины 100. Начальные позиции не могут быть точно на правом и нижнем краях (это будет стоить мне два байта), поэтому начать на краю, использовать что-то вроде,x=799.99
чтобы начать вx=800
. Индексирование начинается с 1, а не с 0.Код:
Изменения:
Все еще использую,line
так как это самый короткий код, который я знаю для создания пикселя.Изменил цвет с черного на синий, используяCo
расширение доColor
(что делает MATLAB автоматически)источник
x=0
илиy=0
потенциально действительные позиции?function
заголовка. Спецификация не требует индексации с нуля или на основе одного, так что я использую MATLAB на основе одного, поэтому нет,x=0
илиy=0
она недопустима в этой программе.x=X
иy=Y
действует вместо этого?Обработка 323 символа
С пробелами:
Я уверен, что мог бы сократить это дальше, но пока это работает.
источник
JavaScript 414
источник