6 / 6 / 7
Регистрация: 16.05.2013
Сообщений: 351

Не рисует линии js+events

03.05.2017, 13:25. Показов 1266. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Пытаюсь заставить рисовать линии на Canvas, когда зажимаю кнопку мыши и вожу по нему (по сути аналог карандаша в Paint). Продебажил, в функции заходит (и на зажимание, и на отпускание), технических ошибок нет. Ошибок в логике не должно быть тоже... Однако линии на Canvas не рисуются. Может кто знающий подскажет почему?

Заранее благодарю за любой совет или "наводку"
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>Draw using JS</title>
        <style type="text/css">
            canvas{
                width: 500px;
                height: 500px;
                border: solid;
            }
        </style>
    </head>
 
    <body>
        <canvas id="can" onmousedown="draw(event.clientX, event.clientY)" onmouseup="reset()">
        </canvas>
 
        <script type="text/javascript">
                        // сохранения координат прошлой точки
            var old_x = -1;
            var old_y = -1;
 
            function draw(xPos,yPos)
            {
                var cvs = document.getElementById("can");
                var ctx = cvs.getContext("2d");
 
                                // получения координат места нажатия на Canvas
                var rect = cvs.getBoundingClientRect();
                        var x = xPos - rect.left;
                        var y = yPos - rect.top;
 
                                // если мы только нажали и начали вести, то сменим координаты на текущую точку
                if (old_x == -1 || old_y == -1)
                {
                    old_x = x;
                    old_y = y;
                }
 
                                // Само рисование
                ctx.beginPath();
                ctx.moveTo(old_x, old_y);
                ctx.lineTo(x, y);
                ctx.stroke();
 
                                // Запоминаем координаты текущей точки, чтобы потом начинать рисование с неё
                old_x = x;
                old_y = y;
            }
 
            function reset()
            {
                                // Сброс текущей точки в "default" состояние
                old_x = -1;
                old_y = -1;
            }
        </script>
    </body>
</html>
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.05.2017, 13:25
Ответы с готовыми решениями:

Не рисует линии на Canvas
Доброго времени суток! :good: Пытаюсь заставить рисовать линии на Canvas, когда зажимаю кнопку мыши и вожу по нему. Продебажил, в...

Не рисует линии
Как с помощью memDC нарисовать линии? Функция работает через dc. Попробовал переделать для рисование в памяти, программа запускается но...

TChart рисует квадратные линии
Кто-нибудь знает какое свойство нужно поменять чтобы чарт рисовал нормальные линии? double _x = Form2-&gt;getA(); double b =...

2
Эксперт HTML/CSS
 Аватар для Shakalaka
653 / 556 / 322
Регистрация: 27.01.2015
Сообщений: 1,374
03.05.2017, 14:18
Лучший ответ Сообщение было отмечено SnapeEye как решение

Решение

Цитата Сообщение от SnapeEye Посмотреть сообщение
Ошибок в логике не должно быть тоже...
Когда вы двигаете по канвасу курсором мышки - это событие mousemove. Вот в нем и должно происходить рисование.
В mousedown вы должны установить начальные координаты, так же вам понадобится какой-то флаг показывающий зажата ли кнопка мыши, его значение будет изменяться из false => true при нажатии кнопки
JavaScript
1
2
3
4
var pressed = false;
can.onmousedown = function(e){ pressed = true; /* x= ... y = ...*/ }
can.onmouseup = function(){ pressed = false; /*reset...*/ }
can.onmousemove = function(e){ if(pressed) /*draw...*/ }
1
6 / 6 / 7
Регистрация: 16.05.2013
Сообщений: 351
03.05.2017, 19:26  [ТС]
Огромное спасибо, разобрался!

Есть вопрос не по теме: почему все, что рисуется становится выпуклым каким-то?
Хотя я рисовал очень маленький кружок в левом верхнем углу...
Миниатюры
Не рисует линии js+events  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
03.05.2017, 19:26
Помогаю со студенческими работами здесь

Вместо круга рисует бесконечные линии
Здравствуйте! Я столкнулась с проблемой при моделировании. У меня 2008 версия программы. Нужно начертить круг в прямоугольнике, но...

QGraphicsScene - addRect не рисует при изменении ширины линии
Хочу перекрасить рамку прямоугольника в другой цвет. Делаю это так: void CuttingMapScene::allocateCell(QRectF cell, Qt::GlobalColor...

Программа в досе определяет мышь и рисует линии от предидущего щелчка к следующему
Вообще прошу помощи по написанию программы, точнее если быть точным по дописанию. Собственно программа в досе определяет мышь и рисует...

Составьте программу, которая рисует на экране две линии по диагоналям экрана
Составьте программу, которая рисует на экране две линии по диагоналям экрана. Добавьте окружность диаметром в половину высоты экрана с...

Работа с мышью: в графическом режиме рисует линии при нажатии кнопки и движении мышки
Осталось сдать последнюю лабу, но что-то никак. Находил похожие, но они на FASM. Вот прошу помощи Дано условие: В графическом режиме...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru