Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
0 / 0 / 0
Регистрация: 05.03.2020
Сообщений: 4

Функция для рисования кругов

16.03.2020, 17:10. Показов 2288. Ответов 2

Студворк — интернет-сервис помощи студентам
Доброго времени суток, необходимо написать метод для рисования кругов (в данном случае 20 кругов со случайным диаметром от 50 до 200 px, случайным цветом и случайными координатами). Console не выводит ошибок, просто не работает, хотя сама функция вызвана


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
$(document).ready(function(){
            let colors = ["purple", "orange","green", "pink", "cyan", "maroon", "blue", "brown", "grey", "yellow", "black"]
 
            function DrawCircles() {
                for(let i=0; i<20; i++)
                {
                let diameter = function (min, max) {
                 min = Math.ceil(min);
                 max = Math.floor(max);
                return Math.floor(Math.random()*(max - min + 1))+ min;
                }
                let randomColor = colors[Math.floor(Math.random()*colors.length)];
                let color = $('.circles').css("color", randomColor);
                let x = Math.floor(Math.random()*($(window).innerWidth - diameter(50, 200)))+ diameter(50, 200);
                let y = Math.floor(Math.random()*($(window).innerHeight - diameter(50, 200))) + diameter(50, 200);
                let location = $('.circles').css('position', 'absolute', 'top', x, 'left', y);
                let circle = $('<div>').addClass('circles').css('border-radius', '50%', color, location).width(diameter(50, 200)).height(diameter(50, 200));
                $('body').append(circle);
                setInterval(function(){
                }, 1000);   
            } 
            } 
            DrawCircles(20);
            
        });
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.03.2020, 17:10
Ответы с готовыми решениями:

Класс для рисования кругов
Класс для рисования кругов (хранить радиус R и координаты x,y центра). Вычислять площадь круга и длину окружности.

Использование графики для рисования кругов
помогите ещё создать с помощью графики эти программы

Что лучше для рисования линий и кругов - QPainter или QGraphicsScene?
Вот реально, что удобней и производительней? Слышал, что QGraphicsScene может быстро рисовать тонну фигур простых и может их позиции что...

2
 Аватар для Уф
890 / 725 / 447
Регистрация: 13.07.2015
Сообщений: 2,277
16.03.2020, 17:52
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
$(document).ready(function(){
            let colors = ["purple", "orange","green", "pink", "cyan", "maroon", "blue", "brown", "grey", "yellow", "black"]
 
            function DrawCircles() {
                for(let i=0; i<20; i++)
                {
                let diameter = function (min, max) {
                 min = Math.ceil(min);
                 max = Math.floor(max);
                return Math.floor(Math.random()*(max - min + 1))+ min;
                }
                let randomColor = colors[Math.floor(Math.random()*colors.length)];
                let x = Math.floor(Math.random()*(window.innerWidth - diameter(50, 200)))+ diameter(50, 200);
                let y = Math.floor(Math.random()*(window.innerHeight - diameter(50, 200))) + diameter(50, 200);
                console.log(x,y);
                let circle = $('<div>').addClass('circles').css({'border-radius':'50%', border: "1px solid black", "background-color":randomColor, 'position': 'absolute', 'top':x, 'left': y}).width(diameter(50, 200)).height(diameter(50, 200));
                $('body').append(circle);
                setInterval(function(){
                }, 1000);   
            } 
            } 
            DrawCircles(20);
            
        });
1
0 / 0 / 0
Регистрация: 05.03.2020
Сообщений: 4
17.03.2020, 08:12  [ТС]
Спасибо "Уф", правда обнаружила, что функция рисует не круги, а овалы на одном месте, а должна по всему экрану. В общем немного отредактировала код и вроде получилось.

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
$(document).ready(function(){
            let colors = ["purple", "orange","green", "pink", "cyan", "maroon", "blue", "brown", "grey", "yellow", "black"]
 
            function DrawCircles() {
                for(let i=0; i<20; i++)
                {
                let diameter = function (min, max) {
                 min = Math.ceil(min);
                 max = Math.flooУфr(max);
                return Math.floor(Math.random()*(max - min + 1))+ min;
                }
                let randomColor = colors[Math.floor(Math.random()*colors.length)];
                let color = $('.circles').css("color", randomColor);
                let x = Math.floor(Math.random()*$window.innerWidth [S]- diameter(50, 200)))+ diameter(50, 200);[/S] // ограничивает площадь экрана для рисования
                let y = Math.floor(Math.random()*$window.innerHeight [S]- diameter(50, 200))) + diameter(50, 200)[/S];
                let width = diameter(50, 200);
                let circle = $('<div>').addClass('circles').css({'border-radius': '50%', 'background-color': randomColor, 
                'position' : 'absolute', 'top': x, 'left': y, 'width': width, 'height': width}); // когда 'width': diameter(50,200) и 'height;:(diameter(50, 200), то значения у них получаются и разные и вместо кругов функция рисует овалы 
                $('body').append(circle);
                 
            } 
            } 
            DrawCircles(20);
            
        });
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.03.2020, 08:12
Помогаю со студенческими работами здесь

Графический способ рисования кругов
Здраствуйте! Помогите решить задачу: Написать программу для рисования узора (см. рисунок). Узор состоит из 50 вложенных окружностей....

Функция y=f(x) для рисования полуокружности
Нужна формула зависимости y от x Нужна для применения в таких кодах: uses GraphABC,ABCObjects; begin SetWindowSize(500,500); ...

Функция для рисования на picturebox
Подскажите как мне написать функцию чтобы при её вызове рисовалось изображение на пикчербоксе ,проблема в том ,что пишу Морской бой...щас...

Функция для рисования окружности
Есть функция для рисования триугольника , а как нарисовать коло ? void Triangle::Plump() { MoveToEx(dc, x, y, NULL); ...

Определить, в каком из кругов находится наибольшее число кругов из данного множества кругов
Круг задается радиусом и координатами центра. Имеется n кругов (n20). Определить, в каком из кругов находится наибольшее число кругов из...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru