Форум программистов, компьютерный форум, киберфорум
JavaScript: HTML5 Canvas
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 09.03.2023
Сообщений: 4

Рисование в canvascontext

21.02.2025, 08:34. Показов 1277. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем добрый день.
учусь рисовать в canvas context
и никак не могу отрисовать круг и несколько дуг рядом. В каком месте расчета начальной точки дуги ошибка?


JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
const arcCount = 4;
 
res.ellipse(centerX, centerY, arcRadius, arcRadius, 0, 0, Math.PI * 2);
 
// Рисуем 4 дуги
for (let i = 0; i < arcCount; i++) 
{
    let offsetX = spacing * (i + 1);
 
    
    const angle = -Math.PI / 2; 
    const startX = centerX + offsetX + arcRadius * Math.cos(angle);
    const startY = centerY + arcRadius * 2 * Math.sin(angle);
 
    // Начало дуги
    res.moveTo(startX, startY);
 
    // дуга
    res.arc(centerX + offsetX - arcRadius, centerY, arcRadius * 2, -Math.PI / 4, Math.PI / 4);
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.02.2025, 08:34
Ответы с готовыми решениями:

Плавное рисование canvas
Пример Вводится координата X и Y и в данную точку рисуется линия. Но она рисуется не плавно. Как можно добиться плавность в canvas? ...

Рисование на карте
Нужно нарисовать что то такое http://********/n2YkkGGF8qgGr6. Подскажите дельные статейки как это сделать

Рисование на изображении, Кнопка загрузки изображения с компа
Уважаемые программисты. Два вопроса: 1 - У меня есть изображение, как сделать чтоб поверх него появились вертикальные линии от верхнего...

3
1184 / 754 / 127
Регистрация: 10.03.2012
Сообщений: 4,845
21.02.2025, 10:15
Цитата Сообщение от Vasyia Посмотреть сообщение
В каком месте расчета начальной точки дуги ошибка?
Какая именно у Вас возникла ошибка?
0
9037 / 2937 / 494
Регистрация: 05.10.2013
Сообщений: 7,962
Записей в блоге: 216
21.02.2025, 13:02
Лучший ответ Сообщение было отмечено Vasyia как решение

Решение

Цитата Сообщение от Vasyia Посмотреть сообщение
и никак не могу отрисовать круг
Ваш код рисования круга:
JavaScript
1
res.ellipse(centerX, centerY, arcRadius, arcRadius, 0, 0, Math.PI * 2);
Вы не показали, какие значения вы задали для: centerX, centerY, arcRadius, arcRadius
Я погуглил: canvas api ellipse
Первая ссылка в списке на документацию CanvasRenderingContext2D: ellipse() method
Если на странице с документацией на метод ellipse() пролистать почти до самого низа, то там есть пример:

JavaScript
1
2
3
4
5
6
7
const canvas = document.getElementById("canvas");
const ctx = canvas.getContext("2d");
 
// Draw the ellipse
ctx.beginPath();
ctx.ellipse(100, 100, 50, 75, Math.PI / 4, 0, 2 * Math.PI);
ctx.stroke();
Для окружности нужно, чтобы третить (radiusX) и четвёртый (radiusY) параметры, в методе ellipse, совпадали:

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
<body>
    <canvas id="renderCanvas" width="250" height="250"></canvas>
 
    <script>
        const canvas = document.getElementById("renderCanvas");
        const ctx = canvas.getContext("2d");
 
        // Draw the circle
        ctx.beginPath();
        ctx.ellipse(100, 100, 50, 50, Math.PI / 4, 0, 2 * Math.PI);
        ctx.stroke();
    </script>
</body>
Песочница: https://plnkr.co/edit/BWBUd5Wz9nvehsi3

Название: 8ae1373bb2d01422f7765532965ca0a91727e3fe.png
Просмотров: 75

Размер: 845 байт

Для рисования дуг есть пример на странице официальной документации метода arc. В этом методе начальный и конечный угол задаются предпоследним и последними параметрами, например, рисование полуокружности:

JavaScript
1
2
3
ctx.beginPath();
ctx.arc(100, 75, 50, 0, Math.PI);
ctx.stroke();
0
0 / 0 / 0
Регистрация: 09.03.2023
Сообщений: 4
23.02.2025, 17:47  [ТС]
Спасибо! разобрался. Еще вопрос у кого-нибудь есть опыт рисования восьмерок

JavaScript
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
 getPath(): Path2D {
 
      const res = new Path2D();
 
      const centerX = this.getSize().x / 2;
      const centerY = this.getSize().y / 2;
      const radiusX = this.getSize().x / 4; // Радиус дуги (ширина капли)
      const radiusY = this.getSize().x / 4; // Высота дуги
 
      const bottomY = centerY + radiusY * 1.8; // Острая нижняя точка
 
      // Рисуем верхнюю дугу (полукруг)
      res.arc(centerX, centerY, radiusX, Math.PI, 0, false);
 
      // Переход к боковым линиям с изгибами
      res.bezierCurveTo(
          centerX + radiusX * 1.2, centerY + radiusY * 0.7,  // Контрольная точка 1 (плавный изгиб)
          centerX + radiusX * 0.5, bottomY - radiusY * 0.3,  // Контрольная точка 2 (уже ближе к низу)
          centerX, bottomY // Нижняя острая точка
      );
 
      res.bezierCurveTo(
          centerX - radiusX * 0.5, bottomY - radiusY * 0.3,  // Контрольная точка 3 (с другой стороны)
          centerX - radiusX * 1.2, centerY + radiusY * 0.7,  // Контрольная точка 4 (подъем к дуге)
          centerX - radiusX, centerY // Возвращаемся к началу дуги
      );
 
      res.closePath();
 
      return res;
вот нарисовал перевернутую "каплю"
может кто нибудь знает есть ли какая-нибудь функция которая переворачивает(отзеркаливает) эту нарисованную фигуру?

что бы получилось примерно как на втором изображении
Миниатюры
Рисование в canvascontext   Рисование в canvascontext  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.02.2025, 17:47
Помогаю со студенческими работами здесь

Рисование на JS
можно ли с помощью JS сделать форму, в которой можно было бы рисовать? Если можно, то как. Если есть такая же технология, но на HTML5,...

Рисование на холсте из обьекта
Подскажите пожалуйста как нарисовать холст? var TableHeight = 300, TableWidth = 500; function init() { canvas =...

Рисование
Здравствуйте! У меня есть &lt;img&gt; и переменная с текстом. Я могу как-то с помощью JavaScript написать этот текст на изображении? ...

Рисование ориентированного графа
Я, как нуб, ищу простой способ нарисовать граф с парой доп условий: - ноды должны содержать текст (порой до 60 символов, можно разбить на...

Google maps API рисование Эллипса
Здравствуйте возник вопрос, как с помощью функций google maps API нарисовать эллипс привязанный к точке?


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru