Форум программистов, компьютерный форум, киберфорум
Java: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/47: Рейтинг темы: голосов - 47, средняя оценка - 4.96
0 / 0 / 0
Регистрация: 26.10.2014
Сообщений: 171

Рисование точки

16.03.2017, 21:32. Показов 9657. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Я наверное задам очень глупый вопрос, но как в Java нарисовать точку? Копался в гугле и на форумах, но так и не смог найти решения. Создать классы Point и Line. Само задание звучит так. Oбъявить массив из n объектов класса Point и определить в методе, какая из точек находится дальше всех от прямой линии, и пометить её другим цветом. С ним все понятно, а вот с рисование точки ничего не получается.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.03.2017, 21:32
Ответы с готовыми решениями:

Рисование точки
Помогите реализовать рисование точки. Нужно, чтоб по щелчку мыши в месте где находится курсор появлялась точка (только точка!). Для этого...

Рисование линий от точки до точки при помощи мыши
Нашла задачу, рисует линии, как я поняла от точки до точки. С помощью tasm и tlink делаю exe файл, запускается, курсор видно, но линии не...

Рисование кривых линий от точки до точки
Всем привет! Может кто находил библиотеки для рисования кривых полос как на картинке ниже отрисованы рельсы (от блока к блоку, с...

3
126 / 113 / 56
Регистрация: 05.12.2012
Сообщений: 463
17.03.2017, 21:06
Точка = отрезок, начало и конец которого совпадают.
1
0 / 0 / 0
Регистрация: 26.10.2014
Сообщений: 171
17.03.2017, 22:10  [ТС]
kushok, это решение я нашел, писал вот так:
Java
1
g.drawLine(30, 30, 30, 30);
Но я не понял как его можно применить в этом задании:Oбъявить массив из n объектов класса Point и определить в методе, какая из точек находится дальше всех от прямой линии, и пометить её другим цветом.
Код получился такой.Он рабочий, но графику не выводит.
Java
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
import java.applet.Applet;
import java.awt.*;
 
import javafx.scene.shape.Line;
public class Lab1class extends Applet {
    
 public static void main(String[] args) {
         
         int a= Math.abs(-5)  ;
            System.out.print("Hello world");
         }
    public void paint(Graphics g)
    {
        
        Point aPoint = new Point(50, 100);
        Point bPoint = new Point(50, 130);
        Point cPoint = new Point(50, 120);
        
        Point [] p1={aPoint,bPoint,cPoint};
        Line  aLine= new Line(30,30,100,30);
        
        
      double max =  Math.abs((aLine.getEndY()-aLine.getStartY())*p1[0].getX()-(aLine.getEndX()-aLine.getStartX())*p1[0].getY()+aLine.getEndX()*aLine.getStartY()-aLine.getEndY()
               *aLine.getStartX())/Math.sqrt( Math.pow(aLine.getEndY()-aLine.getStartY(),2)+ Math.pow(aLine.getEndX()-aLine.getStartX(),2));
        for (int i=0;i<3;i ++)
        {
          if(Math.abs((aLine.getEndY()-aLine.getStartY())*p1[i].getX()-(aLine.getEndX()-aLine.getStartX())*p1[i].getY()+aLine.getEndX()*aLine.getStartY()-aLine.getEndY()
               *aLine.getStartX())/Math.sqrt( Math.pow(aLine.getEndY()-aLine.getStartY(),2)+ Math.pow(aLine.getEndX()-aLine.getStartX(),2))>max)
          {max=Math.abs((aLine.getEndY()-aLine.getStartY())*p1[i].getX()-(aLine.getEndX()-aLine.getStartX())*p1[i].getY()+aLine.getEndX()*aLine.getStartY()-aLine.getEndY()
                   *aLine.getStartX())/Math.sqrt( Math.pow(aLine.getEndY()-aLine.getStartY(),2)+ Math.pow(aLine.getEndX()-aLine.getStartX(),2));}
     
        }
        String  strValue = String.valueOf(max); 
        g.drawString ("Расстояние до самой дальней точки "+strValue, 20, 100);
        
 
    }
    
}
0
 Аватар для Alradalion
132 / 126 / 85
Регистрация: 13.09.2013
Сообщений: 485
18.03.2017, 11:41
Как-то так:
Java
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
import java.applet.Applet;
import java.awt.*;
 
import javafx.scene.shape.Line;
 
public class Lab1class extends Applet {
 
    public void paint(Graphics g) {
 
        Point aPoint = new Point(50, 100);
        Point bPoint = new Point(50, 130);
        Point cPoint = new Point(50, 120);
 
        Point[] p1 = {aPoint, bPoint, cPoint};
        Line aLine = new Line(30, 30, 100, 30);
 
        int maxPoint = 0;
        double max = Math.abs((aLine.getEndY() - aLine.getStartY()) * p1[0].getX() - (aLine.getEndX() - aLine.getStartX()) * p1[0].getY() + aLine.getEndX() * aLine.getStartY() - aLine.getEndY()
                * aLine.getStartX()) / Math.sqrt(Math.pow(aLine.getEndY() - aLine.getStartY(), 2) + Math.pow(aLine.getEndX() - aLine.getStartX(), 2));
        for (int i = 0; i < 3; i++) {
            if (Math.abs((aLine.getEndY() - aLine.getStartY()) * p1[i].getX() - (aLine.getEndX() - aLine.getStartX()) * p1[i].getY() + aLine.getEndX() * aLine.getStartY() - aLine.getEndY()
                    * aLine.getStartX()) / Math.sqrt(Math.pow(aLine.getEndY() - aLine.getStartY(), 2) + Math.pow(aLine.getEndX() - aLine.getStartX(), 2)) > max) {
                max = Math.abs((aLine.getEndY() - aLine.getStartY()) * p1[i].getX() - (aLine.getEndX() - aLine.getStartX()) * p1[i].getY() + aLine.getEndX() * aLine.getStartY() - aLine.getEndY()
                        * aLine.getStartX()) / Math.sqrt(Math.pow(aLine.getEndY() - aLine.getStartY(), 2) + Math.pow(aLine.getEndX() - aLine.getStartX(), 2));
                maxPoint = i;
            }
 
        }
        String strValue = String.valueOf(max);
        g.drawString("Расстояние до самой дальней точки " + strValue, 10, 10);
 
        g.drawLine(30, 30, 100, 30);
 
        for (int j = 0; j < 3; j++) {
            if (j == maxPoint) {
                g.setColor(Color.red);
            } else {
                g.setColor(Color.green);
            }
            g.drawOval(p1[j].x, p1[j].y, 3, 3);
            g.fillOval(p1[j].x, p1[j].y, 3, 3);
        }
 
    }
 
}
Единственное, стоит помнить, что координаты в java считаются в верхнего левого угла, так что если вы хотите, чтобы график имел человеческий (принятый в математике вид), надо пересчитывать относительно какой-нибудь точки. Например, так:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
        //Рисуем координатные оси. Точка отсчета в т.(30,150)
        g.drawLine(30, 30, 30, 150);
        g.drawLine(25, 145, 300, 145);
        
        //рисуем прямую
        g.drawLine(60, 120, 130, 120);
       
        //рисуем и закрашиваем точки
        for (int j = 0; j < 3; j++) {
            if (j == maxPoint) {
                g.setColor(Color.red);
            } else {
                g.setColor(Color.green);
            }
            g.drawOval(p1[j].x+30, 150-p1[j].y, 3, 3);
            g.fillOval(30+p1[j].x, 150-p1[j].y, 3, 3);
        }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.03.2017, 11:41
Помогаю со студенческими работами здесь

Рисование точки
Здравствуйте! Подскажите, каким методом в GDI+ можно зарисовать пиксель? Пробовал рисовать линию с началом и концом в одной и той же точке...

Рисование точки в WindowsForms
Добрый день, уважаемые форумчане. Напишите, пожалуйста, полностью код, программы, которая бы рисовала точку.

Функция imagesetpixel — рисование точки
не получается нарисовать эту подлую точку. в приведенном примере http://php.net/manual/ru/function.imagesetpixel.php что-то намудрили что...

Вращение точки (рисование окружности)
Здравствуйте, уважаемые форумчане. У меня следующий вопрос. Почему когда рисуется окружность, все чуть-чуть скачет (влево, вправо, вверх,...

Рисование точки и окружности в PictureBox
Привет! у меня есть picturebox, на нём я по щелчку мышы хочу поставить точку радиусом R пикселей, а на обработке mousedown стоит вот такая...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru