169 похожих чатов

Здравствуйте. Мне нужно сделать UI, в котором на картинке (загруженной извне)

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

53 ответов

39 просмотров

canvas и объекты с абсолютным расположением

// Получаем элементы DOM const canvas = document.getElementById('canvas'); const deleteButton = document.getElementById('delete-button'); const ctx = canvas.getContext('2d'); // Инициализируем Fabric.js холст const canvasObj = new fabric.Canvas('canvas'); // Массив для хранения точек const points = []; // Функция для создания новой точки function createPoint(x, y) { const circle = new fabric.Circle({ left: x, top: y, radius: 5, fill: 'red', selectable: true, hasControls: false, // Отключаем ресайз и поворот для точек }); // Добавляем точку на холст и в массив canvasObj.add(circle); points.push(circle); } // Обработчик клика по холсту для создания точек canvas.addEventListener('click', (event) => { const { offsetX, offsetY } = event; createPoint(offsetX, offsetY); }); // Обработчик клика по кнопке для удаления выбранных точек deleteButton.addEventListener('click', () => { const selectedPoints = canvasObj.getActiveObjects(); selectedPoints.forEach((point) => { // Удаляем точку с холста и из массива canvasObj.remove(point); const index = points.indexOf(point); if (index !== -1) { points.splice(index, 1); } }); canvasObj.discardActiveObject(); canvasObj.requestRenderAll(); }); // Обработчик перемещения точек (Drag and Drop) canvasObj.on('object:moving', (event) => { // Обновляем координаты точки в массиве const movedPoint = event.target; const index = points.indexOf(movedPoint); if (index !== -1) { points[index] = movedPoint; } }); // Ваши другие процедуры могут использовать массив points для доступа к координатам точек

Steel-Sword Автор вопроса
ПРАВОСЛАВНЫЕ ЗНАКОМСТВА / РЕКЛАМА ЧАТОВ
причем тут библиотека.

Сойдёт и эта наверное. Я вообще хз с какой стороны к задаче подойти, а тут и библиотека есть

Steel Sword
Сойдёт и эта наверное. Я вообще хз с какой стороны...

// Инициализируем Fabric.js холст const canvasObj = new fabric.Canvas('canvas'); если вы за это, то назвать файл джс можем как угодно.

Steel-Sword Автор вопроса
ПРАВОСЛАВНЫЕ ЗНАКОМСТВА / РЕКЛАМА ЧАТОВ
// Получаем элементы DOM const canvas = document.g...

Кстати, мне нужны координаты не канваса, а изображения на нём

Steel-Sword Автор вопроса
ПРАВОСЛАВНЫЕ ЗНАКОМСТВА / РЕКЛАМА ЧАТОВ
так ??

Если кому интересно, то для моей задачи, кажется, очень подходит ImageLayer из библиотеки OpenLayers. Там всё готово, всё по делу без всякой ерунды. https://openlayers.org/en/latest/examples/static-image.html

Raman
Не копируете ответы с gpt

как вы решаете подобные задачи ??

ПРАВОСЛАВНЫЕ ЗНАКОМСТВА / РЕКЛАМА ЧАТОВ
вы не пользуетесь вообще ии ??

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

999
а что так?

В том что бездумно копировать смысла нету и только хуже для людей которым отвечают так как может запутать ещё дальше

Друг друга а не машин

thheakihiro
в случае гпт, деградирует

думаю что нет, выдает мне годные ответы и учебу

Raman
Это не ответ на вопрос

из ответов чата ии мне синтез речи рассказывает

ПРАВОСЛАВНЫЕ ЗНАКОМСТВА / РЕКЛАМА ЧАТОВ
думаю что нет, выдает мне годные ответы и учебу

Сейм, я в гтп чаще спрашиваю чем в гугле + отдаю ему писать какие-нибудь функции банально потому, что иногда быстрее промтп написать и код проверить, чем самому всё писать Гпт это не панацея, а инструмент, которым нужно уметь пользоваться, вот и всё

Кириллл 🚀 Go Aaply
Сейм, я в гтп чаще спрашиваю чем в гугле + отдаю е...

Гпт это не панацея, а инструмент, которым нужно уметь пользоваться, вот и всё => вот вот

Кириллл 🚀 Go Aaply
Сейм, я в гтп чаще спрашиваю чем в гугле + отдаю е...

скажите у вас чат ии выдавал неправильные ответы или вводил в заблужение ??

Кириллл 🚀 Go Aaply
Да, бывает

Я бы даже перефразирывал в выдаёт ли правильные ответы и ответ был ты таким же :)

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
62
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
а где есть mysql cloud кроме яндекс-клауд?
Oleg Nosov
13
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
13
hi im a cs student. i need some advice from people who have enough experience in Embedded Software. I need to know whether this profession is suitable for me. I have watched s...
Sahand 🏔️
8
Не ну фпц - это уже просто троллинг какой-то. Элементарный код нельзя собрать. ЧЯДНТ? program Project1; {$mode delphi} uses SysUtils, Classes, Generics.Collections; var...
Peter
2
Кстати а покупал кто-нибудь ЭЦП для подписи кода? А то у меня на некоторых компах и ОС иногда SmartScreen винды программу за вирус принимал. Если купить такую ЭЦП и подписыват...
Дмитрий Завгородний
15
А кто-нибудь запихивал сборку перловых модулей/образов с perl приложениями в окружения без интернета (в специализированном CI/CD)? У меня сейчас есть ряд cpanfile, которые н...
Andrey Smirnov / 𝓪𝓵𝓵𝓽𝓮𝓻 /
14
Карта сайта