Форум программистов, компьютерный форум, киберфорум
Java: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/25: Рейтинг темы: голосов - 25, средняя оценка - 4.88
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140

Построить линии уровня поверхности, используя библиотеку jfreeChart

25.10.2012, 06:17. Показов 5458. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Кто-нибудь юзал либу для построения графиков jfreeChart?
Необходимо построить линии уровня поверхности. Среди сэмплов нашел один пример, но исходного кода нет, и среди методов ChartFactory - класса содержащего методы, которые и определяют тип графика, нужного мне метода createXYBlockChart тоже нет. В общем может кто строил графики? Или предложите альтернативный быстрый вариант.

Добавлено через 8 часов 13 минут
Скажите а почему на этой строке
Java
1
XYDataset dataset = new XYSeriesCollection(series);
выполнение прерывается и компилятор выдает ошибку
Exception in thread "AWT-EventQueue-0" java.lang.NoClassDefFoundError: org/jfree/util/PublicCloneable
вот кусок кода
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
double maxRadius=10;
        double maxCorner=360;
        double corner,radius;
        double h1=0.1;
        double h2=1;
        corner=0;
        double z;
        double line=2;
        line=(float)f.func(x,y)+line;
        XYSeries series=new XYSeries("mydata");
        for(int i=0;i<=maxCorner/h1-1;i++){
            radius=0;
            for(int j=0;j<=maxRadius/h1;j++){
                z=(float)f.func(radius*java.lang.Math.cos(corner)+x,radius*java.lang.Math.sin(corner)+y);
                if(z>=line){
                    series.add(radius*java.lang.Math.cos(corner)+x, radius*java.lang.Math.sin(corner)+y);
                    break;
                }
                radius=radius+h1;
            }
            corner=corner+h1;
        }
        XYDataset dataset = new XYSeriesCollection(series);
        JFreeChart chart=ChartFactory.createPolarChart("График", dataset, true, true, true);
        
        jPanel12.add(new ChartPanel(chart));
Смотрел по примеру. И вроде все правильно - создаем объект класса XYSeriesCollection, который реализует интерфейс XYDataset. Вот ссылка на доку http://www.jfree.org/jfreechar... index.html

Добавлено через 26 минут
понял косяк - не все jar-файлы добавил
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.10.2012, 06:17
Ответы с готовыми решениями:

Помогите построить 3D bar chart в JFreeChart!!!!!
Всем здравствуйте! нет ли у кого примера построения 3D Bar Chart с использованием JFreeChart??? можно с Applet или Servlet...

График поверхности и линии уровня
Помогите построить график поверхности и линии уровня f(x,y) □(∶=) ( sin⁡ 2xy^3)/2+x

Линии (поверхности) уровня функций
Здравствуйте! Прошу помочь - как построить линии (поверхности) уровня функции: 1) u=x+4y+8z 2) z=x/y 3) z=min(4x,y)

6
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
29.10.2012, 09:29  [ТС]
Попробовал пока использовать статический метод класса ChartFactory, то есть построил график с дефолтными настройками. Получилась вот такая вот ерунда

вот класс создания этого графика
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
public class MyChart {
    private double x;
    private double y;
    private myfunc f;
    private double beginX, beginY;
    //JFreeChart chart;
    public MyChart(double x,double y, double beginX, double beginY, myfunc f){
        this.x=x;
        this.y=y;
        this.beginX=beginX;
        this.beginY=beginY;
        this.f=f;
 
    }
    private XYDataset createDataset(){
        double maxCorner=360;
        double maxRadius=Math.sqrt(beginX*beginX+beginY*beginY)+Math.sqrt(beginX*beginX+beginY*beginY)/6;
        double corner,radius;
        XYSeries series;
        double line;
        double z;
        double h1=0.01;
        double h2=0.1;
        double fixline=(f.func(beginX,beginY)-f.func(x, y))/6;
        double summ=f.func(x, y);
        double[] arrFix=new double[6];
        for(int i=0;i<6;i++){
            summ=summ+fixline;
            arrFix[i]=summ;
        }
        XYSeriesCollection mainSeries=new XYSeriesCollection();
        for(int i=0;i<6;i++){
            corner=0;
            line=arrFix[i];
            if(i==0){
               series=new XYSeries("0-"+String.valueOf(arrFix[i]));
            }
            else{
                series=new XYSeries(String.valueOf(arrFix[i-1])+"-"+String.valueOf(arrFix[i]));
            }
            for(int j=0;j<=maxCorner/h1-1;j++){
            radius=0;
            for(int k=0;k<=maxRadius/h1;k++){
                z=(float)f.func(radius*java.lang.Math.cos(corner)+x,radius*java.lang.Math.sin(corner)+y);
                if(z>=line){
                    series.add(radius*java.lang.Math.cos(corner)+x, radius*java.lang.Math.sin(corner)+y);
                    break;
                }
                radius=radius+h1;
            }
            corner=corner+h1;
        }
            mainSeries.addSeries(series);
        }
        //XYDataset dataset=mainSeries;
        return mainSeries;
    }
    private JFreeChart createChart(XYDataset dataset){
        return ChartFactory.createScatterPlot("График", "x", "y", dataset, PlotOrientation.HORIZONTAL, true, true, true);
    }
    public JFreeChart NewChart(){
        return createChart(createDataset());
    }
 
}
Вообще в целом программа нужна для оптимизации многомерных функций различными методами. Она работает только с квадратичными функциями, так как методы используемые в проге с другими работать 100% не могут. Ну не в этом дело.
Как элемент интерфейса необходимо реализовать построение линий уровня и изобразить на этих графиках итерационный процесс выбранного пользователем метода.
Для построения линии уровня используется метод createScatterPlot (все я не смотрел, этот первый удовлетворительный оказался). В доке информации минимум.
В полученном графике меня не устраивает:
  • линии толстые из-за наличия маркеров и разноцветные, нужно сделать все одним цветом
  • желательно, чтобы был какой-то фон между каждыми линиями
  • график строится очень долго
Первые две проблемы думаю можно решить использованием AreaRenderer и прописыванием каждого компонента графика вручную
На счет третьей нет пока никаких идей. Процесс построения линий уровня заключается в том, что я выбираю определенным образом несколько значений функции (их количество равно количеству линий уровня), далее с использованием полярных координат, предварительно смещая начало координат в точку оптимума, я тупо пробегаю по поверхности (сканирую, последовательно увеличивая радиус и угол), до тех пор пока значение ф-ции в текущей точке не перевалит за выбранное мной заранее значение функции.
В чем сложности по поводу первых двух моментов... Потратил уже кучу времени, роясь в документации - так и не понял однозначно что использовать, чтобы построить более рационально график. Может кто-то более менее разбирается с JFreeChart и мог бы меня направить куда надо. (Примеры кода в инете можно на пальцах посчитать).
Как иначе выбирать данные для построения линий уровня тоже пока никаких идей.
Поэтому может мне лучше написать кусок касающийся графиков на чем-нибудь еще и тупо вставить сохраненную картинку в окно программы(например к Excel нельзя обратиться через Java).
Также после построения линий уровня мне нужно будет изобразить на том же графике ступенчатый итерационный процесс. То есть совместить в одном chart два разных render'a получается.
Надеюсь кто-нибудь все же откликнется...
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
29.10.2012, 09:50  [ТС]
Хотя в ексель на одном графике вроде нельзя использовать различные типы диаграмм, ну я по крайней мере не сталкивался с этим
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
31.10.2012, 07:46  [ТС]
Не знаю есть ли смысл продолжать писать в эту тему, так как глухо как в танке... ни одного ответа...(
Добился пока вот такого результата

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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
package prihodko_lab;
//import java.lang.*;
import org.jfree.chart.JFreeChart;
//import org.jfree.chart.ChartFactory;
//import org.jfree.chart.ChartPanel;
//import org.jfree.chart.plot.PlotOrientation;
import org.jfree.data.xy.XYSeries;
import org.jfree.data.xy.XYSeriesCollection;
import org.jfree.data.xy.XYDataset;
import org.jfree.data.xy.XYZDataset;
//import org.jfree.data.xy.TableXYDataset;
//import org.jfree.chart.renderer.xy.XYBlockRenderer;
//import java.lang.Math;
//import org.jfree.data.xy.TableXYDataset;
//import org.jfree.data.xy.CategoryTableXYDataset;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.NumberTickUnit;
import org.jfree.chart.renderer.xy.VectorRenderer;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.renderer.xy.XYBlockRenderer;
//import org.jfree.chart.renderer.xy.XYBubbleRenderer;
import org.jfree.chart.plot.CombinedRangeXYPlot;
/**
 *
 * @author shepard90
 */
 
 
 
public class MyChart {
    private double x;
    private double y;
    private myfunc f;
    private double beginX, beginY;
    private double max;
    //JFreeChart chart;
    public MyChart(double x,double y, double beginX, double beginY, myfunc f){
        this.x=x;
        this.y=y;
        this.beginX=beginX;
        this.beginY=beginY;
        this.f=f;
 
    }
    private XYZDataset createDataset1(){
        double h=0.1;
        double diapX, diapY;
        diapX=2*Math.abs(beginX-x)+2;
        diapY=2*Math.abs(beginY-y)+2;
        double dx;
        double dy;
        dx=x-diapX/2;
        dy=y-diapY/2;
        int countX,countY;
        countX=Math.round((float)(diapX/h)+1);
        countY=Math.round((float)(diapY/h)+1);
        double[][] series=new double[3][countX*countY];
        double[] a=new double[countX];
        double[] b=new double[countY];
        for(int i=0;i<countX;i++){
            a[i]=dx;
            dx=dx+h;
        }
        for(int i=0;i<countY;i++){
            b[i]=dy;
            dy=dy+h;
        }
        max=f.func(a[0], b[0]);
 
        for(int i=0;i<countX;i++){
            for(int j=0;j<countY;j++){
                series[0][i*countY+j]=a[i];
                series[1][i*countY+j]=b[j];
                series[2][i*countY+j]=f.func(a[i], b[j]);
                if(max<f.func(a[i], b[j])){
                    max=f.func(a[i], b[j]);
                }
            }
            
        }
        java.lang.Comparable j=new java.lang.Integer(5);
        org.jfree.data.xy.DefaultXYZDataset ddataset=new org.jfree.data.xy.DefaultXYZDataset();
        ddataset.addSeries(j, series);
        XYZDataset dataset=ddataset;
        return dataset;
    }
    private XYDataset createDataset2(){
        double maxCorner=360;
        double maxRadius=Math.sqrt(beginX*beginX+beginY*beginY)+Math.sqrt(beginX*beginX+beginY*beginY)/6;
        double corner,radius;
        XYSeries series;
        double line;
        double z;
        double h1=0.1;
        double h2=1;
        double fixline=(f.func(beginX,beginY)-f.func(x, y))/6;
        double summ=f.func(x, y);
        double[] arrFix=new double[6];
        for(int i=0;i<6;i++){
            summ=summ+fixline;
            arrFix[i]=summ;
        }
        XYSeriesCollection mainSeries=new XYSeriesCollection();
        for(int i=0;i<6;i++){
            corner=0;
            line=arrFix[i];
            if(i==0){
               series=new XYSeries("0-"+String.valueOf(arrFix[i]));
            }
            else{
                series=new XYSeries(String.valueOf(arrFix[i-1])+"-"+String.valueOf(arrFix[i]));
            }
            for(int j=0;j<=maxCorner/h1-1;j++){
            radius=0;
            for(int k=0;k<=maxRadius/h1;k++){
                z=(float)f.func(radius*java.lang.Math.cos(corner)+x,radius*java.lang.Math.sin(corner)+y);
                if(z>=line){
                    series.add(radius*java.lang.Math.cos(corner)+x, radius*java.lang.Math.sin(corner)+y);
                    break;
                }
                radius=radius+h1;
            }
            corner=corner+h1;
        }
            mainSeries.addSeries(series);
        }
        //XYDataset dataset=mainSeries;
        return mainSeries;
    }
    private JFreeChart createChart(XYZDataset dataset1, XYDataset dataset2){
        //return ChartFactory.createScatterPlot("График", "x", "y", dataset, PlotOrientation.HORIZONTAL, true, true, true);
        NumberAxis axisX=new NumberAxis("x");
        axisX.setPositiveArrowVisible(true);
         axisX.setStandardTickUnits(NumberAxis.createStandardTickUnits());
        axisX.setTickUnit(new NumberTickUnit(1));
        NumberAxis axisY=new NumberAxis("y");
        axisY.setPositiveArrowVisible(true);
         axisY.setStandardTickUnits(NumberAxis.createStandardTickUnits());
        axisY.setTickUnit(new NumberTickUnit(1));
        //PaintScale
        org.jfree.chart.renderer.GrayPaintScale scale=new org.jfree.chart.renderer.GrayPaintScale(Math.round(f.func(x, y)),this.max);
        //renderer
        XYBlockRenderer renderer1=new XYBlockRenderer();
 
        renderer1.setPaintScale(scale);
        VectorRenderer renderer2=new VectorRenderer();
        for(int i=0;i<6;i++){
            renderer2.setSeriesPaint(i, java.awt.Color.BLACK);
        }
        /*for(int i=0;i<6;i++){
            renderer1.setSeriesPaint(i, java.awt.Color.BLACK);
        }*/
        //plot
        XYPlot subplot1=new XYPlot(dataset1,axisX,axisY,renderer1);
        XYPlot subplot2=new XYPlot(dataset2,axisX,axisY,renderer2);
        //subplot1.setBackgroundPaint(java.awt.Color.WHITE);
        CombinedRangeXYPlot plot=new CombinedRangeXYPlot();
        plot.add(subplot1);
        plot.add(subplot2);
        return new JFreeChart(plot);
    }
    public JFreeChart NewChart(){
        return createChart(createDataset1(),createDataset2());
    }
 
}
Использовал CombinedRangeXYPlot, то есть объединил два XYPlot'a, которым соответствуют свои рендереры и данные. для первого графика использовал XYBlockRenderer и XYZDataset, для второго - VectorRenderer и XYDataset.
Теперь вопрос: как слить два эти графика в один? Видел примеры в виде изображений, где в одном графике заключены несколько разных рендереров, но исходного кода к этим примерам не нашел.
Например вот
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
31.10.2012, 10:27  [ТС]
вообще существует два класса для построения комбинированных графиков: CombinedRangeXYPlot и CombinedDomainXYPlot -объединение по оси y и по оси x соответственно. Вот как скомбинировать графики по двум осям???

Добавлено через 1 час 53 минуты
Мда... не в ту степь меня понесло, не заметил, что у XYPlot есть методы, которые позволяют добавлять renderer и dataset по индексу
0
 Аватар для mutagen
2587 / 2260 / 257
Регистрация: 14.09.2011
Сообщений: 5,185
Записей в блоге: 18
31.10.2012, 17:06
Глухо видимо потому что местные форумчане не пользуются этой библиотекой, Вам лучше поискать форум поближе к разработчикам, ссылку не даю - правила обязывают
0
6 / 6 / 3
Регистрация: 18.10.2010
Сообщений: 140
02.11.2012, 00:47  [ТС]
Цитата Сообщение от mutagen Посмотреть сообщение
Глухо видимо потому что местные форумчане не пользуются этой библиотекой, Вам лучше поискать форум поближе к разработчикам, ссылку не даю - правила обязывают
Специализированные форумы в основном на английском, а я им к сожалению не владею(
Ну в принципе уже разобрался, осталось только там да сям подправить и все
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.11.2012, 00:47
Помогаю со студенческими работами здесь

Построить линии равного уровня (линии контура)
Ребята нужна строчная помощь нужно построить линии уровня функции Z=100*(x2-x1^3)^2+(1-x1)^2; в интервале x1 x2 Буду по гроб...

Отображение поверхности с помощью surf и линии уровня ezcontour
В одном графическом окне отобразить поверхностью с помощью surf и линии уровня ezcontour. syms x y; a=4; b=5; z=...

Найти и построить линии уровня
Найти и построить линии уровня функции z=arcsin(xy).Помогите пожалуйсто,спасибо.

Найти и построить линии уровня функций
z=x*x*y z=ln(x*x+y*y)

Построить линии уровня исходя из данных в файле
Имеется текстовый файл, в котором через пробел записано X Y f(X,Y), можно ли в maple построить линии уровня исходя из данных в файле? если...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
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, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru