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

Рисование в canvascontext

21.02.2025, 08:34. Показов 1330. Ответов 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
1192 / 761 / 128
Регистрация: 10.03.2012
Сообщений: 4,925
21.02.2025, 10:15
Цитата Сообщение от Vasyia Посмотреть сообщение
В каком месте расчета начальной точки дуги ошибка?
Какая именно у Вас возникла ошибка?
0
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,969
Записей в блоге: 233
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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru